mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 12:05:37 +00:00
62 lines
1.9 KiB
PHP
62 lines
1.9 KiB
PHP
<?php
|
|
namespace SilverStripe\Security\Tests\MemberAuthenticator;
|
|
|
|
use SilverStripe\Control\Cookie;
|
|
use SilverStripe\Control\HTTPRequest;
|
|
use SilverStripe\Control\Session;
|
|
use SilverStripe\Dev\SapphireTest;
|
|
|
|
use SilverStripe\Security\Member;
|
|
use SilverStripe\Security\MemberAuthenticator\SessionAuthenticationHandler;
|
|
|
|
class SessionAuthenticationHandlerTest extends SapphireTest
|
|
{
|
|
protected $usesDatabase = true;
|
|
|
|
/**
|
|
* @runInSeparateProcess
|
|
* @preserveGlobalState disabled
|
|
*/
|
|
public function testAuthenticateRequestDefersSessionStartWithoutSessionIdentifier()
|
|
{
|
|
$member = new Member(['Email' => 'test@example.com']);
|
|
$member->write();
|
|
|
|
$handler = new SessionAuthenticationHandler();
|
|
|
|
$session = new Session(null); // unstarted, simulates lack of session cookie
|
|
$session->set($handler->getSessionVariable(), $member->ID);
|
|
|
|
$req = new HTTPRequest('GET', '/');
|
|
$req->setSession($session);
|
|
|
|
$matchedMember = $handler->authenticateRequest($req);
|
|
$this->assertNull($matchedMember);
|
|
}
|
|
|
|
/**
|
|
* @runInSeparateProcess
|
|
* @preserveGlobalState disabled
|
|
*/
|
|
public function testAuthenticateRequestStartsSessionWithSessionIdentifier()
|
|
{
|
|
$member = new Member(['Email' => 'test@example.com']);
|
|
$member->write();
|
|
|
|
$handler = new SessionAuthenticationHandler();
|
|
|
|
$session = new Session(null); // unstarted
|
|
$session->set($handler->getSessionVariable(), $member->ID);
|
|
|
|
$req = new HTTPRequest('GET', '/');
|
|
$req->setSession($session);
|
|
|
|
Cookie::set(session_name(), '1234');
|
|
$session->start($req); // simulate detection of session cookie
|
|
|
|
$matchedMember = $handler->authenticateRequest($req);
|
|
$this->assertNotNull($matchedMember);
|
|
$this->assertEquals($matchedMember->Email, $member->Email);
|
|
}
|
|
}
|