function FileSaveHtaccessLoggingTest::testHtaccessSave
Same name in other branches
- 9 core/modules/system/tests/src/Functional/File/FileSaveHtaccessLoggingTest.php \Drupal\Tests\system\Functional\File\FileSaveHtaccessLoggingTest::testHtaccessSave()
- 8.9.x core/modules/system/tests/src/Functional/File/FileSaveHtaccessLoggingTest.php \Drupal\Tests\system\Functional\File\FileSaveHtaccessLoggingTest::testHtaccessSave()
- 11.x core/modules/system/tests/src/Functional/File/FileSaveHtaccessLoggingTest.php \Drupal\Tests\system\Functional\File\FileSaveHtaccessLoggingTest::testHtaccessSave()
Tests file_save_htaccess().
File
-
core/
modules/ system/ tests/ src/ Functional/ File/ FileSaveHtaccessLoggingTest.php, line 30
Class
- FileSaveHtaccessLoggingTest
- Tests the log message added by file_save_htaccess().
Namespace
Drupal\Tests\system\Functional\FileCode
public function testHtaccessSave() : void {
// Prepare test directories.
$private = $this->publicFilesDirectory . '/test/private';
// Verify that file_save_htaccess() returns FALSE if .htaccess cannot be
// written and writes a correctly formatted message to the error log. Set
// $private to TRUE so all possible .htaccess lines are written.
/** @var \Drupal\Core\File\HtaccessWriterInterface $htaccess */
$htaccess = \Drupal::service('file.htaccess_writer');
$this->assertFalse($htaccess->write($private, TRUE));
$this->drupalLogin($this->drupalCreateUser([
'access site reports',
]));
$this->drupalGet('admin/reports/dblog');
$this->clickLink("Security warning: Couldn't write .htaccess file.");
$lines = FileSecurity::htaccessLines(TRUE);
foreach (array_filter(explode("\n", $lines)) as $line) {
$this->assertSession()
->assertEscaped($line);
}
}
Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.