Browse Source

Update auth test case

Signed-off-by: crynobone <crynobone@gmail.com>
crynobone 12 years ago
parent
commit
590872d3c6
1 changed files with 37 additions and 0 deletions
  1. 37 0
      laravel/tests/cases/auth.test.php

+ 37 - 0
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 @@ class AuthTest extends PHPUnit_Framework_TestCase {
 	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 @@ class AuthTest extends PHPUnit_Framework_TestCase {
 		$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 {