function FileSaveHtaccessLoggingTest::testHtaccessSave

Same name in other branches
  1. 9 core/modules/system/tests/src/Functional/File/FileSaveHtaccessLoggingTest.php \Drupal\Tests\system\Functional\File\FileSaveHtaccessLoggingTest::testHtaccessSave()
  2. 8.9.x core/modules/system/tests/src/Functional/File/FileSaveHtaccessLoggingTest.php \Drupal\Tests\system\Functional\File\FileSaveHtaccessLoggingTest::testHtaccessSave()
  3. 10 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\File

Code

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.