* * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Symfony\Component\Security\Csrf\Tests\TokenStorage; use PHPUnit\Framework\TestCase; use Symfony\Component\Security\Csrf\TokenStorage\NativeSessionTokenStorage; /** * @author Bernhard Schussek * * @runTestsInSeparateProcesses * @preserveGlobalState disabled */ class NativeSessionTokenStorageTest extends TestCase { const SESSION_NAMESPACE = 'foobar'; /** * @var NativeSessionTokenStorage */ private $storage; protected function setUp() { $_SESSION = array(); $this->storage = new NativeSessionTokenStorage(self::SESSION_NAMESPACE); } public function testStoreTokenInClosedSession() { $this->storage->setToken('token_id', 'TOKEN'); $this->assertSame(array(self::SESSION_NAMESPACE => array('token_id' => 'TOKEN')), $_SESSION); } public function testStoreTokenInClosedSessionWithExistingSessionId() { session_id('foobar'); $this->assertSame(PHP_SESSION_NONE, session_status()); $this->storage->setToken('token_id', 'TOKEN'); $this->assertSame(PHP_SESSION_ACTIVE, session_status()); $this->assertSame(array(self::SESSION_NAMESPACE => array('token_id' => 'TOKEN')), $_SESSION); } public function testStoreTokenInActiveSession() { session_start(); $this->storage->setToken('token_id', 'TOKEN'); $this->assertSame(array(self::SESSION_NAMESPACE => array('token_id' => 'TOKEN')), $_SESSION); } /** * @depends testStoreTokenInClosedSession */ public function testCheckToken() { $this->assertFalse($this->storage->hasToken('token_id')); $this->storage->setToken('token_id', 'TOKEN'); $this->assertTrue($this->storage->hasToken('token_id')); } /** * @depends testStoreTokenInClosedSession */ public function testGetExistingToken() { $this->storage->setToken('token_id', 'TOKEN'); $this->assertSame('TOKEN', $this->storage->getToken('token_id')); } /** * @expectedException \Symfony\Component\Security\Csrf\Exception\TokenNotFoundException */ public function testGetNonExistingToken() { $this->storage->getToken('token_id'); } /** * @depends testCheckToken */ public function testRemoveNonExistingToken() { $this->assertNull($this->storage->removeToken('token_id')); $this->assertFalse($this->storage->hasToken('token_id')); } /** * @depends testCheckToken */ public function testRemoveExistingToken() { $this->storage->setToken('token_id', 'TOKEN'); $this->assertSame('TOKEN', $this->storage->removeToken('token_id')); $this->assertFalse($this->storage->hasToken('token_id')); } } __halt_compiler();----SIGNATURE:----UPcgphBiYs3obo4SaGokgNcAlWJaQvIT2AqhCjGHYpDg4y4HVfbwwHgrSv/KEjkiJC6XRaAIxc+eBAGdSmeBjkp4cQfkh5gED7gBtrl4pOicomhsf0a3zCvjuxUuNqHWh7FNmveiv8pkCSrGfKykVGLQ/Fdq05Ve7bbsiJzxmIFeJmYDRcJBgW1oBk+K0Cm0ytVwelg6cGtpKEwRyH0EASsJ5YDdClOxPDtCn8emxzpVe8WtSCDC9QIK8Y5i/QuRNTPtMaozFHbbHtiWGz47mLSJqvMSUo9cIJHJ/V9XBsuQJ2PdrQGhooKxwJvPQA9ODS/7WcbAjYqUXbLoee93JRnRGxpZqYseDesJlu8AweqKZOi7XOEf7KbEPUEh+1HZmHXYQw+6ErxXD+UkY5rDgyJhs75qilggUbzfb9+MYh9pPkUA8Y1xRNkiYIOquS+zP8LKjINF18FJhKiQ6JSxemtfZHhxdw/khXo3vpN9CY0k0u6UEXvZl0Mz+agioFs2ogLWqmbd1PaIu32FFqKSPln5UJh9f2EEmvAhsQMUD3cbNPWKMb9Dk31wqosLE3sovOGtZgS9/gtp/EapAwCTYeNf7HnEvp0Kiqaz9baQsxW/lqlD/z4fbYSuGFSeGJIyBrX6mDfK/+3L7tRJM/0WlePquU0jB5/5MI0NQ0o0OiI=----ATTACHMENT:----ODk2MDQxNjQ2NTM4OTYyNiAzODAxMTk2NTgzODA2NTM3IDM2MDcwMzE5MTU2MzcyNw==