class ExtensionListTest in Drupal 9
Same name and namespace in other branches
- 8 core/tests/Drupal/Tests/Core/Extension/ExtensionListTest.php \Drupal\Tests\Core\Extension\ExtensionListTest
@coversDefaultClass \Drupal\Core\Extension\ExtensionList @group Extension
Hierarchy
- class \Drupal\Tests\UnitTestCase extends \PHPUnit\Framework\TestCase uses \Symfony\Bridge\PhpUnit\ExpectDeprecationTrait, PhpUnitCompatibilityTrait, PhpUnitWarnings
- class \Drupal\Tests\Core\Extension\ExtensionListTest
Expanded class hierarchy of ExtensionListTest
File
- core/
tests/ Drupal/ Tests/ Core/ Extension/ ExtensionListTest.php, line 22
Namespace
Drupal\Tests\Core\ExtensionView source
class ExtensionListTest extends UnitTestCase {
/**
* @covers ::getName
*/
public function testGetNameWithNonExistingExtension() {
list($cache, $info_parser, $module_handler, $state) = $this
->getMocks();
$test_extension_list = new TestExtension($this
->randomMachineName(), 'test_extension', $cache
->reveal(), $info_parser
->reveal(), $module_handler
->reveal(), $state
->reveal(), 'testing');
$extension_discovery = $this
->prophesize(ExtensionDiscovery::class);
$extension_discovery
->scan('test_extension')
->willReturn([]);
$test_extension_list
->setExtensionDiscovery($extension_discovery
->reveal());
$this
->expectException(UnknownExtensionException::class);
$test_extension_list
->getName('test_name');
}
/**
* @covers ::getName
*/
public function testGetName() {
$test_extension_list = $this
->setupTestExtensionList();
$this
->assertEquals('test name', $test_extension_list
->getName('test_name'));
}
/**
* @covers ::get
*/
public function testGetWithNonExistingExtension() {
list($cache, $info_parser, $module_handler, $state) = $this
->getMocks();
$test_extension_list = new TestExtension($this
->randomMachineName(), 'test_extension', $cache
->reveal(), $info_parser
->reveal(), $module_handler
->reveal(), $state
->reveal(), 'testing');
$extension_discovery = $this
->prophesize(ExtensionDiscovery::class);
$extension_discovery
->scan('test_extension')
->willReturn([]);
$test_extension_list
->setExtensionDiscovery($extension_discovery
->reveal());
$this
->expectException(UnknownExtensionException::class);
$test_extension_list
->get('test_name');
}
/**
* @covers ::get
*/
public function testGet() {
$test_extension_list = $this
->setupTestExtensionList();
$extension = $test_extension_list
->get('test_name');
$this
->assertInstanceOf(Extension::class, $extension);
$this
->assertEquals('test_name', $extension
->getName());
}
/**
* @covers ::getList
*/
public function testGetList() {
$test_extension_list = $this
->setupTestExtensionList();
$extensions = $test_extension_list
->getList();
$this
->assertCount(1, $extensions);
$this
->assertEquals('test_name', $extensions['test_name']
->getName());
}
/**
* @covers ::getExtensionInfo
* @covers ::getAllInstalledInfo
*/
public function testGetExtensionInfo() {
$test_extension_list = $this
->setupTestExtensionList();
$test_extension_list
->setInstalledExtensions([
'test_name',
]);
$info = $test_extension_list
->getExtensionInfo('test_name');
$this
->assertEquals([
'type' => 'test_extension',
'core' => '8.x',
'name' => 'test name',
'mtime' => 123456789,
], $info);
}
/**
* @covers ::getAllAvailableInfo
*/
public function testGetAllAvailableInfo() {
$test_extension_list = $this
->setupTestExtensionList();
$infos = $test_extension_list
->getAllAvailableInfo();
$this
->assertEquals([
'test_name' => [
'type' => 'test_extension',
'core' => '8.x',
'name' => 'test name',
'mtime' => 123456789,
],
], $infos);
}
/**
* @covers ::getAllInstalledInfo
*/
public function testGetAllInstalledInfo() {
$test_extension_list = $this
->setupTestExtensionList([
'test_name',
'test_name_2',
]);
$test_extension_list
->setInstalledExtensions([
'test_name_2',
]);
$infos = $test_extension_list
->getAllInstalledInfo();
$this
->assertEquals([
'test_name_2' => [
'type' => 'test_extension',
'core' => '8.x',
'name' => 'test name',
'mtime' => 123456789,
],
], $infos);
}
/**
* @covers ::getPathnames
*/
public function testGetPathnames() {
$test_extension_list = $this
->setupTestExtensionList();
$filenames = $test_extension_list
->getPathnames();
$this
->assertEquals([
'test_name' => 'example/test_name/test_name.info.yml',
], $filenames);
}
/**
* @covers ::getPathname
*/
public function testGetPathname() {
$test_extension_list = $this
->setupTestExtensionList();
$pathname = $test_extension_list
->getPathname('test_name');
$this
->assertEquals('example/test_name/test_name.info.yml', $pathname);
}
/**
* @covers ::setPathname
* @covers ::getPathname
*/
public function testSetPathname() {
$test_extension_list = $this
->setupTestExtensionList();
$test_extension_list
->setPathname('test_name', 'vfs://drupal_root/example2/test_name/test_name.info.yml');
$this
->assertEquals('vfs://drupal_root/example2/test_name/test_name.info.yml', $test_extension_list
->getPathname('test_name'));
}
/**
* @covers ::getPath
*/
public function testGetPath() {
$test_extension_list = $this
->setupTestExtensionList();
$path = $test_extension_list
->getPath('test_name');
$this
->assertEquals('example/test_name', $path);
}
/**
* @covers ::reset
*/
public function testReset() {
$test_extension_list = $this
->setupTestExtensionList();
$path = $test_extension_list
->getPath('test_name');
$this
->assertEquals('example/test_name', $path);
$pathname = $test_extension_list
->getPathname('test_name');
$this
->assertEquals('example/test_name/test_name.info.yml', $pathname);
$filenames = $test_extension_list
->getPathnames();
$this
->assertEquals([
'test_name' => 'example/test_name/test_name.info.yml',
], $filenames);
$test_extension_list
->reset();
// Ensure that everything is still usable after the resetting.
$path = $test_extension_list
->getPath('test_name');
$this
->assertEquals('example/test_name', $path);
$pathname = $test_extension_list
->getPathname('test_name');
$this
->assertEquals('example/test_name/test_name.info.yml', $pathname);
$filenames = $test_extension_list
->getPathnames();
$this
->assertEquals([
'test_name' => 'example/test_name/test_name.info.yml',
], $filenames);
}
/**
* @covers ::checkIncompatibility
*
* @dataProvider providerCheckIncompatibility
*/
public function testCheckIncompatibility($additional_settings, $expected) {
$test_extension_list = $this
->setupTestExtensionList([
'test_name',
], $additional_settings);
$this
->assertSame($expected, $test_extension_list
->checkIncompatibility('test_name'));
}
/**
* DataProvider for testCheckIncompatibility().
*/
public function providerCheckIncompatibility() {
return [
'core_incompatible true' => [
[
'core_incompatible' => TRUE,
],
TRUE,
],
'core_incompatible false' => [
[
'core_incompatible' => FALSE,
],
FALSE,
],
'PHP 1, core_incompatible FALSE' => [
[
'core_incompatible' => FALSE,
'php' => 1,
],
FALSE,
],
'PHP 1000000000000, core_incompatible FALSE' => [
[
'core_incompatible' => FALSE,
'php' => 1000000000000,
],
TRUE,
],
'PHP 1, core_incompatible TRUE' => [
[
'core_incompatible' => TRUE,
'php' => 1,
],
TRUE,
],
'PHP 1000000000000, core_incompatible TRUE' => [
[
'core_incompatible' => TRUE,
'php' => 1000000000000,
],
TRUE,
],
];
}
/**
* Sets up an a test extension list.
*
* @param string[] $extension_names
* The names of the extensions to create.
* @param mixed[] $additional_info_values
* The additional values to add to extensions info.yml files. These values
* will be encoded using '\Drupal\Component\Serialization\Yaml::encode()'.
* The array keys should be valid top level yaml file keys.
*
* @return \Drupal\Tests\Core\Extension\TestExtension
* The test extension list.
*/
protected function setupTestExtensionList(array $extension_names = [
'test_name',
], array $additional_info_values = []) {
vfsStream::setup('drupal_root');
$folders = [
'example' => [],
];
foreach ($extension_names as $extension_name) {
$folders['example'][$extension_name][$extension_name . '.info.yml'] = Yaml::encode([
'name' => 'test name',
'type' => 'test_extension',
'core' => '8.x',
] + $additional_info_values);
}
vfsStream::create($folders);
foreach ($extension_names as $extension_name) {
touch("vfs://drupal_root/example/{$extension_name}/{$extension_name}.info.yml", 123456789);
}
list($cache, $info_parser, $module_handler, $state) = $this
->getMocks();
$info_parser
->parse(Argument::any())
->will(function ($args) {
return Yaml::decode(file_get_contents('vfs://drupal_root/' . $args[0]));
});
$test_extension_list = new TestExtension('vfs://drupal_root', 'test_extension', $cache
->reveal(), $info_parser
->reveal(), $module_handler
->reveal(), $state
->reveal(), 'testing');
$extension_discovery = $this
->prophesize(ExtensionDiscovery::class);
$extension_scan_result = [];
foreach ($extension_names as $extension_name) {
$extension_scan_result[$extension_name] = new Extension('vfs://drupal_root', 'test_extension', "example/{$extension_name}/{$extension_name}.info.yml");
}
$extension_discovery
->scan('test_extension')
->willReturn($extension_scan_result);
$test_extension_list
->setExtensionDiscovery($extension_discovery
->reveal());
return $test_extension_list;
}
protected function getMocks() {
$cache = $this
->prophesize(CacheBackendInterface::class);
$info_parser = $this
->prophesize(InfoParserInterface::class);
$module_handler = $this
->prophesize(ModuleHandlerInterface::class);
$state = $this
->prophesize(StateInterface::class);
return [
$cache,
$info_parser,
$module_handler,
$state,
];
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
ExtensionListTest:: |
protected | function | ||
ExtensionListTest:: |
public | function | DataProvider for testCheckIncompatibility(). | |
ExtensionListTest:: |
protected | function | Sets up an a test extension list. | |
ExtensionListTest:: |
public | function | @covers ::checkIncompatibility | |
ExtensionListTest:: |
public | function | @covers ::get | |
ExtensionListTest:: |
public | function | @covers ::getAllAvailableInfo | |
ExtensionListTest:: |
public | function | @covers ::getAllInstalledInfo | |
ExtensionListTest:: |
public | function | @covers ::getExtensionInfo @covers ::getAllInstalledInfo | |
ExtensionListTest:: |
public | function | @covers ::getList | |
ExtensionListTest:: |
public | function | @covers ::getName | |
ExtensionListTest:: |
public | function | @covers ::getName | |
ExtensionListTest:: |
public | function | @covers ::getPath | |
ExtensionListTest:: |
public | function | @covers ::getPathname | |
ExtensionListTest:: |
public | function | @covers ::getPathnames | |
ExtensionListTest:: |
public | function | @covers ::get | |
ExtensionListTest:: |
public | function | @covers ::reset | |
ExtensionListTest:: |
public | function | @covers ::setPathname @covers ::getPathname | |
PhpUnitWarnings:: |
private static | property | Deprecation warnings from PHPUnit to raise with @trigger_error(). | |
PhpUnitWarnings:: |
public | function | Converts PHPUnit deprecation warnings to E_USER_DEPRECATED. | |
UnitTestCase:: |
protected | property | The random generator. | |
UnitTestCase:: |
protected | property | The app root. | 1 |
UnitTestCase:: |
protected | function | Asserts if two arrays are equal by sorting them first. | |
UnitTestCase:: |
protected | function | Returns a stub class resolver. | |
UnitTestCase:: |
public | function | Returns a stub config factory that behaves according to the passed 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. | |
UnitTestCase:: |
protected | function | 308 | |
UnitTestCase:: |
public static | function |