merged branch drak/nativestorage (PR #4899)
Commits -------a351362
[HttpFoundation] Add NativeSessionHandler tests653821a
[HttpFoundation] Remove FileSessionHandler3456787
Partially revert "[HttpFoundation][Sessions] Refactored tests"39813a0
Revert "[FrameworkBundle] Refactor session file handler service name and update changelogs"fbee4cf
Restore NativeFileSessionHandler Discussion ---------- [Session] Restore NativeFileSessionStorage Bug fix: no Feature addition: yes Backwards compatibility break: no Symfony2 tests pass: yes Fixes the following tickets: #4668 Todo: - License of the code: MIT This reverts the removal of the native file handler.
This commit is contained in:
commit
a798ff100c
@ -26,7 +26,7 @@ CHANGELOG
|
|||||||
* [BC BREAK] following session options: 'lifetime', 'path', 'domain', 'secure',
|
* [BC BREAK] following session options: 'lifetime', 'path', 'domain', 'secure',
|
||||||
'httponly' are now prefixed with cookie_ when dumped to the container
|
'httponly' are now prefixed with cookie_ when dumped to the container
|
||||||
* Added `handler_id` configuration under `session` key to represent `session.handler`
|
* Added `handler_id` configuration under `session` key to represent `session.handler`
|
||||||
service, defaults to `session.handler.file`.
|
service, defaults to `session.handler.native_file`.
|
||||||
* Added `gc_maxlifetime`, `gc_probability`, and `gc_divisor` to session
|
* Added `gc_maxlifetime`, `gc_probability`, and `gc_divisor` to session
|
||||||
configuration. This means session garbage collection has a
|
configuration. This means session garbage collection has a
|
||||||
`gc_probability`/`gc_divisor` chance of being run. The `gc_maxlifetime` defines
|
`gc_probability`/`gc_divisor` chance of being run. The `gc_maxlifetime` defines
|
||||||
|
@ -10,7 +10,7 @@
|
|||||||
<parameter key="session.attribute_bag.class">Symfony\Component\HttpFoundation\Session\Attribute\AttributeBag</parameter>
|
<parameter key="session.attribute_bag.class">Symfony\Component\HttpFoundation\Session\Attribute\AttributeBag</parameter>
|
||||||
<parameter key="session.storage.native.class">Symfony\Component\HttpFoundation\Session\Storage\NativeSessionStorage</parameter>
|
<parameter key="session.storage.native.class">Symfony\Component\HttpFoundation\Session\Storage\NativeSessionStorage</parameter>
|
||||||
<parameter key="session.storage.mock_file.class">Symfony\Component\HttpFoundation\Session\Storage\MockFileSessionStorage</parameter>
|
<parameter key="session.storage.mock_file.class">Symfony\Component\HttpFoundation\Session\Storage\MockFileSessionStorage</parameter>
|
||||||
<parameter key="session.handler.file.class">Symfony\Component\HttpFoundation\Session\Storage\Handler\FileSessionHandler</parameter>
|
<parameter key="session.handler.native_file.class">Symfony\Component\HttpFoundation\Session\Storage\Handler\NativeFileSessionHandler</parameter>
|
||||||
<parameter key="session_listener.class">Symfony\Bundle\FrameworkBundle\EventListener\SessionListener</parameter>
|
<parameter key="session_listener.class">Symfony\Bundle\FrameworkBundle\EventListener\SessionListener</parameter>
|
||||||
</parameters>
|
</parameters>
|
||||||
|
|
||||||
@ -34,7 +34,7 @@
|
|||||||
<argument>%kernel.cache_dir%/sessions</argument>
|
<argument>%kernel.cache_dir%/sessions</argument>
|
||||||
</service>
|
</service>
|
||||||
|
|
||||||
<service id="session.handler.file" class="%session.handler.file.class%" public="false">
|
<service id="session.handler.native_file" class="%session.handler.native_file.class%" public="false">
|
||||||
<argument>%session.save_path%</argument>
|
<argument>%session.save_path%</argument>
|
||||||
</service>
|
</service>
|
||||||
|
|
||||||
@ -45,6 +45,5 @@
|
|||||||
|
|
||||||
<!-- for BC -->
|
<!-- for BC -->
|
||||||
<service id="session.storage.filesystem" alias="session.storage.mock_file" />
|
<service id="session.storage.filesystem" alias="session.storage.mock_file" />
|
||||||
<service id="session.handler.native_file" alias="session.handler.file" />
|
|
||||||
</services>
|
</services>
|
||||||
</container>
|
</container>
|
||||||
|
@ -22,7 +22,8 @@ CHANGELOG
|
|||||||
* [BC BREAK] Moved all session related classes and interfaces into own namespace, as
|
* [BC BREAK] Moved all session related classes and interfaces into own namespace, as
|
||||||
`Symfony\Component\HttpFoundation\Session` and renamed classes accordingly.
|
`Symfony\Component\HttpFoundation\Session` and renamed classes accordingly.
|
||||||
Session handlers are located in the subnamespace `Symfony\Component\HttpFoundation\Session\Handler`.
|
Session handlers are located in the subnamespace `Symfony\Component\HttpFoundation\Session\Handler`.
|
||||||
* SessionHandlers must implement `\SessionHandlerInterface`.
|
* SessionHandlers must implement `\SessionHandlerInterface` or extend from the
|
||||||
|
`Symfony\Component\HttpFoundation\Storage\Handler\NativeSessionHandler` base class.
|
||||||
* Added internal storage driver proxy mechanism for forward compatibility with
|
* Added internal storage driver proxy mechanism for forward compatibility with
|
||||||
PHP 5.4 `\SessionHandler` class.
|
PHP 5.4 `\SessionHandler` class.
|
||||||
* Added session handlers for custom Memcache, Memcached and Null session save handlers.
|
* Added session handlers for custom Memcache, Memcached and Null session save handlers.
|
||||||
|
@ -1,116 +0,0 @@
|
|||||||
<?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 Symfony\Component\HttpFoundation\Session\Storage\Handler;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* FileSessionHandler.
|
|
||||||
*
|
|
||||||
* @author Drak <drak@zikula.org>
|
|
||||||
*/
|
|
||||||
class FileSessionHandler implements \SessionHandlerInterface
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* @var string
|
|
||||||
*/
|
|
||||||
private $savePath;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @var string
|
|
||||||
*/
|
|
||||||
private $prefix;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Constructor.
|
|
||||||
*
|
|
||||||
* @param string $savePath Path of directory to save session files.
|
|
||||||
* @param string $prefix
|
|
||||||
*/
|
|
||||||
public function __construct($savePath = null, $prefix = 'sess_')
|
|
||||||
{
|
|
||||||
if (null === $savePath) {
|
|
||||||
$savePath = sys_get_temp_dir();
|
|
||||||
}
|
|
||||||
|
|
||||||
$this->savePath = $savePath;
|
|
||||||
if (false === is_dir($this->savePath)) {
|
|
||||||
mkdir($this->savePath, 0777, true);
|
|
||||||
}
|
|
||||||
|
|
||||||
$this->prefix = $prefix;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* {@inheritdoc}
|
|
||||||
*/
|
|
||||||
public function open($savePath, $sessionName)
|
|
||||||
{
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* {@inheritdoc}
|
|
||||||
*/
|
|
||||||
public function close()
|
|
||||||
{
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* {@inheritdoc}
|
|
||||||
*/
|
|
||||||
public function read($id)
|
|
||||||
{
|
|
||||||
$file = $this->getPath().$id;
|
|
||||||
|
|
||||||
return is_readable($file) ? file_get_contents($file) : '';
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* {@inheritdoc}
|
|
||||||
*/
|
|
||||||
public function write($id, $data)
|
|
||||||
{
|
|
||||||
return false === file_put_contents($this->getPath().$id, $data) ? false : true;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* {@inheritdoc}
|
|
||||||
*/
|
|
||||||
public function destroy($id)
|
|
||||||
{
|
|
||||||
$file = $this->getPath().$id;
|
|
||||||
if (is_file($file)) {
|
|
||||||
unlink($file);
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* {@inheritdoc}
|
|
||||||
*/
|
|
||||||
public function gc($maxlifetime)
|
|
||||||
{
|
|
||||||
foreach (glob($this->getPath().'*') as $file) {
|
|
||||||
if ((filemtime($file) + $maxlifetime) < time()) {
|
|
||||||
unlink($file);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
private function getPath()
|
|
||||||
{
|
|
||||||
return $this->savePath.'/'.$this->prefix;
|
|
||||||
}
|
|
||||||
}
|
|
@ -0,0 +1,41 @@
|
|||||||
|
<?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 Symfony\Component\HttpFoundation\Session\Storage\Handler;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* NativeFileSessionHandler.
|
||||||
|
*
|
||||||
|
* Native session handler using PHP's built in file storage.
|
||||||
|
*
|
||||||
|
* @author Drak <drak@zikula.org>
|
||||||
|
*/
|
||||||
|
class NativeFileSessionHandler extends NativeSessionHandler
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Constructor.
|
||||||
|
*
|
||||||
|
* @param string $savePath Path of directory to save session files. Default null will leave setting as defined by PHP.
|
||||||
|
*/
|
||||||
|
public function __construct($savePath = null)
|
||||||
|
{
|
||||||
|
if (null === $savePath) {
|
||||||
|
$savePath = ini_get('session.save_path');
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($savePath && !is_dir($savePath)) {
|
||||||
|
mkdir($savePath, 0777, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
ini_set('session.save_handler', 'files');
|
||||||
|
ini_set('session.save_path', $savePath);
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,24 @@
|
|||||||
|
<?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 Symfony\Component\HttpFoundation\Session\Storage\Handler;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Adds SessionHandler functionality if available.
|
||||||
|
*
|
||||||
|
* @see http://php.net/sessionhandler
|
||||||
|
*/
|
||||||
|
|
||||||
|
if (version_compare(phpversion(), '5.4.0', '>=')) {
|
||||||
|
class NativeSessionHandler extends \SessionHandler {}
|
||||||
|
} else {
|
||||||
|
class NativeSessionHandler {}
|
||||||
|
}
|
@ -11,9 +11,6 @@
|
|||||||
|
|
||||||
namespace Symfony\Component\HttpFoundation\Session\Storage;
|
namespace Symfony\Component\HttpFoundation\Session\Storage;
|
||||||
|
|
||||||
use Symfony\Component\HttpFoundation\Session\Storage\Handler\FileSessionHandler;
|
|
||||||
use Symfony\Component\HttpFoundation\Session\Storage\MetadataBag;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* MockFileSessionStorage is used to mock sessions for
|
* MockFileSessionStorage is used to mock sessions for
|
||||||
* functional testing when done in a single PHP process.
|
* functional testing when done in a single PHP process.
|
||||||
@ -28,27 +25,35 @@ use Symfony\Component\HttpFoundation\Session\Storage\MetadataBag;
|
|||||||
class MockFileSessionStorage extends MockArraySessionStorage
|
class MockFileSessionStorage extends MockArraySessionStorage
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* @var FileSessionHandler
|
* @var string
|
||||||
*/
|
*/
|
||||||
private $handler;
|
private $savePath;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @var array
|
||||||
|
*/
|
||||||
|
private $sessionData;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Constructor.
|
* Constructor.
|
||||||
*
|
*
|
||||||
* @param string $savePath Path of directory to save session files.
|
* @param string $savePath Path of directory to save session files.
|
||||||
* @param string $name Session name.
|
* @param string $name Session name.
|
||||||
* @param FileSessionHandler $handler Save handler
|
* @param MetadataBag $metaBag MetadataBag instance.
|
||||||
* @param MetadataBag $metaData Metadatabag
|
|
||||||
*/
|
*/
|
||||||
public function __construct($savePath = null, $name = 'MOCKSESSID', FileSessionHandler $handler = null, MetadataBag $metaData = null)
|
public function __construct($savePath = null, $name = 'MOCKSESSID', MetadataBag $metaBag = null)
|
||||||
{
|
{
|
||||||
if (null == $handler) {
|
if (null === $savePath) {
|
||||||
$handler = new FileSessionHandler($savePath, 'mocksess_');
|
$savePath = sys_get_temp_dir();
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->handler = $handler;
|
if (!is_dir($savePath)) {
|
||||||
|
mkdir($savePath, 0777, true);
|
||||||
|
}
|
||||||
|
|
||||||
parent::__construct($name, $metaData);
|
$this->savePath = $savePath;
|
||||||
|
|
||||||
|
parent::__construct($name, $metaBag);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -92,7 +97,7 @@ class MockFileSessionStorage extends MockArraySessionStorage
|
|||||||
*/
|
*/
|
||||||
public function save()
|
public function save()
|
||||||
{
|
{
|
||||||
$this->handler->write($this->id, serialize($this->data));
|
file_put_contents($this->getFilePath(), serialize($this->data));
|
||||||
|
|
||||||
// this is needed for Silex, where the session object is re-used across requests
|
// this is needed for Silex, where the session object is re-used across requests
|
||||||
// in functional tests. In Symfony, the container is rebooted, so we don't have
|
// in functional tests. In Symfony, the container is rebooted, so we don't have
|
||||||
@ -106,7 +111,19 @@ class MockFileSessionStorage extends MockArraySessionStorage
|
|||||||
*/
|
*/
|
||||||
private function destroy()
|
private function destroy()
|
||||||
{
|
{
|
||||||
$this->handler->destroy($this->id);
|
if (is_file($this->getFilePath())) {
|
||||||
|
unlink($this->getFilePath());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Calculate path to file.
|
||||||
|
*
|
||||||
|
* @return string File path
|
||||||
|
*/
|
||||||
|
private function getFilePath()
|
||||||
|
{
|
||||||
|
return $this->savePath.'/'.$this->id.'.mocksess';
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -114,8 +131,8 @@ class MockFileSessionStorage extends MockArraySessionStorage
|
|||||||
*/
|
*/
|
||||||
private function read()
|
private function read()
|
||||||
{
|
{
|
||||||
$data = $this->handler->read($this->id);
|
$filePath = $this->getFilePath();
|
||||||
$this->data = $data ? unserialize($data) : array();
|
$this->data = is_readable($filePath) && is_file($filePath) ? unserialize(file_get_contents($filePath)) : array();
|
||||||
|
|
||||||
$this->loadSession();
|
$this->loadSession();
|
||||||
}
|
}
|
||||||
|
@ -1,106 +0,0 @@
|
|||||||
<?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 Symfony\Component\HttpFoundation\Tests\Session\Storage\Handler;
|
|
||||||
|
|
||||||
use Symfony\Component\HttpFoundation\Session\Storage\Handler\FileSessionHandler;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Test class for FileSessionHandler.
|
|
||||||
*
|
|
||||||
* @author Drak <drak@zikula.org>
|
|
||||||
*/
|
|
||||||
class FileSessionStorageTest extends \PHPUnit_Framework_TestCase
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* @var FileSessionHandler
|
|
||||||
*/
|
|
||||||
private $handler;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @var string
|
|
||||||
*/
|
|
||||||
private $path;
|
|
||||||
|
|
||||||
public function setUp()
|
|
||||||
{
|
|
||||||
$this->path = sys_get_temp_dir().'/filesessionhandler';
|
|
||||||
$this->handler = new FileSessionHandler($this->path, 'mocksess_');
|
|
||||||
|
|
||||||
parent::setUp();
|
|
||||||
}
|
|
||||||
|
|
||||||
public function tearDown()
|
|
||||||
{
|
|
||||||
foreach (glob($this->path.'/*') as $file) {
|
|
||||||
unlink($file);
|
|
||||||
}
|
|
||||||
|
|
||||||
rmdir($this->path);
|
|
||||||
|
|
||||||
$this->handler = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function test__construct()
|
|
||||||
{
|
|
||||||
$this->assertTrue(is_dir($this->path));
|
|
||||||
}
|
|
||||||
|
|
||||||
public function testOpen()
|
|
||||||
{
|
|
||||||
$this->assertTrue($this->handler->open('a', 'b'));
|
|
||||||
}
|
|
||||||
|
|
||||||
public function testClose()
|
|
||||||
{
|
|
||||||
$this->assertTrue($this->handler->close());
|
|
||||||
}
|
|
||||||
|
|
||||||
public function testReadWrite()
|
|
||||||
{
|
|
||||||
$this->assertEmpty($this->handler->read('123'));
|
|
||||||
$this->assertTrue($this->handler->write('123', 'data'));
|
|
||||||
$this->assertEquals('data', $this->handler->read('123'));
|
|
||||||
}
|
|
||||||
|
|
||||||
public function testDestroy()
|
|
||||||
{
|
|
||||||
$this->handler->write('456', 'data');
|
|
||||||
$this->handler->destroy('123');
|
|
||||||
$this->assertEquals('data', $this->handler->read('456'));
|
|
||||||
$this->handler->destroy('456');
|
|
||||||
$this->assertEmpty($this->handler->read('456'));
|
|
||||||
}
|
|
||||||
|
|
||||||
public function testGc()
|
|
||||||
{
|
|
||||||
$prefix = $this->path.'/mocksess_';
|
|
||||||
$this->handler->write('1', 'data');
|
|
||||||
touch($prefix.'1', time()-86400);
|
|
||||||
|
|
||||||
$this->handler->write('2', 'data');
|
|
||||||
touch($prefix.'2', time()-3600);
|
|
||||||
|
|
||||||
$this->handler->write('3', 'data');
|
|
||||||
touch($prefix.'3', time()-300);
|
|
||||||
|
|
||||||
$this->handler->write('4', 'data');
|
|
||||||
|
|
||||||
$this->handler->gc(90000);
|
|
||||||
$this->assertEquals(4, count(glob($this->path.'/*')));
|
|
||||||
|
|
||||||
$this->handler->gc(4000);
|
|
||||||
$this->assertEquals(3, count(glob($this->path.'/*')));
|
|
||||||
|
|
||||||
$this->handler->gc(200);
|
|
||||||
$this->assertEquals(1, count(glob($this->path.'/*')));
|
|
||||||
}
|
|
||||||
}
|
|
@ -0,0 +1,49 @@
|
|||||||
|
<?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 Symfony\Component\HttpFoundation\Tests\Session\Storage\Handler;
|
||||||
|
|
||||||
|
use Symfony\Component\HttpFoundation\Session\Storage\Handler\NativeFileSessionHandler;
|
||||||
|
use Symfony\Component\HttpFoundation\Session\Storage\NativeSessionStorage;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test class for NativeFileSessionHandler.
|
||||||
|
*
|
||||||
|
* @author Drak <drak@zikula.org>
|
||||||
|
*
|
||||||
|
* @runTestsInSeparateProcesses
|
||||||
|
*/
|
||||||
|
class NativeFileSessionHandlerTest extends \PHPUnit_Framework_TestCase
|
||||||
|
{
|
||||||
|
public function testConstruct()
|
||||||
|
{
|
||||||
|
$storage = new NativeSessionStorage(array('name' => 'TESTING'), new NativeFileSessionHandler(sys_get_temp_dir()));
|
||||||
|
|
||||||
|
if (version_compare(phpversion(), '5.4.0', '<')) {
|
||||||
|
$this->assertEquals('files', $storage->getSaveHandler()->getSaveHandlerName());
|
||||||
|
$this->assertEquals('files', ini_get('session.save_handler'));
|
||||||
|
} else {
|
||||||
|
$this->assertEquals('files', $storage->getSaveHandler()->getSaveHandlerName());
|
||||||
|
$this->assertEquals('user', ini_get('session.save_handler'));
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->assertEquals(sys_get_temp_dir(), ini_get('session.save_path'));
|
||||||
|
$this->assertEquals('TESTING', ini_get('session.name'));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testConstructDefault()
|
||||||
|
{
|
||||||
|
$path = ini_get('session.save_path');
|
||||||
|
$storage = new NativeSessionStorage(array('name' => 'TESTING'), new NativeFileSessionHandler());
|
||||||
|
|
||||||
|
$this->assertEquals($path, ini_get('session.save_path'));
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,39 @@
|
|||||||
|
<?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 Symfony\Component\HttpFoundation\Tests\Session\Storage\Handler;
|
||||||
|
|
||||||
|
use Symfony\Component\HttpFoundation\Session\Storage\Handler\NativeSessionHandler;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test class for NativeSessionHandler.
|
||||||
|
*
|
||||||
|
* @author Drak <drak@zikula.org>
|
||||||
|
*
|
||||||
|
* @runTestsInSeparateProcesses
|
||||||
|
*/
|
||||||
|
class NativeSessionHandlerTest extends \PHPUnit_Framework_TestCase
|
||||||
|
{
|
||||||
|
public function testConstruct()
|
||||||
|
{
|
||||||
|
$handler = new NativeSessionHandler();
|
||||||
|
|
||||||
|
// note for PHPUnit optimisers - the use of assertTrue/False
|
||||||
|
// here is deliberate since the tests do not require the classes to exist - drak
|
||||||
|
if (version_compare(phpversion(), '5.4.0', '<')) {
|
||||||
|
$this->assertFalse($handler instanceof \SessionHandler);
|
||||||
|
$this->assertTrue($handler instanceof NativeSessionHandler);
|
||||||
|
} else {
|
||||||
|
$this->assertTrue($handler instanceof \SessionHandler);
|
||||||
|
$this->assertTrue($handler instanceof NativeSessionHandler);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -28,7 +28,7 @@ class MockFileSessionStorageTest extends \PHPUnit_Framework_TestCase
|
|||||||
private $sessionDir;
|
private $sessionDir;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @var MockFileSessionStorage
|
* @var FileMockSessionStorage
|
||||||
*/
|
*/
|
||||||
protected $storage;
|
protected $storage;
|
||||||
|
|
||||||
@ -40,14 +40,12 @@ class MockFileSessionStorageTest extends \PHPUnit_Framework_TestCase
|
|||||||
|
|
||||||
protected function tearDown()
|
protected function tearDown()
|
||||||
{
|
{
|
||||||
foreach (glob($this->sessionDir.'/mocksess_*') as $file) {
|
|
||||||
unlink($file);
|
|
||||||
}
|
|
||||||
|
|
||||||
rmdir($this->sessionDir);
|
|
||||||
|
|
||||||
$this->sessionDir = null;
|
$this->sessionDir = null;
|
||||||
$this->storage = null;
|
$this->storage = null;
|
||||||
|
array_map('unlink', glob($this->sessionDir.'/*.session'));
|
||||||
|
if (is_dir($this->sessionDir)) {
|
||||||
|
rmdir($this->sessionDir);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testStart()
|
public function testStart()
|
||||||
|
@ -12,6 +12,7 @@
|
|||||||
namespace Symfony\Component\HttpFoundation\Tests\Session\Storage;
|
namespace Symfony\Component\HttpFoundation\Tests\Session\Storage;
|
||||||
|
|
||||||
use Symfony\Component\HttpFoundation\Session\Storage\NativeSessionStorage;
|
use Symfony\Component\HttpFoundation\Session\Storage\NativeSessionStorage;
|
||||||
|
use Symfony\Component\HttpFoundation\Session\Storage\Handler\NativeFileSessionHandler;
|
||||||
use Symfony\Component\HttpFoundation\Session\Storage\Handler\NullSessionHandler;
|
use Symfony\Component\HttpFoundation\Session\Storage\Handler\NullSessionHandler;
|
||||||
use Symfony\Component\HttpFoundation\Session\Flash\FlashBag;
|
use Symfony\Component\HttpFoundation\Session\Flash\FlashBag;
|
||||||
use Symfony\Component\HttpFoundation\Session\Attribute\AttributeBag;
|
use Symfony\Component\HttpFoundation\Session\Attribute\AttributeBag;
|
||||||
@ -136,8 +137,8 @@ class NativeSessionStorageTest extends \PHPUnit_Framework_TestCase
|
|||||||
$this->markTestSkipped('Test skipped, for PHP 5.3 only.');
|
$this->markTestSkipped('Test skipped, for PHP 5.3 only.');
|
||||||
}
|
}
|
||||||
|
|
||||||
ini_set('session.save_handler', 'files');
|
|
||||||
$storage = $this->getStorage();
|
$storage = $this->getStorage();
|
||||||
|
$storage->setSaveHandler(new NativeFileSessionHandler());
|
||||||
$this->assertInstanceOf('Symfony\Component\HttpFoundation\Session\Storage\Proxy\NativeProxy', $storage->getSaveHandler());
|
$this->assertInstanceOf('Symfony\Component\HttpFoundation\Session\Storage\Proxy\NativeProxy', $storage->getSaveHandler());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user