public function CacheCollectorTest::testUpdateCacheInvalidatedConflict in Zircon Profile 8
Same name and namespace in other branches
- 8.0 core/tests/Drupal/Tests/Core/Cache/CacheCollectorTest.php \Drupal\Tests\Core\Cache\CacheCollectorTest::testUpdateCacheInvalidatedConflict()
Tests updating the cache when there is a conflict after cache invalidation.
File
- core/
tests/ Drupal/ Tests/ Core/ Cache/ CacheCollectorTest.php, line 226 - Contains \Drupal\Tests\Core\Cache\CacheCollectorTest.
Class
- CacheCollectorTest
- @coversDefaultClass \Drupal\Core\Cache\CacheCollector @group Cache
Namespace
Drupal\Tests\Core\CacheCode
public function testUpdateCacheInvalidatedConflict() {
$key = $this
->randomMachineName();
$value = $this
->randomMachineName();
$cache = (object) array(
'data' => array(
$key => $value,
),
'created' => (int) $_SERVER['REQUEST_TIME'],
);
$this->cacheBackend
->expects($this
->at(0))
->method('get')
->with($this->cid)
->will($this
->returnValue($cache));
$this->cacheBackend
->expects($this
->at(1))
->method('invalidate')
->with($this->cid);
$this->collector
->set($key, 'new value');
// Set up mock objects for the expected calls, first a lock acquire, then
// cache get to look for conflicting cache entries, which does find
// and then it deletes the cache and aborts.
$this->lock
->expects($this
->once())
->method('acquire')
->with($this->cid . ':Drupal\\Core\\Cache\\CacheCollector')
->will($this
->returnValue(TRUE));
$cache = (object) array(
'data' => array(
$key => $value,
),
'created' => (int) $_SERVER['REQUEST_TIME'] + 1,
);
$this->cacheBackend
->expects($this
->at(0))
->method('get')
->with($this->cid)
->will($this
->returnValue($cache));
$this->cacheBackend
->expects($this
->once())
->method('delete')
->with($this->cid);
$this->lock
->expects($this
->once())
->method('release')
->with($this->cid . ':Drupal\\Core\\Cache\\CacheCollector');
// Destruct the object to trigger the update data process.
$this->collector
->destruct();
}