You are here

class EntityTest in Drupal 8

Same name in this branch
  1. 8 core/modules/views/tests/src/Unit/Plugin/area/EntityTest.php \Drupal\Tests\views\Unit\Plugin\area\EntityTest
  2. 8 core/modules/views/tests/src/Unit/Plugin/argument_validator/EntityTest.php \Drupal\Tests\views\Unit\Plugin\argument_validator\EntityTest
  3. 8 core/modules/system/tests/modules/entity_test/src/Entity/EntityTest.php \Drupal\entity_test\Entity\EntityTest
Same name and namespace in other branches
  1. 9 core/modules/views/tests/src/Unit/Plugin/argument_validator/EntityTest.php \Drupal\Tests\views\Unit\Plugin\argument_validator\EntityTest

@coversDefaultClass \Drupal\views\Plugin\views\argument_validator\Entity @group views

Hierarchy

Expanded class hierarchy of EntityTest

File

core/modules/views/tests/src/Unit/Plugin/argument_validator/EntityTest.php, line 14

Namespace

Drupal\Tests\views\Unit\Plugin\argument_validator
View source
class EntityTest extends UnitTestCase {

  /**
   * The view executable.
   *
   * @var \Drupal\views\ViewExecutable
   */
  protected $executable;

  /**
   * The view display.
   *
   * @var \Drupal\views\Plugin\views\display\DisplayPluginBase
   */
  protected $display;

  /**
   * The entity manager.
   *
   * @var \PHPUnit\Framework\MockObject\MockObject|\Drupal\Core\Entity\EntityTypeManagerInterface
   */
  protected $entityTypeManager;

  /**
   * The mocked entity type bundle info used in this test.
   *
   * @var \Drupal\Core\Entity\EntityTypeBundleInfoInterface|\PHPUnit\Framework\MockObject\MockObject
   */
  protected $entityTypeBundleInfo;

  /**
   * The tested argument validator.
   *
   * @var \Drupal\views\Plugin\views\argument_validator\Entity
   */
  protected $argumentValidator;

  /**
   * {@inheritdoc}
   */
  protected function setUp() {
    parent::setUp();
    $this->entityTypeManager = $this
      ->createMock(EntityTypeManagerInterface::class);
    $this->entityTypeBundleInfo = $this
      ->createMock(EntityTypeBundleInfoInterface::class);
    $mock_entity = $this
      ->getMockForAbstractClass('Drupal\\Core\\Entity\\EntityBase', [], '', FALSE, TRUE, TRUE, [
      'bundle',
      'access',
    ]);
    $mock_entity
      ->expects($this
      ->any())
      ->method('bundle')
      ->will($this
      ->returnValue('test_bundle'));
    $mock_entity
      ->expects($this
      ->any())
      ->method('access')
      ->will($this
      ->returnValueMap([
      [
        'test_op',
        NULL,
        FALSE,
        TRUE,
      ],
      [
        'test_op_2',
        NULL,
        FALSE,
        FALSE,
      ],
      [
        'test_op_3',
        NULL,
        FALSE,
        TRUE,
      ],
    ]));
    $mock_entity_bundle_2 = $this
      ->getMockForAbstractClass('Drupal\\Core\\Entity\\EntityBase', [], '', FALSE, TRUE, TRUE, [
      'bundle',
      'access',
    ]);
    $mock_entity_bundle_2
      ->expects($this
      ->any())
      ->method('bundle')
      ->will($this
      ->returnValue('test_bundle_2'));
    $mock_entity_bundle_2
      ->expects($this
      ->any())
      ->method('access')
      ->will($this
      ->returnValueMap([
      [
        'test_op',
        NULL,
        FALSE,
        FALSE,
      ],
      [
        'test_op_2',
        NULL,
        FALSE,
        FALSE,
      ],
      [
        'test_op_3',
        NULL,
        FALSE,
        TRUE,
      ],
    ]));
    $storage = $this
      ->createMock('Drupal\\Core\\Entity\\EntityStorageInterface');

    // Setup values for IDs passed as strings or numbers.
    $value_map = [
      [
        [],
        [],
      ],
      [
        [
          1,
        ],
        [
          1 => $mock_entity,
        ],
      ],
      [
        [
          '1',
        ],
        [
          1 => $mock_entity,
        ],
      ],
      [
        [
          1,
          2,
        ],
        [
          1 => $mock_entity,
          2 => $mock_entity_bundle_2,
        ],
      ],
      [
        [
          '1',
          '2',
        ],
        [
          1 => $mock_entity,
          2 => $mock_entity_bundle_2,
        ],
      ],
      [
        [
          2,
        ],
        [
          2 => $mock_entity_bundle_2,
        ],
      ],
      [
        [
          '2',
        ],
        [
          2 => $mock_entity_bundle_2,
        ],
      ],
    ];
    $storage
      ->expects($this
      ->any())
      ->method('loadMultiple')
      ->will($this
      ->returnValueMap($value_map));
    $this->entityTypeManager
      ->expects($this
      ->any())
      ->method('getStorage')
      ->with('entity_test')
      ->will($this
      ->returnValue($storage));
    $this->executable = $this
      ->getMockBuilder('Drupal\\views\\ViewExecutable')
      ->disableOriginalConstructor()
      ->getMock();
    $this->display = $this
      ->getMockBuilder('Drupal\\views\\Plugin\\views\\display\\DisplayPluginBase')
      ->disableOriginalConstructor()
      ->getMock();
    $definition = [
      'entity_type' => 'entity_test',
    ];
    $this->argumentValidator = new Entity([], 'entity_test', $definition, $this->entityTypeManager, $this->entityTypeBundleInfo);
  }

  /**
   * Tests the validate argument method with no access and bundles.
   *
   * @see \Drupal\views\Plugin\views\argument_validator\Entity::validateArgument()
   */
  public function testValidateArgumentNoAccess() {
    $options = [];
    $options['access'] = FALSE;
    $options['bundles'] = [];
    $this->argumentValidator
      ->init($this->executable, $this->display, $options);
    $this
      ->assertFalse($this->argumentValidator
      ->validateArgument(3));
    $this
      ->assertFalse($this->argumentValidator
      ->validateArgument(''));
    $this
      ->assertTrue($this->argumentValidator
      ->validateArgument(1));
    $this
      ->assertTrue($this->argumentValidator
      ->validateArgument(2));
    $this
      ->assertFalse($this->argumentValidator
      ->validateArgument('1,2'));
  }

  /**
   * Tests the validate argument method with access and no bundles.
   *
   * @see \Drupal\views\Plugin\views\argument_validator\Entity::validateArgument()
   */
  public function testValidateArgumentAccess() {
    $options = [];
    $options['access'] = TRUE;
    $options['bundles'] = [];
    $options['operation'] = 'test_op';
    $this->argumentValidator
      ->init($this->executable, $this->display, $options);
    $this
      ->assertFalse($this->argumentValidator
      ->validateArgument(3));
    $this
      ->assertFalse($this->argumentValidator
      ->validateArgument(''));
    $this
      ->assertTrue($this->argumentValidator
      ->validateArgument(1));
    $options = [];
    $options['access'] = TRUE;
    $options['bundles'] = [];
    $options['operation'] = 'test_op_2';
    $this->argumentValidator
      ->init($this->executable, $this->display, $options);
    $this
      ->assertFalse($this->argumentValidator
      ->validateArgument(3));
    $this
      ->assertFalse($this->argumentValidator
      ->validateArgument(''));
    $this
      ->assertFalse($this->argumentValidator
      ->validateArgument(1));
    $this
      ->assertFalse($this->argumentValidator
      ->validateArgument(2));
  }

  /**
   * Tests the validate argument method with bundle checking.
   */
  public function testValidateArgumentBundle() {
    $options = [];
    $options['access'] = FALSE;
    $options['bundles'] = [
      'test_bundle' => 1,
    ];
    $this->argumentValidator
      ->init($this->executable, $this->display, $options);
    $this
      ->assertTrue($this->argumentValidator
      ->validateArgument(1));
    $this
      ->assertFalse($this->argumentValidator
      ->validateArgument(2));
    $options['bundles'] = NULL;
    $this->argumentValidator
      ->init($this->executable, $this->display, $options);
    $this
      ->assertTrue($this->argumentValidator
      ->validateArgument(1));
    $this
      ->assertTrue($this->argumentValidator
      ->validateArgument(2));
  }

  /**
   * @covers ::calculateDependencies
   */
  public function testCalculateDependencies() {

    // Create an entity manager, storage, entity type, and entity to mock the
    // loading of entities providing bundles.
    $entity_type_manager = $this
      ->createMock(EntityTypeManagerInterface::class);
    $storage = $this
      ->createMock('Drupal\\Core\\Entity\\EntityStorageInterface');
    $entity_type = $this
      ->createMock('Drupal\\Core\\Entity\\EntityTypeInterface');
    $mock_entity = $this
      ->createMock('Drupal\\Core\\Entity\\EntityInterface');
    $mock_entity
      ->expects($this
      ->any())
      ->method('getConfigDependencyKey')
      ->willReturn('config');
    $mock_entity
      ->expects($this
      ->any())
      ->method('getConfigDependencyName')
      ->willReturn('test_bundle');
    $storage
      ->expects($this
      ->any())
      ->method('loadMultiple')
      ->with([
      'test_bundle',
    ])
      ->willReturn([
      'test_bundle' => $mock_entity,
    ]);
    $entity_type
      ->expects($this
      ->any())
      ->method('getBundleEntityType')
      ->willReturn('entity_test_bundle');
    $entity_type_manager
      ->expects($this
      ->any())
      ->method('getDefinition')
      ->with('entity_test')
      ->willReturn($entity_type);
    $entity_type_manager
      ->expects($this
      ->any())
      ->method('hasHandler')
      ->with('entity_test_bundle', 'storage')
      ->willReturn(TRUE);
    $entity_type_manager
      ->expects($this
      ->any())
      ->method('getStorage')
      ->with('entity_test_bundle')
      ->willReturn($storage);

    // Set up the argument validator.
    $argumentValidator = new Entity([], 'entity_test', [
      'entity_type' => 'entity_test',
    ], $entity_type_manager, $this->entityTypeBundleInfo);
    $options = [];
    $options['access'] = FALSE;
    $options['bundles'] = [
      'test_bundle' => 1,
    ];
    $argumentValidator
      ->init($this->executable, $this->display, $options);
    $this
      ->assertEquals([
      'config' => [
        'test_bundle',
      ],
    ], $argumentValidator
      ->calculateDependencies());
  }

  /**
   * Tests the validate argument method with multiple argument splitting.
   */
  public function testValidateArgumentMultiple() {
    $options = [];
    $options['access'] = TRUE;
    $options['bundles'] = [];
    $options['operation'] = 'test_op';
    $options['multiple'] = TRUE;
    $this->argumentValidator
      ->init($this->executable, $this->display, $options);
    $this
      ->assertTrue($this->argumentValidator
      ->validateArgument('1'));
    $this
      ->assertFalse($this->argumentValidator
      ->validateArgument('2'));
    $this
      ->assertFalse($this->argumentValidator
      ->validateArgument('1,2'));
    $this
      ->assertFalse($this->argumentValidator
      ->validateArgument('1+2'));
    $options = [];
    $options['access'] = TRUE;
    $options['bundles'] = [];
    $options['operation'] = 'test_op_3';
    $options['multiple'] = TRUE;
    $this->argumentValidator
      ->init($this->executable, $this->display, $options);
    $this
      ->assertTrue($this->argumentValidator
      ->validateArgument('1,2'));
    $this
      ->assertTrue($this->argumentValidator
      ->validateArgument('1+2'));
  }

}

Members

Namesort descending Modifiers Type Description Overrides
EntityTest::$argumentValidator protected property The tested argument validator.
EntityTest::$display protected property The view display.
EntityTest::$entityTypeBundleInfo protected property The mocked entity type bundle info used in this test.
EntityTest::$entityTypeManager protected property The entity manager.
EntityTest::$executable protected property The view executable.
EntityTest::setUp protected function Overrides UnitTestCase::setUp
EntityTest::testCalculateDependencies public function @covers ::calculateDependencies
EntityTest::testValidateArgumentAccess public function Tests the validate argument method with access and no bundles.
EntityTest::testValidateArgumentBundle public function Tests the validate argument method with bundle checking.
EntityTest::testValidateArgumentMultiple public function Tests the validate argument method with multiple argument splitting.
EntityTest::testValidateArgumentNoAccess public function Tests the validate argument method with no access and bundles.
PhpunitCompatibilityTrait::getMock Deprecated public function Returns a mock object for the specified class using the available method.
PhpunitCompatibilityTrait::setExpectedException Deprecated public function Compatibility layer for PHPUnit 6 to support PHPUnit 4 code.
UnitTestCase::$randomGenerator protected property The random generator.
UnitTestCase::$root protected property The app root. 1
UnitTestCase::assertArrayEquals protected function Asserts if two arrays are equal by sorting them first.
UnitTestCase::getBlockMockWithMachineName Deprecated protected function Mocks a block with a block plugin. 1
UnitTestCase::getClassResolverStub protected function Returns a stub class resolver.
UnitTestCase::getConfigFactoryStub public function Returns a stub config factory that behaves according to the passed array.
UnitTestCase::getConfigStorageStub public function Returns a stub config storage that returns the supplied configuration.
UnitTestCase::getContainerWithCacheTagsInvalidator protected function Sets up a container with a cache tags invalidator.
UnitTestCase::getRandomGenerator protected function Gets the random generator for the utility methods.
UnitTestCase::getStringTranslationStub public function Returns a stub translation manager that just returns the passed string.
UnitTestCase::randomMachineName public function Generates a unique random string containing letters and numbers.