mirror of
https://github.com/elyby/league-oauth2-ely.git
synced 2025-01-12 23:12:13 +05:30
129 lines
4.8 KiB
PHP
129 lines
4.8 KiB
PHP
<?php
|
|
/** @noinspection PhpUnhandledExceptionInspection */
|
|
namespace Ely\OAuth2\Client\Test;
|
|
|
|
use Ely\OAuth2\Client\Exception\IdentityProviderException;
|
|
use Ely\OAuth2\Client\Provider;
|
|
use Ely\OAuth2\Client\ResourceOwner;
|
|
use GuzzleHttp\Client;
|
|
use GuzzleHttp\Handler\MockHandler;
|
|
use GuzzleHttp\HandlerStack;
|
|
use GuzzleHttp\Psr7\Response;
|
|
use League\OAuth2\Client\Token\AccessToken;
|
|
use PHPUnit\Framework\TestCase;
|
|
|
|
class ProviderTest extends TestCase {
|
|
|
|
/**
|
|
* @var Provider
|
|
*/
|
|
private $provider;
|
|
|
|
/**
|
|
* @var MockHandler
|
|
*/
|
|
private $mockHandler;
|
|
|
|
protected function setUp() {
|
|
$this->provider = new Provider([
|
|
'clientId' => 'mock_client_id',
|
|
'clientSecret' => 'mock_secret',
|
|
'redirectUri' => 'none',
|
|
]);
|
|
$this->mockHandler = new MockHandler();
|
|
$client = new Client(['handler' => HandlerStack::create($this->mockHandler)]);
|
|
$this->provider->setHttpClient($client);
|
|
}
|
|
|
|
public function testGetResourceOwnerDetailsUrl() {
|
|
$url = $this->provider->getResourceOwnerDetailsUrl(new AccessToken(['access_token' => 'mock_token']));
|
|
$this->assertSame('/api/account/v1/info', parse_url($url, PHP_URL_PATH));
|
|
}
|
|
|
|
public function testGetAuthorizationUrl() {
|
|
$url = $this->provider->getAuthorizationUrl();
|
|
$uri = parse_url($url);
|
|
parse_str($uri['query'], $query);
|
|
|
|
$this->assertSame('/oauth2/v1/mock_client_id', $uri['path']);
|
|
$this->assertArrayNotHasKey('client_id', $query);
|
|
$this->assertArrayHasKey('redirect_uri', $query);
|
|
$this->assertArrayHasKey('state', $query);
|
|
$this->assertArrayHasKey('scope', $query);
|
|
$this->assertArrayHasKey('response_type', $query);
|
|
$this->assertArrayNotHasKey('approval_prompt', $query);
|
|
$this->assertNotNull($this->provider->getState());
|
|
}
|
|
|
|
public function testScopes() {
|
|
$options = ['scope' => ['minecraft_server_session', 'account_info']];
|
|
$url = $this->provider->getAuthorizationUrl($options);
|
|
$this->assertContains('scope=minecraft_server_session%2Caccount_info', $url);
|
|
}
|
|
|
|
public function testGetBaseAccessTokenUrl() {
|
|
$url = $this->provider->getBaseAccessTokenUrl([]);
|
|
$this->assertSame('/api/oauth2/v1/token', parse_url($url, PHP_URL_PATH));
|
|
}
|
|
|
|
public function testGetAccessToken() {
|
|
$this->mockHandler->append(new Response(200, ['content-type' => 'json'], $this->getAccessTokenResponse()));
|
|
|
|
$token = $this->provider->getAccessToken('authorization_code', ['code' => 'mock_authorization_code']);
|
|
|
|
$this->assertSame('mock_access_token', $token->getToken());
|
|
$this->assertNotNull($token->getExpires());
|
|
$this->assertNull($token->getRefreshToken());
|
|
}
|
|
|
|
public function testExceptionThrownWhenErrorObjectReceived() {
|
|
$this->mockHandler->append(new Response(418, ['content-type' => 'json'], json_encode([
|
|
'name' => 'Some error happened',
|
|
'message' => 'Some exception message',
|
|
'status' => 418,
|
|
'code' => 0,
|
|
])));
|
|
|
|
$this->setExpectedException(IdentityProviderException::class, 'Some exception message');
|
|
|
|
$this->provider->getAccessToken('authorization_code', ['code' => 'mock_authorization_code']);
|
|
}
|
|
|
|
public function testExceptionThrownOnIncorrectContentType() {
|
|
$this->mockHandler->append(new Response(502, ['content-type' => 'text/html; charset=UTF-8'], 'html content'));
|
|
|
|
$this->setExpectedException(IdentityProviderException::class, 'Bad Gateway');
|
|
|
|
$this->provider->getAccessToken('authorization_code', ['code' => 'mock_authorization_code']);
|
|
}
|
|
|
|
public function testGetResourceOwner() {
|
|
$this->mockHandler->append(new Response(200, ['content-type' => 'json'], $this->getAccessTokenResponse()));
|
|
$this->mockHandler->append(new Response(200, ['content-type' => 'json'], json_encode([
|
|
'id' => 1,
|
|
'uuid' => 'ffc8fdc9-5824-509e-8a57-c99b940fb996',
|
|
'username' => 'ErickSkrauch',
|
|
'registeredAt' => 1470566470,
|
|
'profileLink' => 'http://ely.by/u1',
|
|
'preferredLanguage' => 'be',
|
|
'email' => 'erickskrauch@ely.by',
|
|
])));
|
|
|
|
/** @var AccessToken $token */
|
|
$token = $this->provider->getAccessToken('authorization_code', ['code' => 'mock_authorization_code']);
|
|
$user = $this->provider->getResourceOwner($token);
|
|
|
|
$this->assertInstanceOf(ResourceOwner::class, $user);
|
|
$this->assertSame(0, $this->mockHandler->count());
|
|
}
|
|
|
|
private function getAccessTokenResponse() {
|
|
return json_encode([
|
|
'access_token' => 'mock_access_token',
|
|
'token_type' => 'bearer',
|
|
'expires_in' => 3600,
|
|
]);
|
|
}
|
|
|
|
}
|