function EntityUnitTest::testPostSaveBundle

Same name in other branches
  1. 9 core/tests/Drupal/Tests/Core/Entity/EntityUnitTest.php \Drupal\Tests\Core\Entity\EntityUnitTest::testPostSaveBundle()
  2. 10 core/tests/Drupal/Tests/Core/Entity/EntityUnitTest.php \Drupal\Tests\Core\Entity\EntityUnitTest::testPostSaveBundle()
  3. 11.x core/tests/Drupal/Tests/Core/Entity/EntityUnitTest.php \Drupal\Tests\Core\Entity\EntityUnitTest::testPostSaveBundle()

@covers ::postSave

File

core/tests/Drupal/Tests/Core/Entity/EntityUnitTest.php, line 449

Class

EntityUnitTest
@coversDefaultClass \Drupal\Core\Entity\Entity @group Entity @group Access

Namespace

Drupal\Tests\Core\Entity

Code

public function testPostSaveBundle() {
    $this->cacheTagsInvalidator
        ->expects($this->at(0))
        ->method('invalidateTags')
        ->with([
        // List cache tag.
$this->entityTypeId . '_list',
        $this->entityTypeId . '_list:' . $this->entity
            ->bundle(),
    ]);
    $this->cacheTagsInvalidator
        ->expects($this->at(1))
        ->method('invalidateTags')
        ->with([
        // Own cache tag.
$this->entityTypeId . ':' . $this->values['id'],
        // List cache tag.
$this->entityTypeId . '_list',
        $this->entityTypeId . '_list:' . $this->entity
            ->bundle(),
    ]);
    $this->entityType
        ->expects($this->atLeastOnce())
        ->method('hasKey')
        ->with('bundle')
        ->willReturn(TRUE);
    // This method is internal, so check for errors on calling it only.
    $storage = $this->createMock('\\Drupal\\Core\\Entity\\EntityStorageInterface');
    // A creation should trigger the invalidation of the global list cache tag
    // and the one for the bundle.
    $this->entity
        ->postSave($storage, FALSE);
    // An update should trigger the invalidation of the "list", bundle list and
    // the "own" cache tags.
    $this->entity
        ->postSave($storage, TRUE);
}

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.