class FileSystemTest in Zircon Profile 8
Same name and namespace in other branches
- 8.0 core/tests/Drupal/Tests/Core/File/FileSystemTest.php \Drupal\Tests\Core\File\FileSystemTest
@coversDefaultClass \Drupal\Core\File\FileSystem
@group File
Hierarchy
- class \Drupal\Tests\UnitTestCase extends \Drupal\Tests\PHPUnit_Framework_TestCase
- class \Drupal\Tests\Core\File\FileSystemTest
Expanded class hierarchy of FileSystemTest
File
- core/
tests/ Drupal/ Tests/ Core/ File/ FileSystemTest.php, line 20 - Contains \Drupal\Tests\Core\File\FileSystemTest.
Namespace
Drupal\Tests\Core\FileView source
class FileSystemTest extends UnitTestCase {
/**
* @var \Drupal\Core\File\FileSystem
*/
protected $fileSystem;
/**
* The file logger channel.
*
* @var \Psr\Log\LoggerInterface|\PHPUnit_Framework_MockObject_MockObject
*/
protected $logger;
/**
* {@inheritdoc}
*/
protected function setUp() {
parent::setUp();
$settings = new Settings([]);
$stream_wrapper_manager = $this
->getMock('Drupal\\Core\\StreamWrapper\\StreamWrapperManagerInterface');
$this->logger = $this
->getMock('Psr\\Log\\LoggerInterface');
$this->fileSystem = new FileSystem($stream_wrapper_manager, $settings, $this->logger);
}
/**
* @covers ::chmod
*/
public function testChmodFile() {
vfsStream::setup('dir');
vfsStream::create([
'test.txt' => 'asdf',
]);
$uri = 'vfs://dir/test.txt';
$this
->assertTrue($this->fileSystem
->chmod($uri));
$this
->assertFilePermissions(FileSystem::CHMOD_FILE, $uri);
$this
->assertTrue($this->fileSystem
->chmod($uri, 0444));
$this
->assertFilePermissions(0444, $uri);
}
/**
* @covers ::chmod
*/
public function testChmodDir() {
vfsStream::setup('dir');
vfsStream::create([
'nested_dir' => [],
]);
$uri = 'vfs://dir/nested_dir';
$this
->assertTrue($this->fileSystem
->chmod($uri));
$this
->assertFilePermissions(FileSystem::CHMOD_DIRECTORY, $uri);
$this
->assertTrue($this->fileSystem
->chmod($uri, 0444));
$this
->assertFilePermissions(0444, $uri);
}
/**
* @covers ::chmod
*/
public function testChmodUnsuccessful() {
vfsStream::setup('dir');
$this->logger
->expects($this
->once())
->method('error');
$this
->assertFalse($this->fileSystem
->chmod('vfs://dir/test.txt'));
}
/**
* @covers ::unlink
*/
public function testUnlink() {
vfsStream::setup('dir');
vfsStream::create([
'test.txt' => 'asdf',
]);
$uri = 'vfs://dir/test.txt';
$this->fileSystem = $this
->getMockBuilder('Drupal\\Core\\File\\FileSystem')
->disableOriginalConstructor()
->setMethods([
'validScheme',
])
->getMock();
$this->fileSystem
->expects($this
->once())
->method('validScheme')
->willReturn(TRUE);
$this
->assertFileExists($uri);
$this->fileSystem
->unlink($uri);
$this
->assertFileNotExists($uri);
}
/**
* @covers ::basename
*
* @dataProvider providerTestBasename
*/
public function testBasename($uri, $expected, $suffix = NULL) {
$this
->assertSame($expected, $this->fileSystem
->basename($uri, $suffix));
}
public function providerTestBasename() {
$data = [];
$data[] = [
'public://nested/dir',
'dir',
];
$data[] = [
'public://dir/test.txt',
'test.txt',
];
$data[] = [
'public://dir/test.txt',
'test',
'.txt',
];
return $data;
}
/**
* @covers ::uriScheme
*
* @dataProvider providerTestUriScheme
*/
public function testUriScheme($uri, $expected) {
$this
->assertSame($expected, $this->fileSystem
->uriScheme($uri));
}
public function providerTestUriScheme() {
$data = [];
$data[] = [
'public://filename',
'public',
];
$data[] = [
'public://extra://',
'public',
];
$data[] = [
'invalid',
FALSE,
];
return $data;
}
/**
* Asserts that the file permissions of a given URI matches.
*
* @param int $expected_mode
* @param string $uri
* @param string $message
*/
protected function assertFilePermissions($expected_mode, $uri, $message = '') {
// Mask out all but the last three octets.
$actual_mode = fileperms($uri) & 0777;
// PHP on Windows has limited support for file permissions. Usually each of
// "user", "group" and "other" use one octal digit (3 bits) to represent the
// read/write/execute bits. On Windows, chmod() ignores the "group" and
// "other" bits, and fileperms() returns the "user" bits in all three
// positions. $expected_mode is updated to reflect this.
if (substr(PHP_OS, 0, 3) == 'WIN') {
// Reset the "group" and "other" bits.
$expected_mode = $expected_mode & 0700;
// Shift the "user" bits to the "group" and "other" positions also.
$expected_mode = $expected_mode | $expected_mode >> 3 | $expected_mode >> 6;
}
$this
->assertSame($expected_mode, $actual_mode, $message);
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
FileSystemTest:: |
protected | property | ||
FileSystemTest:: |
protected | property | The file logger channel. | |
FileSystemTest:: |
protected | function | Asserts that the file permissions of a given URI matches. | |
FileSystemTest:: |
public | function | ||
FileSystemTest:: |
public | function | ||
FileSystemTest:: |
protected | function |
Overrides UnitTestCase:: |
|
FileSystemTest:: |
public | function | @covers ::basename | |
FileSystemTest:: |
public | function | @covers ::chmod | |
FileSystemTest:: |
public | function | @covers ::chmod | |
FileSystemTest:: |
public | function | @covers ::chmod | |
FileSystemTest:: |
public | function | @covers ::unlink | |
FileSystemTest:: |
public | function | @covers ::uriScheme | |
UnitTestCase:: |
protected | property | The random generator. | |
UnitTestCase:: |
protected | property | The app root. | |
UnitTestCase:: |
protected | function | Asserts if two arrays are equal by sorting them first. | |
UnitTestCase:: |
protected | function | Mocks a block with a block plugin. | |
UnitTestCase:: |
protected | function | Returns a stub class resolver. | |
UnitTestCase:: |
public | function | Returns a stub config factory that behaves according to the passed in array. | |
UnitTestCase:: |
public | function | Returns a stub config storage that returns the supplied configuration. | |
UnitTestCase:: |
protected | function | Sets up a container with a cache tags invalidator. | |
UnitTestCase:: |
protected | function | Gets the random generator for the utility methods. | |
UnitTestCase:: |
public | function | Returns a stub translation manager that just returns the passed string. | |
UnitTestCase:: |
public | function | Generates a unique random string containing letters and numbers. |