class ViewsTest in Drupal 8
Same name and namespace in other branches
- 9 core/modules/views/tests/src/Unit/ViewsTest.php \Drupal\Tests\views\Unit\ViewsTest
- 10 core/modules/views/tests/src/Unit/ViewsTest.php \Drupal\Tests\views\Unit\ViewsTest
@coversDefaultClass \Drupal\views\Views @group views
Hierarchy
- class \Drupal\Tests\UnitTestCase extends \PHPUnit\Framework\TestCase uses PhpunitCompatibilityTrait
- class \Drupal\Tests\views\Unit\ViewsTest
Expanded class hierarchy of ViewsTest
File
- core/
modules/ views/ tests/ src/ Unit/ ViewsTest.php, line 19
Namespace
Drupal\Tests\views\UnitView source
class ViewsTest extends UnitTestCase {
/**
* The test container.
*
* @var \Drupal\Core\DependencyInjection\ContainerBuilder
*/
protected $container;
/**
* {@inheritdoc}
*/
protected function setUp() {
parent::setUp();
$this->container = new ContainerBuilder();
$user = $this
->createMock('Drupal\\Core\\Session\\AccountInterface');
$request_stack = new RequestStack();
$request_stack
->push(new Request());
$views_data = $this
->getMockBuilder('Drupal\\views\\ViewsData')
->disableOriginalConstructor()
->getMock();
$route_provider = $this
->createMock('Drupal\\Core\\Routing\\RouteProviderInterface');
$this->container
->set('views.executable', new ViewExecutableFactory($user, $request_stack, $views_data, $route_provider));
\Drupal::setContainer($this->container);
}
/**
* Tests the getView() method.
*
* @covers ::getView
*/
public function testGetView() {
$view = new View([
'id' => 'test_view',
], 'view');
$view_storage = $this
->getMockBuilder('Drupal\\Core\\Config\\Entity\\ConfigEntityStorage')
->disableOriginalConstructor()
->getMock();
$view_storage
->expects($this
->once())
->method('load')
->with('test_view')
->will($this
->returnValue($view));
$entity_type_manager = $this
->createMock('Drupal\\Core\\Entity\\EntityTypeManagerInterface');
$entity_type_manager
->expects($this
->once())
->method('getStorage')
->with('view')
->will($this
->returnValue($view_storage));
$this->container
->set('entity_type.manager', $entity_type_manager);
$executable = Views::getView('test_view');
$this
->assertInstanceOf('Drupal\\views\\ViewExecutable', $executable);
$this
->assertEquals($view
->id(), $executable->storage
->id());
$this
->assertEquals(spl_object_hash($view), spl_object_hash($executable->storage));
}
/**
* Tests the getView() method against a non-existent view.
*
* @covers ::getView
*/
public function testGetNonExistentView() {
$entity_type_manager = $this
->prophesize(EntityTypeManagerInterface::class);
$storage = $this
->prophesize(EntityStorageInterface::class);
$storage
->load('test_view_non_existent')
->willReturn(NULL);
$entity_type_manager
->getStorage('view')
->willReturn($storage
->reveal());
$this->container
->set('entity_type.manager', $entity_type_manager
->reveal());
$executable_does_not_exist = Views::getView('test_view_non_existent');
$this
->assertNull($executable_does_not_exist);
}
/**
* @covers ::getApplicableViews
*
* @dataProvider providerTestGetApplicableViews
*/
public function testGetApplicableViews($applicable_type, $expected) {
$view_1 = new View([
'id' => 'test_view_1',
'display' => [
'default' => [
'display_plugin' => 'default',
'display_options' => [],
],
'type_a' => [
'display_plugin' => 'type_a',
'display_options' => [],
],
],
], 'view');
$view_2 = new View([
'id' => 'test_view_2',
'display' => [
'default' => [
'display_plugin' => 'default',
'display_options' => [],
],
'type_b' => [
'display_plugin' => 'type_b',
'display_options' => [
'enabled' => TRUE,
],
],
'type_b_2' => [
'display_plugin' => 'type_b',
'display_options' => [
'enabled' => FALSE,
],
],
],
], 'view');
$view_3 = new View([
'id' => 'test_view_3',
'display' => [
'default' => [
'display_plugin' => 'default',
'display_options' => [],
],
// Test with Type A but a disabled display.
'type_a' => [
'display_plugin' => 'type_a',
'display_options' => [
'enabled' => FALSE,
],
],
// Type D intentionally doesn't exist.
'type_d' => [
'display_plugin' => 'type_d',
'display_options' => [],
],
],
], 'view');
$query = $this
->createMock('Drupal\\Core\\Entity\\Query\\QueryInterface');
$query
->expects($this
->exactly(2))
->method('condition')
->willReturnSelf();
$query
->expects($this
->once())
->method('execute')
->willReturn([
'test_view_1',
'test_view_2',
'test_view_3',
]);
$view_storage = $this
->getMockBuilder('Drupal\\Core\\Config\\Entity\\ConfigEntityStorage')
->disableOriginalConstructor()
->getMock();
$view_storage
->expects($this
->once())
->method('getQuery')
->willReturn($query);
$view_storage
->expects($this
->once())
->method('loadMultiple')
->with([
'test_view_1',
'test_view_2',
'test_view_3',
])
->will($this
->returnValue([
'test_view_1' => $view_1,
'test_view_2' => $view_2,
'test_view_3' => $view_3,
]));
$entity_type_manager = $this
->createMock(EntityTypeManagerInterface::class);
$entity_type_manager
->expects($this
->exactly(2))
->method('getStorage')
->with('view')
->will($this
->returnValue($view_storage));
$this->container
->set('entity_type.manager', $entity_type_manager);
$definitions = [
'type_a' => [
'type_a' => TRUE,
'type_b' => FALSE,
],
'type_b' => [
'type_a' => FALSE,
'type_b' => TRUE,
],
];
$display_manager = $this
->createMock('Drupal\\Component\\Plugin\\PluginManagerInterface');
$display_manager
->expects($this
->once())
->method('getDefinitions')
->willReturn($definitions);
$this->container
->set('plugin.manager.views.display', $display_manager);
$result = Views::getApplicableViews($applicable_type);
$this
->assertEquals($expected, $result);
}
/**
* Data provider for testGetApplicableViews.
*
* @return array
*/
public function providerTestGetApplicableViews() {
return [
[
'type_a',
[
[
'test_view_1',
'type_a',
],
],
],
[
'type_b',
[
[
'test_view_2',
'type_b',
],
],
],
[
'type_c',
[],
],
];
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
PhpunitCompatibilityTrait:: |
public | function | Returns a mock object for the specified class using the available method. | |
PhpunitCompatibilityTrait:: |
public | function | Compatibility layer for PHPUnit 6 to support PHPUnit 4 code. | |
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 | Mocks a block with a block plugin. | 1 |
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. | |
ViewsTest:: |
protected | property | The test container. | |
ViewsTest:: |
public | function | Data provider for testGetApplicableViews. | |
ViewsTest:: |
protected | function |
Overrides UnitTestCase:: |
|
ViewsTest:: |
public | function | @covers ::getApplicableViews | |
ViewsTest:: |
public | function | Tests the getView() method against a non-existent view. | |
ViewsTest:: |
public | function | Tests the getView() method. |