From 590872d3c6ec91d06fcc3c21e70a34d4de0be8a7 Mon Sep 17 00:00:00 2001 From: crynobone Date: Thu, 29 Nov 2012 22:18:24 +0800 Subject: [PATCH] Update auth test case Signed-off-by: crynobone --- laravel/tests/cases/auth.test.php | 37 +++++++++++++++++++++++++++++++ 1 file changed, 37 insertions(+) diff --git a/laravel/tests/cases/auth.test.php b/laravel/tests/cases/auth.test.php index 3be1c1e5..cce20fc9 100644 --- a/laravel/tests/cases/auth.test.php +++ b/laravel/tests/cases/auth.test.php @@ -17,6 +17,9 @@ class AuthTest extends PHPUnit_Framework_TestCase { 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; @@ -30,6 +33,9 @@ public function setUp() 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; @@ -300,6 +306,37 @@ public function testLogoutMethodLogsOutUser() $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 {