123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109 |
- <?php
- /*
- * This file is part of jwt-auth.
- *
- * (c) Sean Tymon <tymon148@gmail.com>
- *
- * For the full copyright and license information, please view the LICENSE
- * file that was distributed with this source code.
- */
- 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\Contracts\Events\Dispatcher');
- $this->auth = Mockery::mock('Tymon\JWTAuth\JWTAuth');
- $this->request = Mockery::mock('Illuminate\Http\Request');
- $this->response = Mockery::mock('Illuminate\Contracts\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 () {
- });
- }
- }
|