Commit 3998066e by Taylor Otwell

refactored session tests.

parent ba751b43
<?php namespace Laravel\Session; <?php namespace Laravel\Session;
use Closure;
use Laravel\Str; use Laravel\Str;
use Laravel\Config; use Laravel\Config;
use Laravel\Session\Drivers\Driver; use Laravel\Session\Drivers\Driver;
...@@ -12,21 +13,21 @@ class Manager { ...@@ -12,21 +13,21 @@ class Manager {
* *
* @var array * @var array
*/ */
protected static $session = array(); public static $session = array();
/** /**
* Indicates if the session exists in persistent storage. * Indicates if the session exists in persistent storage.
* *
* @var bool * @var bool
*/ */
protected static $exists = true; public static $exists = true;
/** /**
* Indicates if the session ID has been regenerated. * Indicates if the session ID has been regenerated.
* *
* @var bool * @var bool
*/ */
protected static $regenerated = false; public static $regenerated = false;
/** /**
* Start the session handling for the current request. * Start the session handling for the current request.
...@@ -167,7 +168,7 @@ class Manager { ...@@ -167,7 +168,7 @@ class Manager {
*/ */
public static function keep($key) public static function keep($key)
{ {
if (is_array($key)) return array_map(array($this, 'keep'), $key); if (is_array($key)) return array_map(array('Laravel\\Session\\Manager', 'keep'), $key);
static::flash($key, static::get($key)); static::flash($key, static::get($key));
...@@ -214,7 +215,7 @@ class Manager { ...@@ -214,7 +215,7 @@ class Manager {
* *
* @return array * @return array
*/ */
protected static function age() public static function age()
{ {
static::$session['last_activity'] = time(); static::$session['last_activity'] = time();
......
<?php <?php
use Laravel\IoC; use Laravel\IoC;
use Laravel\Config;
use Laravel\Session\Manager; use Laravel\Session\Manager;
class SessionManagerTest extends PHPUnit_Framework_TestCase { class SessionManagerTest extends PHPUnit_Framework_TestCase {
public function setUp()
{
Manager::$session = array();
}
/** /**
* @dataProvider mockProvider * @dataProvider mockProvider
*/ */
...@@ -12,9 +18,7 @@ class SessionManagerTest extends PHPUnit_Framework_TestCase { ...@@ -12,9 +18,7 @@ class SessionManagerTest extends PHPUnit_Framework_TestCase {
{ {
$transporter->expects($this->once())->method('get'); $transporter->expects($this->once())->method('get');
$manager = new Manager($driver, $transporter); Manager::start($driver, $transporter);
$manager->payload($this->getConfig());
} }
/** /**
...@@ -30,9 +34,7 @@ class SessionManagerTest extends PHPUnit_Framework_TestCase { ...@@ -30,9 +34,7 @@ class SessionManagerTest extends PHPUnit_Framework_TestCase {
->method('load') ->method('load')
->with($this->equalTo('something')); ->with($this->equalTo('something'));
$manager = new Manager($driver, $transporter); Manager::start($driver, $transporter);
$manager->payload($this->getConfig());
} }
/** /**
...@@ -42,11 +44,9 @@ class SessionManagerTest extends PHPUnit_Framework_TestCase { ...@@ -42,11 +44,9 @@ class SessionManagerTest extends PHPUnit_Framework_TestCase {
{ {
$this->setDriverExpectation($driver, 'load', $this->getDummySession()); $this->setDriverExpectation($driver, 'load', $this->getDummySession());
$manager = new Manager($driver, $transporter); Manager::start($driver, $transporter);
$payload = $manager->payload($this->getConfig());
$this->assertInstanceOf('Laravel\\Session\\Payload', $payload); $this->assertEquals(Manager::$session, $this->getDummySession());
$this->assertEquals($payload->session, $this->getDummySession());
} }
/** /**
...@@ -56,12 +56,10 @@ class SessionManagerTest extends PHPUnit_Framework_TestCase { ...@@ -56,12 +56,10 @@ class SessionManagerTest extends PHPUnit_Framework_TestCase {
{ {
$this->setDriverExpectation($driver, 'load', null); $this->setDriverExpectation($driver, 'load', null);
$manager = new Manager($driver, $transporter); Manager::start($driver, $transporter);
$payload = $manager->payload($this->getConfig());
$this->assertInstanceOf('Laravel\\Session\\Payload', $payload); $this->assertTrue(is_array(Manager::$session['data']));
$this->assertEquals(strlen($payload->session['id']), 40); $this->assertEquals(strlen(Manager::$session['id']), 40);
$this->assertTrue(is_array($payload->session['data']));
} }
/** /**
...@@ -70,13 +68,12 @@ class SessionManagerTest extends PHPUnit_Framework_TestCase { ...@@ -70,13 +68,12 @@ class SessionManagerTest extends PHPUnit_Framework_TestCase {
public function test_session_manager_creates_new_session_when_session_is_expired($driver, $transporter) public function test_session_manager_creates_new_session_when_session_is_expired($driver, $transporter)
{ {
$dateTime = new DateTime('1970-01-01'); $dateTime = new DateTime('1970-01-01');
$this->setDriverExpectation($driver, 'load', array('last_activity' => $dateTime->getTimestamp())); $this->setDriverExpectation($driver, 'load', array('last_activity' => $dateTime->getTimestamp()));
$manager = new Manager($driver, $transporter); Manager::start($driver, $transporter);
$payload = $manager->payload($this->getConfig());
$this->assertInstanceOf('Laravel\\Session\\Payload', $payload); $this->assertEquals(strlen(Manager::$session['id']), 40);
$this->assertEquals(strlen($payload->session['id']), 40);
} }
/** /**
...@@ -86,13 +83,13 @@ class SessionManagerTest extends PHPUnit_Framework_TestCase { ...@@ -86,13 +83,13 @@ class SessionManagerTest extends PHPUnit_Framework_TestCase {
{ {
$session = $this->getDummySession(); $session = $this->getDummySession();
unset($session['data']['csrf_token']); unset($session['data']['csrf_token']);
$this->setDriverExpectation($driver, 'load', $session); $this->setDriverExpectation($driver, 'load', $session);
$manager = new Manager($driver, $transporter); Manager::start($driver, $transporter);
$payload = $manager->payload($this->getConfig());
$this->assertTrue(isset($payload->session['data']['csrf_token'])); $this->assertTrue(isset(Manager::$session['data']['csrf_token']));
$this->assertEquals(strlen($payload->session['data']['csrf_token']), 16); $this->assertEquals(strlen(Manager::$session['data']['csrf_token']), 16);
} }
/** /**
...@@ -104,27 +101,15 @@ class SessionManagerTest extends PHPUnit_Framework_TestCase { ...@@ -104,27 +101,15 @@ class SessionManagerTest extends PHPUnit_Framework_TestCase {
->method('load') ->method('load')
->will($this->returnValue($this->getDummySession())); ->will($this->returnValue($this->getDummySession()));
$manager = new Manager($driver, $transporter); Manager::start($driver, $transporter);
$payload = $this->getMock(
'Laravel\\Session\\Payload',
array('age'),
array(array('id' => 'something'))
);
$payload->expects($this->any())
->method('age')
->will($this->returnValue('something'));
$driver->expects($this->once()) $driver->expects($this->once())
->method('save') ->method('save');
->with('something', $this->getConfig());
$transporter->expects($this->once()) $transporter->expects($this->once())
->method('put') ->method('put');
->with('something', $this->getConfig());
$manager->close($payload, $this->getConfig()); Manager::close($driver, $transporter);
} }
/** /**
...@@ -133,14 +118,14 @@ class SessionManagerTest extends PHPUnit_Framework_TestCase { ...@@ -133,14 +118,14 @@ class SessionManagerTest extends PHPUnit_Framework_TestCase {
public function test_close_method_calls_sweep_when_driver_is_sweeper($driver, $transporter) public function test_close_method_calls_sweep_when_driver_is_sweeper($driver, $transporter)
{ {
$driver = $this->getMock('SweeperStub', array('sweep')); $driver = $this->getMock('SweeperStub', array('sweep'));
$driver->expects($this->once())->method('sweep'); $driver->expects($this->once())->method('sweep');
$manager = new Manager($driver, $transporter); Manager::start($driver, $transporter);
$config = $this->getConfig(); Config::$items['session']['sweepage'] = array(100, 100);
$config['sweepage'] = array(100, 100);
$manager->close(new Laravel\Session\Payload($this->getDummySession()), $config); Manager::close($driver, $transporter);
} }
/** /**
...@@ -149,14 +134,158 @@ class SessionManagerTest extends PHPUnit_Framework_TestCase { ...@@ -149,14 +134,158 @@ class SessionManagerTest extends PHPUnit_Framework_TestCase {
public function test_close_method_doesnt_call_sweep_when_driver_isnt_sweeper($driver, $transporter) public function test_close_method_doesnt_call_sweep_when_driver_isnt_sweeper($driver, $transporter)
{ {
$driver = $this->getMock('Laravel\\Session\\Drivers\\Driver', array('sweep', 'load', 'save', 'delete')); $driver = $this->getMock('Laravel\\Session\\Drivers\\Driver', array('sweep', 'load', 'save', 'delete'));
$driver->expects($this->never())->method('sweep'); $driver->expects($this->never())->method('sweep');
$manager = new Manager($driver, $transporter); Manager::start($driver, $transporter);
Config::$items['session']['sweepage'] = array(100, 100);
Manager::close($driver, $transporter);
}
public function test_has_method_indicates_if_item_exists_in_payload()
{
Manager::$session = $this->getDummyData();
$this->assertTrue(Manager::has('name'));
$this->assertTrue(Manager::has('age'));
$this->assertTrue(Manager::has('gender'));
$this->assertFalse(Manager::has('something'));
$this->assertFalse(Manager::has('id'));
$this->assertFalse(Manager::has('last_activity'));
}
public function test_get_method_returns_item_from_payload()
{
Manager::$session = $this->getDummyData();
$this->assertEquals(Manager::get('name'), 'Taylor');
$this->assertEquals(Manager::get('age'), 25);
$this->assertEquals(Manager::get('gender'), 'male');
}
public function test_get_method_returns_default_when_item_doesnt_exist()
{
Manager::$session = $this->getDummyData();
$this->assertNull(Manager::get('something'));
$this->assertEquals('Taylor', Manager::get('something', 'Taylor'));
$this->assertEquals('Taylor', Manager::get('something', function() {return 'Taylor';}));
}
public function test_put_method_adds_to_payload()
{
Manager::$session = $this->getDummyData();
Manager::put('name', 'Weldon');
Manager::put('workmate', 'Joe');
$this->assertEquals(Manager::$session['data']['name'], 'Weldon');
$this->assertEquals(Manager::$session['data']['workmate'], 'Joe');
}
public function test_flash_method_puts_item_in_flash_data()
{
Manager::$session = array();
Manager::flash('name', 'Taylor');
$this->assertEquals(Manager::$session['data'][':new:name'], 'Taylor');
}
public function test_reflash_keeps_all_session_data()
{
Manager::$session = array('data' => array(':old:name' => 'Taylor', ':old:age' => 25));
Manager::reflash();
$this->assertTrue(isset(Manager::$session['data'][':new:name']));
$this->assertTrue(isset(Manager::$session['data'][':new:age']));
$this->assertFalse(isset(Manager::$session['data'][':old:name']));
$this->assertFalse(isset(Manager::$session['data'][':old:age']));
}
public function test_keep_method_keeps_specified_session_data()
{
Manager::$session = array('data' => array(':old:name' => 'Taylor', ':old:age' => 25));
Manager::keep('name');
$this->assertTrue(isset(Manager::$session['data'][':new:name']));
$this->assertFalse(isset(Manager::$session['data'][':old:name']));
Manager::$session = array('data' => array(':old:name' => 'Taylor', ':old:age' => 25));
Manager::keep(array('name', 'age'));
$this->assertTrue(isset(Manager::$session['data'][':new:name']));
$this->assertTrue(isset(Manager::$session['data'][':new:age']));
$this->assertFalse(isset(Manager::$session['data'][':old:name']));
$this->assertFalse(isset(Manager::$session['data'][':old:age']));
}
public function test_flush_method_clears_payload_data()
{
Manager::$session = array('data' => array('name' => 'Taylor'));
Manager::flush();
$this->assertEquals(count(Manager::$session['data']), 0);
}
public function test_regenerate_session_sets_new_session_id()
{
Manager::$session = array('id' => 'something');
Manager::regenerate();
$this->assertTrue(Manager::$regenerated);
$this->assertEquals(strlen(Manager::$session['id']), 40);
}
public function test_age_method_sets_last_activity_time()
{
$data = $this->getDummyData();
unset($data['last_activity']);
Manager::$session = $data;
Manager::age();
$this->assertTrue(isset(Manager::$session['last_activity']));
}
public function test_age_method_ages_all_flash_data()
{
Manager::$session = $this->getDummyData();
Manager::age();
$this->assertTrue(isset(Manager::$session['data'][':old:age']));
$this->assertFalse(isset(Manager::$session['data'][':old:gender']));
}
public function test_age_method_returns_session_array()
{
Manager::$session = $this->getDummyData();
$age = Manager::age();
$config = $this->getConfig(); $this->assertEquals($age['id'], 'something');
$config['sweepage'] = array(100, 100); }
// ---------------------------------------------------------------------
// Support Functions
// ---------------------------------------------------------------------
$manager->close(new Laravel\Session\Payload($this->getDummySession()), $config); public function getDummyData()
{
return array('id' => 'something', 'last_activity' => time(), 'data' => array(
'name' => 'Taylor',
':new:age' => 25,
':old:gender' => 'male',
'state' => 'Oregon',
));
} }
// --------------------------------------------------------------------- // ---------------------------------------------------------------------
...@@ -202,7 +331,7 @@ class SessionManagerTest extends PHPUnit_Framework_TestCase { ...@@ -202,7 +331,7 @@ class SessionManagerTest extends PHPUnit_Framework_TestCase {
private function getConfig() private function getConfig()
{ {
return Laravel\Config::get('session'); return Config::$items['session'];
} }
} }
......
<?php
use Laravel\Session\Payload;
class SessionPayloadTest extends PHPUnit_Framework_TestCase {
public function test_has_method_indicates_if_item_exists_in_payload()
{
$payload = new Payload($this->getDummyData());
$this->assertTrue($payload->has('name'));
$this->assertTrue($payload->has('age'));
$this->assertTrue($payload->has('gender'));
$this->assertFalse($payload->has('something'));
$this->assertFalse($payload->has('id'));
$this->assertFalse($payload->has('last_activity'));
}
public function test_get_method_returns_item_from_payload()
{
$payload = new Payload($this->getDummyData());
$this->assertEquals($payload->get('name'), 'Taylor');
$this->assertEquals($payload->get('age'), 25);
$this->assertEquals($payload->get('gender'), 'male');
}
public function test_get_method_returns_default_when_item_doesnt_exist()
{
$payload = new Payload($this->getDummyData());
$this->assertNull($payload->get('something'));
$this->assertEquals('Taylor', $payload->get('something', 'Taylor'));
$this->assertEquals('Taylor', $payload->get('something', function() {return 'Taylor';}));
}
public function test_put_method_adds_to_payload()
{
$payload = new Payload($this->getDummyData());
$payload->put('name', 'Weldon');
$payload->put('workmate', 'Joe');
$this->assertEquals($payload->session['data']['name'], 'Weldon');
$this->assertEquals($payload->session['data']['workmate'], 'Joe');
$this->assertInstanceOf('Laravel\\Session\\Payload', $payload->put('something', 'test'));
}
public function test_flash_method_puts_item_in_flash_data()
{
$payload = new Payload(array());
$payload->flash('name', 'Taylor');
$this->assertEquals($payload->session['data'][':new:name'], 'Taylor');
$this->assertInstanceOf('Laravel\\Session\\Payload', $payload->flash('something', 'test'));
}
public function test_reflash_keeps_all_session_data()
{
$payload = new Payload(array('data' => array(':old:name' => 'Taylor', ':old:age' => 25)));
$payload->reflash();
$this->assertTrue(isset($payload->session['data'][':new:name']));
$this->assertTrue(isset($payload->session['data'][':new:age']));
$this->assertFalse(isset($payload->session['data'][':old:name']));
$this->assertFalse(isset($payload->session['data'][':old:age']));
}
public function test_keep_method_keeps_specified_session_data()
{
$payload = new Payload(array('data' => array(':old:name' => 'Taylor', ':old:age' => 25)));
$payload->keep('name');
$this->assertTrue(isset($payload->session['data'][':new:name']));
$this->assertFalse(isset($payload->session['data'][':old:name']));
$payload = new Payload(array('data' => array(':old:name' => 'Taylor', ':old:age' => 25)));
$payload->keep(array('name', 'age'));
$this->assertTrue(isset($payload->session['data'][':new:name']));
$this->assertTrue(isset($payload->session['data'][':new:age']));
$this->assertFalse(isset($payload->session['data'][':old:name']));
$this->assertFalse(isset($payload->session['data'][':old:age']));
}
public function test_flush_method_clears_payload_data()
{
$payload = new Payload(array('data' => array('name' => 'Taylor')));
$payload->flush();
$this->assertEquals(count($payload->session['data']), 0);
}
public function test_regenerate_session_sets_new_session_id()
{
$payload = new Payload(array('id' => 'something'));
$payload->regenerate();
$this->assertTrue($payload->regenerated);
$this->assertEquals(strlen($payload->session['id']), 40);
}
public function test_age_method_sets_last_activity_time()
{
$data = $this->getDummyData();
unset($data['last_activity']);
$payload = new Payload($data);
$payload->age();
$this->assertTrue(isset($payload->session['last_activity']));
}
public function test_age_method_ages_all_flash_data()
{
$payload = new Payload($this->getDummyData());
$payload->age();
$this->assertTrue(isset($payload->session['data'][':old:age']));
$this->assertFalse(isset($payload->session['data'][':old:gender']));
}
public function test_age_method_returns_session_array()
{
$payload = new Payload($this->getDummyData());
$age = $payload->age();
$this->assertEquals($age['id'], 'something');
}
// ---------------------------------------------------------------------
// Support Functions
// ---------------------------------------------------------------------
public function getDummyData()
{
return array('id' => 'something', 'last_activity' => time(), 'data' => array(
'name' => 'Taylor',
':new:age' => 25,
':old:gender' => 'male',
'state' => 'Oregon',
));
}
}
\ No newline at end of file
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment