123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393 |
- <?php
- use Symfony\Component\HttpFoundation\LaravelRequest as RequestFoundation;
- use Laravel\Str;
- use Laravel\Auth;
- use Laravel\Cookie;
- use Laravel\Session;
- use Laravel\Crypter;
- use Laravel\Session\Payload;
- class AuthTest extends PHPUnit_Framework_TestCase {
- /**
- * Setup teh test environment.
- */
- public function setUp()
- {
- $_SERVER['auth.login.stub'] = null;
- $_SERVER['test.user.login'] = null;
- $_SERVER['test.user.logout'] = null;
- Cookie::$jar = array();
- Config::$items = array();
- Auth::driver()->user = null;
- Session::$instance = null;
- Config::set('database.default', 'sqlite');
- }
- /**
- * Tear down the test environment.
- */
- public function tearDown()
- {
- $_SERVER['auth.login.stub'] = null;
- $_SERVER['test.user.login'] = null;
- $_SERVER['test.user.logout'] = null;
-
- Cookie::$jar = array();
- Config::$items = array();
- Auth::driver()->user = null;
- Session::$instance = null;
- 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.
- *
- * @group laravel
- */
- public function testUserMethodReturnsCurrentUser()
- {
- Auth::driver()->user = 'Taylor';
- $this->assertEquals('Taylor', Auth::user());
- }
- /**
- * Test the Auth::check method.
- *
- * @group laravel
- */
- public function testCheckMethodReturnsTrueWhenUserIsSet()
- {
- $auth = new AuthUserReturnsDummy;
- $this->assertTrue($auth->check());
- }
- /**
- * Test the Auth::check method.
- *
- * @group laravel
- */
- public function testCheckMethodReturnsFalseWhenNoUserIsSet()
- {
- $auth = new AuthUserReturnsNull;
- $this->assertFalse($auth->check());
- }
- /**
- * Test the Auth::guest method.
- *
- * @group laravel
- */
- public function testGuestReturnsTrueWhenNoUserIsSet()
- {
- $auth = new AuthUserReturnsNull;
- $this->assertTrue($auth->guest());
- }
- /**
- * Test the Auth::guest method.
- *
- * @group laravel
- */
- public function testGuestReturnsFalseWhenUserIsSet()
- {
- $auth = new AuthUserReturnsDummy;
-
- $this->assertFalse($auth->guest());
- }
- /**
- * Test the Auth::user method.
- *
- * @group laravel
- */
- public function testUserMethodReturnsNullWhenNoUserExistsAndNoRecallerExists()
- {
- Session::$instance = new Payload($this->getMock('Laravel\\Session\\Drivers\\Driver'));
- $this->assertNull(Auth::user());
- }
- /**
- * Test the Auth::user method.
- *
- * @group laravel
- */
- public function testUserReturnsUserByID()
- {
- Session::$instance = new Payload($this->getMock('Laravel\\Session\\Drivers\\Driver'));
-
- Auth::login(1);
- $this->assertEquals('Taylor Otwell', Auth::user()->name);
- Auth::logout();
- }
- /**
- * Test the Auth::user method.
- *
- * @group laravel
- */
- public function testNullReturnedWhenUserIDNotValidInteger()
- {
- Session::$instance = new Payload($this->getMock('Laravel\\Session\\Drivers\\Driver'));
-
- Auth::login('asdlkasd');
- $this->assertNull(Auth::user());
- }
- /**
- * Test the Auth::recall method.
- *
- * @group laravel
- */
- public function testUserCanBeRecalledViaCookie()
- {
- Session::$instance = new Payload($this->getMock('Laravel\\Session\\Drivers\\Driver'));
- $cookie = Crypter::encrypt('1|'.Str::random(40));
- Cookie::forever('authloginstub_remember', $cookie);
- $auth = new AuthLoginStub;
- $this->assertEquals('Taylor Otwell', $auth->user()->name);
-
- $this->assertTrue($auth->user()->id === $_SERVER['auth.login.stub']['user']);
- }
- /**
- * Test the Auth::attempt method.
- *
- * @group laravel
- */
- public function testAttemptMethodReturnsFalseWhenCredentialsAreInvalid()
- {
- $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)));
- }
- /**
- * Test the Auth::attempt method.
- *
- * @group laravel
- */
- public function testAttemptReturnsTrueWhenCredentialsAreCorrect()
- {
- 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']);
- $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();
- }
- /**
- * Test Auth::login method.
- *
- * @group laravel
- */
- public function testLoginMethodStoresUserKeyInSession()
- {
- Session::$instance = new Payload($this->getMock('Laravel\\Session\\Drivers\\Driver'));
- $user = new StdClass;
- $user->id = 10;
- Auth::login($user);
- // FIXME: Not sure whether hard-coding the key is a good idea.
- $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);
- }
- /**
- * Test the Auth::login method.
- *
- * @group laravel
- */
- public function testLoginStoresRememberCookieWhenNeeded()
- {
- 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(1, true);
- $this->assertTrue(isset(Cookie::$jar['laravel_auth_drivers_fluent_remember']));
- $cookie = Cookie::get('laravel_auth_drivers_fluent_remember');
- $cookie = explode('|', Crypter::decrypt($cookie));
- $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');
- }
- /**
- * Test the Auth::logout method.
- *
- * @group laravel
- */
- public function testLogoutMethodLogsOutUser()
- {
- Session::$instance = new Payload($this->getMock('Laravel\\Session\\Drivers\\Driver'));
-
- $data = Session::$instance->session['data']['laravel_auth_drivers_fluent_login'] = 1;
- Auth::logout();
- $this->assertNull(Auth::user());
- $this->assertFalse(isset(Session::$instance->session['data']['laravel_auth_drivers_fluent_login']));
- $this->assertTrue(Cookie::$jar['laravel_auth_drivers_fluent_remember']['expiration'] < time());
- }
- /**
- * Test `laravel.auth: login` and `laravel.auth: logout` is called properly
- *
- * @group laravel
- */
- public function testAuthEventIsCalledProperly()
- {
- Session::$instance = new Payload($this->getMock('Laravel\\Session\\Drivers\\Driver'));
- Event::listen('laravel.auth: login', function ()
- {
- $_SERVER['test.user.login'] = 'foo';
- });
- Event::listen('laravel.auth: logout', function ()
- {
- $_SERVER['test.user.logout'] = 'foo';
- });
- $this->assertNull($_SERVER['test.user.login']);
- $this->assertNull($_SERVER['test.user.logout']);
-
- Auth::login(1, true);
- $this->assertEquals('foo', $_SERVER['test.user.login']);
- Auth::logout();
- $this->assertEquals('foo', $_SERVER['test.user.logout']);
- }
- }
- class AuthUserReturnsNull extends Laravel\Auth\Drivers\Driver {
- public function user() { return null; }
- public function retrieve($id) { return null; }
- public function attempt($arguments = array()) { return null; }
- }
- class AuthUserReturnsDummy extends Laravel\Auth\Drivers\Driver {
- 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\Drivers\Fluent {
-
- 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;
- }
- }
|