|
5 | 5 | use Illuminate\Http\Request; |
6 | 6 | use Illuminate\Http\Response; |
7 | 7 | use Laravel\Passport\AccessToken; |
| 8 | +use Laravel\Passport\Contracts\OAuthenticatable; |
8 | 9 | use Laravel\Passport\Exceptions\AuthenticationException; |
9 | 10 | use Laravel\Passport\Http\Middleware\CheckTokenForAnyScope; |
| 11 | +use Laravel\Passport\TransientToken; |
10 | 12 | use League\OAuth2\Server\Exception\OAuthServerException; |
11 | 13 | use League\OAuth2\Server\ResourceServer; |
12 | 14 | use Mockery\Adapter\Phpunit\MockeryPHPUnitIntegration; |
@@ -41,6 +43,27 @@ public function test_request_is_passed_along_if_token_is_valid() |
41 | 43 | $this->assertSame('response', $response->getContent()); |
42 | 44 | } |
43 | 45 |
|
| 46 | + public function test_request_is_passed_along_if_token_is_transient() |
| 47 | + { |
| 48 | + $user = m::mock(OAuthenticatable::class); |
| 49 | + $user->shouldReceive('currentAccessToken')->andReturn(new TransientToken()); |
| 50 | + |
| 51 | + $resourceServer = m::mock(ResourceServer::class); |
| 52 | + $resourceServer->shouldNotReceive('validateAuthenticatedRequest'); |
| 53 | + |
| 54 | + $middleware = new CheckTokenForAnyScope($resourceServer); |
| 55 | + |
| 56 | + $request = Request::create('/'); |
| 57 | + $request->headers->set('Authorization', 'Bearer token'); |
| 58 | + $request->setUserResolver(fn () => $user); |
| 59 | + |
| 60 | + $response = $middleware->handle($request, function () { |
| 61 | + return new Response('response'); |
| 62 | + }, 'notfoo'); |
| 63 | + |
| 64 | + $this->assertSame('response', $response->getContent()); |
| 65 | + } |
| 66 | + |
44 | 67 | public function test_request_is_passed_along_if_token_has_any_required_scope() |
45 | 68 | { |
46 | 69 | $resourceServer = m::mock(ResourceServer::class); |
|
0 commit comments