95 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			95 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| namespace Tymon\JWTAuth\Test;
 | |
| 
 | |
| use Mockery;
 | |
| use Tymon\JWTAuth\Middleware\GetUserFromToken;
 | |
| use Tymon\JWTAuth\Exceptions\TokenExpiredException;
 | |
| use Tymon\JWTAuth\Exceptions\TokenInvalidException;
 | |
| 
 | |
| class GetUserFromTokenTest extends \PHPUnit_Framework_TestCase
 | |
| {
 | |
|     public function setUp()
 | |
|     {
 | |
|         $this->events = Mockery::mock('Illuminate\Events\Dispatcher');
 | |
|         $this->auth = Mockery::mock('Tymon\JWTAuth\JWTAuth');
 | |
| 
 | |
|         $this->request = Mockery::mock('Illuminate\Http\Request');
 | |
|         $this->response = Mockery::mock('Illuminate\Routing\ResponseFactory');
 | |
| 
 | |
|         $this->middleware = new GetUserFromToken($this->response, $this->events, $this->auth);
 | |
| 
 | |
|         $this->auth->shouldReceive('setRequest')->once()->with($this->request)->andReturn($this->auth);
 | |
|     }
 | |
| 
 | |
|     public function tearDown()
 | |
|     {
 | |
|         Mockery::close();
 | |
|     }
 | |
| 
 | |
|     /** @test */
 | |
|     public function it_should_fire_an_event_when_no_token_is_available()
 | |
|     {
 | |
|         $this->auth->shouldReceive('getToken')->once()->andReturn(false);
 | |
| 
 | |
|         $this->events->shouldReceive('fire')->once()->with('tymon.jwt.absent', [], true);
 | |
|         $this->response->shouldReceive('json')->with(['error' => 'token_not_provided'], 400);
 | |
| 
 | |
|         $this->middleware->handle($this->request, function () {});
 | |
|     }
 | |
| 
 | |
|     /** @test */
 | |
|     public function it_should_fire_an_event_when_the_token_has_expired()
 | |
|     {
 | |
|         $exception = new TokenExpiredException;
 | |
| 
 | |
|         $this->auth->shouldReceive('getToken')->once()->andReturn('foo');
 | |
|         $this->auth->shouldReceive('authenticate')->once()->with('foo')->andThrow($exception);
 | |
| 
 | |
|         $this->events->shouldReceive('fire')->once()->with('tymon.jwt.expired', [$exception], true);
 | |
|         $this->response->shouldReceive('json')->with(['error' => 'token_expired'], 401);
 | |
| 
 | |
|         $this->middleware->handle($this->request, function () {});
 | |
|     }
 | |
| 
 | |
|     /** @test */
 | |
|     public function it_should_fire_an_event_when_the_token_is_invalid()
 | |
|     {
 | |
|         $exception = new TokenInvalidException;
 | |
| 
 | |
|         $this->auth->shouldReceive('getToken')->once()->andReturn('foo');
 | |
|         $this->auth->shouldReceive('authenticate')->once()->with('foo')->andThrow($exception);
 | |
| 
 | |
|         $this->events->shouldReceive('fire')->once()->with('tymon.jwt.invalid', [$exception], true);
 | |
|         $this->response->shouldReceive('json')->with(['error' => 'token_invalid'], 400);
 | |
| 
 | |
|         $this->middleware->handle($this->request, function () {});
 | |
|     }
 | |
| 
 | |
|     /** @test */
 | |
|     public function it_should_fire_an_event_when_no_user_is_found()
 | |
|     {
 | |
|         $this->auth->shouldReceive('getToken')->once()->andReturn('foo');
 | |
|         $this->auth->shouldReceive('authenticate')->once()->with('foo')->andReturn(false);
 | |
| 
 | |
|         $this->events->shouldReceive('fire')->once()->with('tymon.jwt.user_not_found', [], true);
 | |
|         $this->response->shouldReceive('json')->with(['error' => 'user_not_found'], 404);
 | |
| 
 | |
|         $this->middleware->handle($this->request, function () {});
 | |
|     }
 | |
| 
 | |
|     /** @test */
 | |
|     public function it_should_fire_an_event_when_the_token_has_been_decoded_and_user_is_found()
 | |
|     {
 | |
|         $user = (object) ['id' => 1];
 | |
| 
 | |
|         $this->auth->shouldReceive('getToken')->once()->andReturn('foo');
 | |
|         $this->auth->shouldReceive('authenticate')->once()->with('foo')->andReturn($user);
 | |
| 
 | |
|         $this->events->shouldReceive('fire')->once()->with('tymon.jwt.valid', $user);
 | |
|         $this->response->shouldReceive('json')->never();
 | |
| 
 | |
|         $this->middleware->handle($this->request, function () {});
 | |
|     }
 | |
| }
 | 
