class NoSessionOpenTest
Same name and namespace in other branches
- 11.x core/tests/Drupal/Tests/Core/PageCache/NoSessionOpenTest.php \Drupal\Tests\Core\PageCache\NoSessionOpenTest
- 10 core/tests/Drupal/Tests/Core/PageCache/NoSessionOpenTest.php \Drupal\Tests\Core\PageCache\NoSessionOpenTest
- 8.9.x core/tests/Drupal/Tests/Core/PageCache/NoSessionOpenTest.php \Drupal\Tests\Core\PageCache\NoSessionOpenTest
@coversDefaultClass \Drupal\Core\PageCache\RequestPolicy\NoSessionOpen
@group PageCache
Hierarchy
- class \Drupal\Tests\UnitTestCase uses \Drupal\Tests\Traits\PhpUnitWarnings, \Drupal\Tests\PhpUnitCompatibilityTrait, \Symfony\Bridge\PhpUnit\ExpectDeprecationTrait extends \PHPUnit\Framework\TestCase
- class \Drupal\Tests\Core\PageCache\NoSessionOpenTest extends \Drupal\Tests\UnitTestCase
Expanded class hierarchy of NoSessionOpenTest
File
-
core/
tests/ Drupal/ Tests/ Core/ PageCache/ NoSessionOpenTest.php, line 14
Namespace
Drupal\Tests\Core\PageCacheView source
class NoSessionOpenTest extends UnitTestCase {
/**
* The session configuration.
*
* @var \Drupal\Core\Session\SessionConfigurationInterface|\PHPUnit\Framework\MockObject\MockObject
*/
protected $sessionConfiguration;
/**
* The request policy under test.
*
* @var \Drupal\Core\PageCache\RequestPolicy\NoSessionOpen
*/
protected $policy;
/**
* {@inheritdoc}
*/
protected function setUp() : void {
$this->sessionConfiguration = $this->createMock('Drupal\\Core\\Session\\SessionConfigurationInterface');
$this->policy = new NoSessionOpen($this->sessionConfiguration);
}
/**
* Asserts that caching is allowed unless there is a session cookie present.
*
* @covers ::check
*/
public function testNoAllowUnlessSessionCookiePresent() {
$request_without_session = new Request();
$request_with_session = Request::create('/', 'GET', [], [
'some-session-name' => 'some-session-id',
]);
$this->sessionConfiguration
->expects($this->exactly(2))
->method('hasSession')
->willReturnMap([
[
$request_without_session,
FALSE,
],
[
$request_with_session,
TRUE,
],
]);
$result = $this->policy
->check($request_without_session);
$this->assertSame(RequestPolicyInterface::ALLOW, $result);
$result = $this->policy
->check($request_with_session);
$this->assertSame(NULL, $result);
}
}
Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.