class ConfigEntityMapperTest in Drupal 9
Same name and namespace in other branches
- 8 core/modules/config_translation/tests/src/Unit/ConfigEntityMapperTest.php \Drupal\Tests\config_translation\Unit\ConfigEntityMapperTest
Tests the functionality provided by the configuration entity mapper.
@group config_translation
Hierarchy
- class \Drupal\Tests\UnitTestCase extends \PHPUnit\Framework\TestCase uses \Symfony\Bridge\PhpUnit\ExpectDeprecationTrait, PhpUnitCompatibilityTrait, PhpUnitWarnings
- class \Drupal\Tests\config_translation\Unit\ConfigEntityMapperTest
Expanded class hierarchy of ConfigEntityMapperTest
File
- core/
modules/ config_translation/ tests/ src/ Unit/ ConfigEntityMapperTest.php, line 15
Namespace
Drupal\Tests\config_translation\UnitView source
class ConfigEntityMapperTest extends UnitTestCase {
/**
* The configuration entity mapper to test.
*
* @var \Drupal\config_translation\ConfigEntityMapper
*/
protected $configEntityMapper;
/**
* The entity type manager used for testing.
*
* @var \Drupal\Core\Entity\EntityTypeManagerInterface|\PHPUnit\Framework\MockObject\MockObject
*/
protected $entityTypeManager;
/**
* The entity instance used for testing.
*
* @var \Drupal\Core\Entity\EntityInterface|\PHPUnit\Framework\MockObject\MockObject
*/
protected $entity;
/**
* The route provider used for testing.
*
* @var \Drupal\Core\Routing\RouteProviderInterface|\PHPUnit\Framework\MockObject\MockObject
*/
protected $routeProvider;
/**
* The mocked language manager.
*
* @var \Drupal\Core\Language\LanguageManagerInterface|\PHPUnit\Framework\MockObject\MockObject
*/
protected $languageManager;
/**
* The mocked event dispatcher.
*
* @var \Symfony\Contracts\EventDispatcher\EventDispatcherInterface|\PHPUnit\Framework\MockObject\MockObject
*/
protected $eventDispatcher;
protected function setUp() : void {
$this->entityTypeManager = $this
->createMock('Drupal\\Core\\Entity\\EntityTypeManagerInterface');
$this->entity = $this
->createMock('Drupal\\Core\\Config\\Entity\\ConfigEntityInterface');
$this->routeProvider = $this
->createMock('Drupal\\Core\\Routing\\RouteProviderInterface');
$this->routeProvider
->expects($this
->any())
->method('getRouteByName')
->with('entity.configurable_language.edit_form')
->will($this
->returnValue(new Route('/admin/config/regional/language/edit/{configurable_language}')));
$definition = [
'class' => '\\Drupal\\config_translation\\ConfigEntityMapper',
'base_route_name' => 'entity.configurable_language.edit_form',
'title' => '@label language',
'names' => [],
'entity_type' => 'configurable_language',
'route_name' => 'config_translation.item.overview.entity.configurable_language.edit_form',
];
$typed_config_manager = $this
->createMock('Drupal\\Core\\Config\\TypedConfigManagerInterface');
$locale_config_manager = $this
->getMockBuilder('Drupal\\locale\\LocaleConfigManager')
->disableOriginalConstructor()
->getMock();
$this->languageManager = $this
->createMock('Drupal\\Core\\Language\\LanguageManagerInterface');
$this->eventDispatcher = $this
->createMock('Symfony\\Contracts\\EventDispatcher\\EventDispatcherInterface');
$this->configEntityMapper = new ConfigEntityMapper('configurable_language', $definition, $this
->getConfigFactoryStub(), $typed_config_manager, $locale_config_manager, $this
->createMock('Drupal\\config_translation\\ConfigMapperManagerInterface'), $this->routeProvider, $this
->getStringTranslationStub(), $this->entityTypeManager, $this->languageManager, $this->eventDispatcher);
}
/**
* Tests ConfigEntityMapper::setEntity() and ConfigEntityMapper::getEntity().
*/
public function testEntityGetterAndSetter() {
$this->entity
->expects($this
->once())
->method('id')
->with()
->will($this
->returnValue('entity_id'));
$entity_type = $this
->createMock('Drupal\\Core\\Config\\Entity\\ConfigEntityTypeInterface');
$entity_type
->expects($this
->any())
->method('getConfigPrefix')
->will($this
->returnValue('config_prefix'));
$this->entityTypeManager
->expects($this
->once())
->method('getDefinition')
->with('configurable_language')
->will($this
->returnValue($entity_type));
// No entity is set.
$this
->assertNull($this->configEntityMapper
->getEntity());
$result = $this->configEntityMapper
->setEntity($this->entity);
$this
->assertTrue($result);
// Ensure that the getter provides the entity.
$this
->assertEquals($this->entity, $this->configEntityMapper
->getEntity());
// Ensure that the configuration name was added to the mapper.
$plugin_definition = $this->configEntityMapper
->getPluginDefinition();
$this
->assertContains('config_prefix.entity_id', $plugin_definition['names']);
// Make sure setEntity() returns FALSE when called a second time.
$result = $this->configEntityMapper
->setEntity($this->entity);
$this
->assertFalse($result);
}
/**
* Tests ConfigEntityMapper::getOverviewRouteParameters().
*/
public function testGetOverviewRouteParameters() {
$entity_type = $this
->createMock('Drupal\\Core\\Config\\Entity\\ConfigEntityTypeInterface');
$this->entityTypeManager
->expects($this
->once())
->method('getDefinition')
->with('configurable_language')
->will($this
->returnValue($entity_type));
$this->configEntityMapper
->setEntity($this->entity);
$this->entity
->expects($this
->once())
->method('id')
->with()
->will($this
->returnValue('entity_id'));
$result = $this->configEntityMapper
->getOverviewRouteParameters();
$this
->assertSame([
'configurable_language' => 'entity_id',
], $result);
}
/**
* Tests ConfigEntityMapper::getType().
*/
public function testGetType() {
$result = $this->configEntityMapper
->getType();
$this
->assertSame('configurable_language', $result);
}
/**
* Tests ConfigEntityMapper::getTypeName().
*/
public function testGetTypeName() {
$entity_type = $this
->createMock('Drupal\\Core\\Config\\Entity\\ConfigEntityTypeInterface');
$entity_type
->expects($this
->once())
->method('getLabel')
->will($this
->returnValue('test'));
$this->entityTypeManager
->expects($this
->once())
->method('getDefinition')
->with('configurable_language')
->will($this
->returnValue($entity_type));
$result = $this->configEntityMapper
->getTypeName();
$this
->assertSame('test', $result);
}
/**
* Tests ConfigEntityMapper::getTypeLabel().
*/
public function testGetTypeLabel() {
$entity_type = $this
->createMock('Drupal\\Core\\Config\\Entity\\ConfigEntityTypeInterface');
$entity_type
->expects($this
->once())
->method('getLabel')
->will($this
->returnValue('test'));
$this->entityTypeManager
->expects($this
->once())
->method('getDefinition')
->with('configurable_language')
->will($this
->returnValue($entity_type));
$result = $this->configEntityMapper
->getTypeLabel();
$this
->assertSame('test', $result);
}
/**
* Tests ConfigEntityMapper::getOperations().
*/
public function testGetOperations() {
$result = $this->configEntityMapper
->getOperations();
$expected = [
'list' => [
'title' => 'List',
'url' => Url::fromRoute('config_translation.entity_list', [
'mapper_id' => 'configurable_language',
]),
],
];
$this
->assertEquals($expected, $result);
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
ConfigEntityMapperTest:: |
protected | property | The configuration entity mapper to test. | |
ConfigEntityMapperTest:: |
protected | property | The entity instance used for testing. | |
ConfigEntityMapperTest:: |
protected | property | The entity type manager used for testing. | |
ConfigEntityMapperTest:: |
protected | property | The mocked event dispatcher. | |
ConfigEntityMapperTest:: |
protected | property | The mocked language manager. | |
ConfigEntityMapperTest:: |
protected | property | The route provider used for testing. | |
ConfigEntityMapperTest:: |
protected | function |
Overrides UnitTestCase:: |
|
ConfigEntityMapperTest:: |
public | function | Tests ConfigEntityMapper::setEntity() and ConfigEntityMapper::getEntity(). | |
ConfigEntityMapperTest:: |
public | function | Tests ConfigEntityMapper::getOperations(). | |
ConfigEntityMapperTest:: |
public | function | Tests ConfigEntityMapper::getOverviewRouteParameters(). | |
ConfigEntityMapperTest:: |
public | function | Tests ConfigEntityMapper::getType(). | |
ConfigEntityMapperTest:: |
public | function | Tests ConfigEntityMapper::getTypeLabel(). | |
ConfigEntityMapperTest:: |
public | function | Tests ConfigEntityMapper::getTypeName(). | |
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:: |
public static | function |