setExpireTime(time() + 3600); $accessToken->setId('mock-token'); $this->mockFoundedAccessToken($accessToken); $identity = OAuth2Identity::findIdentityByAccessToken('mock-token'); $this->assertSame('mock-token', $identity->getId()); } public function testFindIdentityByAccessTokenWithNonExistsToken() { $this->expectException(UnauthorizedHttpException::class); $this->expectExceptionMessage('Incorrect token'); OAuth2Identity::findIdentityByAccessToken('not exists token'); } public function testFindIdentityByAccessTokenWithExpiredToken() { $this->expectException(UnauthorizedHttpException::class); $this->expectExceptionMessage('Token expired'); $accessToken = new AccessTokenEntity(mock(AbstractServer::class)); $accessToken->setExpireTime(time() - 3600); $this->mockFoundedAccessToken($accessToken); OAuth2Identity::findIdentityByAccessToken('mock-token'); } private function mockFoundedAccessToken(AccessTokenEntity $accessToken) { /** @var AccessTokenInterface|\Mockery\MockInterface $accessTokensStorage */ $accessTokensStorage = mock(AccessTokenInterface::class); $accessTokensStorage->shouldReceive('get')->with('mock-token')->andReturn($accessToken); /** @var Component|\Mockery\MockInterface $component */ $component = mock(Component::class); $component->shouldReceive('getAccessTokenStorage')->andReturn($accessTokensStorage); Yii::$app->set('oauth', $component); } }