|
@@ -1,5 +1,7 @@
|
|
|
<?php
|
|
|
|
|
|
+use Symfony\Component\HttpFoundation\LaravelRequest as RequestFoundation;
|
|
|
+
|
|
|
use Laravel\Str;
|
|
|
use Laravel\Auth;
|
|
|
use Laravel\Cookie;
|
|
@@ -35,6 +37,33 @@ class AuthTest extends PHPUnit_Framework_TestCase {
|
|
|
Config::set('database.default', 'mysql');
|
|
|
}
|
|
|
|
|
|
+ /**
|
|
|
+ * Set one of the $_SERVER variables.
|
|
|
+ *
|
|
|
+ * @param string $key
|
|
|
+ * @param string $value
|
|
|
+ */
|
|
|
+ protected function setServerVar($key, $value)
|
|
|
+ {
|
|
|
+ $_SERVER[$key] = $value;
|
|
|
+
|
|
|
+ $this->restartRequest();
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Reinitialize the global request.
|
|
|
+ *
|
|
|
+ * @return void
|
|
|
+ */
|
|
|
+ protected function restartRequest()
|
|
|
+ {
|
|
|
+ // FIXME: Ugly hack, but old contents from previous requests seem to
|
|
|
+ // trip up the Foundation class.
|
|
|
+ $_FILES = array();
|
|
|
+
|
|
|
+ Request::$foundation = RequestFoundation::createFromGlobals();
|
|
|
+ }
|
|
|
+
|
|
|
/**
|
|
|
* Test the Auth::user method.
|
|
|
*
|
|
@@ -54,7 +83,9 @@ class AuthTest extends PHPUnit_Framework_TestCase {
|
|
|
*/
|
|
|
public function testCheckMethodReturnsTrueWhenUserIsSet()
|
|
|
{
|
|
|
- $this->assertTrue(AuthUserReturnsDummy::check());
|
|
|
+ $auth = new AuthUserReturnsDummy;
|
|
|
+
|
|
|
+ $this->assertTrue($auth->check());
|
|
|
}
|
|
|
|
|
|
/**
|
|
@@ -64,7 +95,9 @@ class AuthTest extends PHPUnit_Framework_TestCase {
|
|
|
*/
|
|
|
public function testCheckMethodReturnsFalseWhenNoUserIsSet()
|
|
|
{
|
|
|
- $this->assertFalse(AuthUserReturnsNull::check());
|
|
|
+ $auth = new AuthUserReturnsNull;
|
|
|
+
|
|
|
+ $this->assertFalse($auth->check());
|
|
|
}
|
|
|
|
|
|
/**
|
|
@@ -74,7 +107,9 @@ class AuthTest extends PHPUnit_Framework_TestCase {
|
|
|
*/
|
|
|
public function testGuestReturnsTrueWhenNoUserIsSet()
|
|
|
{
|
|
|
- $this->assertTrue(AuthUserReturnsNull::guest());
|
|
|
+ $auth = new AuthUserReturnsNull;
|
|
|
+
|
|
|
+ $this->assertTrue($auth->guest());
|
|
|
}
|
|
|
|
|
|
/**
|
|
@@ -84,7 +119,9 @@ class AuthTest extends PHPUnit_Framework_TestCase {
|
|
|
*/
|
|
|
public function testGuestReturnsFalseWhenUserIsSet()
|
|
|
{
|
|
|
- $this->assertFalse(AuthUserReturnsDummy::guest());
|
|
|
+ $auth = new AuthUserReturnsDummy;
|
|
|
+
|
|
|
+ $this->assertFalse($auth->guest());
|
|
|
}
|
|
|
|
|
|
/**
|
|
@@ -107,10 +144,12 @@ class AuthTest extends PHPUnit_Framework_TestCase {
|
|
|
public function testUserReturnsUserByID()
|
|
|
{
|
|
|
Session::$instance = new Payload($this->getMock('Laravel\\Session\\Drivers\\Driver'));
|
|
|
- // FIXME: Not sure whether hard-coding the key is a good idea.
|
|
|
- Session::$instance->session['data']['laravel_auth_drivers_fluent_login'] = 1;
|
|
|
+
|
|
|
+ Auth::login(1);
|
|
|
|
|
|
$this->assertEquals('Taylor Otwell', Auth::user()->name);
|
|
|
+
|
|
|
+ Auth::logout();
|
|
|
}
|
|
|
|
|
|
/**
|
|
@@ -121,8 +160,8 @@ class AuthTest extends PHPUnit_Framework_TestCase {
|
|
|
public function testNullReturnedWhenUserIDNotValidInteger()
|
|
|
{
|
|
|
Session::$instance = new Payload($this->getMock('Laravel\\Session\\Drivers\\Driver'));
|
|
|
- // FIXME: Not sure whether hard-coding the key is a good idea.
|
|
|
- Session::$instance->session['data']['laravel_auth_drivers_fluent_login'] = 'asdlkasd';
|
|
|
+
|
|
|
+ Auth::login('asdlkasd');
|
|
|
|
|
|
$this->assertNull(Auth::user());
|
|
|
}
|
|
@@ -137,10 +176,13 @@ class AuthTest extends PHPUnit_Framework_TestCase {
|
|
|
Session::$instance = new Payload($this->getMock('Laravel\\Session\\Drivers\\Driver'));
|
|
|
|
|
|
$cookie = Crypter::encrypt('1|'.Str::random(40));
|
|
|
- Cookie::forever(Config::get('auth.cookie'), $cookie);
|
|
|
+ Cookie::forever('authloginstub_remember', $cookie);
|
|
|
+
|
|
|
+ $auth = new AuthLoginStub;
|
|
|
|
|
|
- $this->assertEquals('Taylor Otwell', AuthLoginStub::user()->name);
|
|
|
- $this->assertTrue(AuthLoginStub::user() === $_SERVER['auth.login.stub']['user']);
|
|
|
+ $this->assertEquals('Taylor Otwell', $auth->user()->name);
|
|
|
+
|
|
|
+ $this->assertTrue($auth->user()->id === $_SERVER['auth.login.stub']['user']);
|
|
|
}
|
|
|
|
|
|
/**
|
|
@@ -150,11 +192,11 @@ class AuthTest extends PHPUnit_Framework_TestCase {
|
|
|
*/
|
|
|
public function testAttemptMethodReturnsFalseWhenCredentialsAreInvalid()
|
|
|
{
|
|
|
- $this->assertFalse(Auth::attempt('foo', 'foo'));
|
|
|
- $this->assertFalse(Auth::attempt('foo', null));
|
|
|
- $this->assertFalse(Auth::attempt(null, null));
|
|
|
- $this->assertFalse(Auth::attempt('taylor', 'password'));
|
|
|
- $this->assertFalse(Auth::attempt('taylor', 232));
|
|
|
+ $this->assertFalse(Auth::attempt(array('username' => 'foo', 'password' => 'foo')));
|
|
|
+ $this->assertFalse(Auth::attempt(array('username' => 'foo', 'password' => null)));
|
|
|
+ $this->assertFalse(Auth::attempt(array('username' => null, 'password' => null)));
|
|
|
+ $this->assertFalse(Auth::attempt(array('username' => 'taylor', 'password' => 'password')));
|
|
|
+ $this->assertFalse(Auth::attempt(array('username' => 'taylor', 'password' => 232)));
|
|
|
}
|
|
|
|
|
|
/**
|
|
@@ -164,13 +206,22 @@ class AuthTest extends PHPUnit_Framework_TestCase {
|
|
|
*/
|
|
|
public function testAttemptReturnsTrueWhenCredentialsAreCorrect()
|
|
|
{
|
|
|
- $this->assertTrue(AuthLoginStub::attempt('taylor', 'password1'));
|
|
|
- $this->assertEquals('Taylor Otwell', $_SERVER['auth.login.stub']['user']->name);
|
|
|
+ Session::$instance = new Payload($this->getMock('Laravel\\Session\\Drivers\\Driver'));
|
|
|
+
|
|
|
+ $auth = new AuthLoginStub;
|
|
|
+
|
|
|
+ $this->assertTrue($auth->attempt(array('username' => 'taylor', 'password' => 'password1')));
|
|
|
+ $this->assertEquals('1', $_SERVER['auth.login.stub']['user']);
|
|
|
$this->assertFalse($_SERVER['auth.login.stub']['remember']);
|
|
|
|
|
|
- $this->assertTrue(AuthLoginStub::attempt('taylor', 'password1', true));
|
|
|
- $this->assertEquals('Taylor Otwell', $_SERVER['auth.login.stub']['user']->name);
|
|
|
+ $auth_secure = new AuthLoginStub;
|
|
|
+
|
|
|
+ $this->assertTrue($auth_secure->attempt(array('username' => 'taylor', 'password' => 'password1', 'remember' => true)));
|
|
|
+ $this->assertEquals('1', $_SERVER['auth.login.stub']['user']);
|
|
|
$this->assertTrue($_SERVER['auth.login.stub']['remember']);
|
|
|
+
|
|
|
+ $auth_secure->logout();
|
|
|
+ $auth->logout();
|
|
|
}
|
|
|
|
|
|
/**
|
|
@@ -189,9 +240,13 @@ class AuthTest extends PHPUnit_Framework_TestCase {
|
|
|
$user = Session::$instance->session['data']['laravel_auth_drivers_fluent_login'];
|
|
|
$this->assertEquals(10, $user->id);
|
|
|
|
|
|
+
|
|
|
+ Auth::logout();
|
|
|
+
|
|
|
Auth::login(5);
|
|
|
$user = Session::$instance->session['data']['laravel_auth_drivers_fluent_login'];
|
|
|
$this->assertEquals(5, $user);
|
|
|
+ Auth::logout(5);
|
|
|
}
|
|
|
|
|
|
/**
|
|
@@ -203,20 +258,27 @@ class AuthTest extends PHPUnit_Framework_TestCase {
|
|
|
{
|
|
|
Session::$instance = new Payload($this->getMock('Laravel\\Session\\Drivers\\Driver'));
|
|
|
|
|
|
+ $this->setServerVar('HTTPS', 'on');
|
|
|
+
|
|
|
// Set the session vars to make sure remember cookie uses them
|
|
|
Config::set('session.path', 'foo');
|
|
|
Config::set('session.domain', 'bar');
|
|
|
Config::set('session.secure', true);
|
|
|
|
|
|
- Auth::login(10);
|
|
|
- $this->assertTrue(isset(Cookie::$jar[Config::get('auth.cookie')]));
|
|
|
+ Auth::login(1, true);
|
|
|
+
|
|
|
+ $this->assertTrue(isset(Cookie::$jar['laravel_auth_drivers_fluent_remember']));
|
|
|
|
|
|
- $cookie = Cookie::$jar[Config::get('auth.cookie')]['value'];
|
|
|
+ $cookie = Cookie::$jar['laravel_auth_drivers_fluent_remember']['value'];
|
|
|
$cookie = explode('|', Crypter::decrypt($cookie));
|
|
|
- $this->assertEquals(10, $cookie[0]);
|
|
|
- $this->assertEquals('foo', Cookie::$jar[Config::get('auth.cookie')]['path']);
|
|
|
- $this->assertEquals('bar', Cookie::$jar[Config::get('auth.cookie')]['domain']);
|
|
|
- $this->assertTrue(Cookie::$jar[Config::get('auth.cookie')]['secure']);
|
|
|
+ $this->assertEquals(1, $cookie[0]);
|
|
|
+ $this->assertEquals('foo', Cookie::$jar['laravel_auth_drivers_fluent_remember']['path']);
|
|
|
+ $this->assertEquals('bar', Cookie::$jar['laravel_auth_drivers_fluent_remember']['domain']);
|
|
|
+ $this->assertTrue(Cookie::$jar['laravel_auth_drivers_fluent_remember']['secure']);
|
|
|
+
|
|
|
+ Auth::logout();
|
|
|
+
|
|
|
+ $this->setServerVar('HTTPS', 'off');
|
|
|
}
|
|
|
|
|
|
/**
|
|
@@ -228,40 +290,70 @@ class AuthTest extends PHPUnit_Framework_TestCase {
|
|
|
{
|
|
|
Session::$instance = new Payload($this->getMock('Laravel\\Session\\Drivers\\Driver'));
|
|
|
|
|
|
- //$data = Session::$instance->session['data']['laravel_auth_drivers_fluent_login'] = 10;
|
|
|
-
|
|
|
- // FIXME: Restore some of these!
|
|
|
- //Config::set('auth.logout', function($user) { $_SERVER['auth.logout.stub'] = $user; });
|
|
|
+ $data = Session::$instance->session['data']['laravel_auth_drivers_fluent_login'] = 1;
|
|
|
|
|
|
- //Auth::$user = 'Taylor';
|
|
|
Auth::logout();
|
|
|
|
|
|
- //$this->assertEquals('Taylor', $_SERVER['auth.logout.stub']);
|
|
|
+ // A workaround since Cookie will is only stored in memory, until Response class is called.
|
|
|
+ Auth::driver()->token = null;
|
|
|
+
|
|
|
$this->assertNull(Auth::user());
|
|
|
- // FIXME: Not sure whether hard-coding the key is a good idea.
|
|
|
+
|
|
|
$this->assertFalse(isset(Session::$instance->session['data']['laravel_auth_drivers_fluent_login']));
|
|
|
$this->assertTrue(Cookie::$jar['laravel_auth_drivers_fluent_remember']['expiration'] < time());
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
-class AuthUserReturnsNull extends Laravel\Auth {
|
|
|
+class AuthUserReturnsNull extends Laravel\Auth\Drivers\Driver {
|
|
|
+
|
|
|
+ public function user() { return null; }
|
|
|
+
|
|
|
+ public function retrieve($id) { return null; }
|
|
|
|
|
|
- public static function user() {}
|
|
|
+ public function attempt($arguments = array()) { return null; }
|
|
|
|
|
|
}
|
|
|
|
|
|
-class AuthUserReturnsDummy extends Laravel\Auth {
|
|
|
+class AuthUserReturnsDummy extends Laravel\Auth\Drivers\Driver {
|
|
|
|
|
|
- public static function user() { return 'Taylor'; }
|
|
|
+ public function user() { return 'Taylor'; }
|
|
|
+
|
|
|
+ public function retrieve($id) { return null; }
|
|
|
+
|
|
|
+ public function attempt($arguments = array())
|
|
|
+ {
|
|
|
+ return $this->login($arguments['username']);
|
|
|
+ }
|
|
|
|
|
|
}
|
|
|
|
|
|
-class AuthLoginStub extends Laravel\Auth {
|
|
|
+class AuthLoginStub extends Laravel\Auth\Drivers\Fluent {
|
|
|
|
|
|
- public static function login($user, $remember = false)
|
|
|
+ public function login($user, $remember = false)
|
|
|
{
|
|
|
+ if (is_null($remember)) $remember = false;
|
|
|
+
|
|
|
$_SERVER['auth.login.stub'] = compact('user', 'remember');
|
|
|
+
|
|
|
+ return parent::login($user, $remember);
|
|
|
+ }
|
|
|
+
|
|
|
+ public function logout()
|
|
|
+ {
|
|
|
+ parent::logout();
|
|
|
+ }
|
|
|
+
|
|
|
+ public function retrieve($id)
|
|
|
+ {
|
|
|
+ $user = parent::retrieve($id);
|
|
|
+
|
|
|
+ $_SERVER['auth.login.stub'] = array(
|
|
|
+ 'user' => $user->id,
|
|
|
+ 'remember' => false,
|
|
|
+ );
|
|
|
+
|
|
|
+ return $user;
|
|
|
}
|
|
|
|
|
|
}
|