Вход Регистрация
Файл: symfony-2.7/src/Symfony/Component/Security/Http/Tests/Session/SessionAuthenticationStrategyTest.php
Строк: 180
<?php

/*
 * This file is part of the Symfony package.
 *
 * (c) Fabien Potencier <fabien@symfony.com>
 *
 * For the full copyright and license information, please view the LICENSE
 * file that was distributed with this source code.
 */

namespace SymfonyComponentSecurityHttpTestsSession;

use 
SymfonyComponentSecurityHttpSessionSessionAuthenticationStrategy;

class 
SessionAuthenticationStrategyTest extends PHPUnit_Framework_TestCase
{
    public function 
testSessionIsNotChanged()
    {
        
$request $this->getRequest();
        
$request->expects($this->never())->method('getSession');

        
$strategy = new SessionAuthenticationStrategy(SessionAuthenticationStrategy::NONE);
        
$strategy->onAuthentication($request$this->getToken());
    }

    
/**
     * @expectedException RuntimeException
     * @expectedExceptionMessage Invalid session authentication strategy "foo"
     */
    
public function testUnsupportedStrategy()
    {
        
$request $this->getRequest();
        
$request->expects($this->never())->method('getSession');

        
$strategy = new SessionAuthenticationStrategy('foo');
        
$strategy->onAuthentication($request$this->getToken());
    }

    public function 
testSessionIsMigrated()
    {
        if (
PHP_VERSION_ID >= 50400 && PHP_VERSION_ID 50411) {
            
$this->markTestSkipped('We cannot destroy the old session on PHP 5.4.0 - 5.4.10.');
        }

        
$session $this->getMock('SymfonyComponentHttpFoundationSessionSessionInterface');
        
$session->expects($this->once())->method('migrate')->with($this->equalTo(true));

        
$strategy = new SessionAuthenticationStrategy(SessionAuthenticationStrategy::MIGRATE);
        
$strategy->onAuthentication($this->getRequest($session), $this->getToken());
    }

    public function 
testSessionIsMigratedWithPhp54Workaround()
    {
        if (
PHP_VERSION_ID 50400 || PHP_VERSION_ID >= 50411) {
            
$this->markTestSkipped('This PHP version is not affected.');
        }

        
$session $this->getMock('SymfonyComponentHttpFoundationSessionSessionInterface');
        
$session->expects($this->once())->method('migrate')->with($this->equalTo(false));

        
$strategy = new SessionAuthenticationStrategy(SessionAuthenticationStrategy::MIGRATE);
        
$strategy->onAuthentication($this->getRequest($session), $this->getToken());
    }

    public function 
testSessionIsInvalidated()
    {
        
$session $this->getMock('SymfonyComponentHttpFoundationSessionSessionInterface');
        
$session->expects($this->once())->method('invalidate');

        
$strategy = new SessionAuthenticationStrategy(SessionAuthenticationStrategy::INVALIDATE);
        
$strategy->onAuthentication($this->getRequest($session), $this->getToken());
    }

    private function 
getRequest($session null)
    {
        
$request $this->getMock('SymfonyComponentHttpFoundationRequest');

        if (
null !== $session) {
            
$request->expects($this->any())->method('getSession')->will($this->returnValue($session));
        }

        return 
$request;
    }

    private function 
getToken()
    {
        return 
$this->getMock('SymfonyComponentSecurityCoreAuthenticationTokenTokenInterface');
    }
}
Онлайн: 2
Реклама