Files
Kanboard-Prod/vendor/lusitanian/oauth/tests/Unit/OAuth2/Service/AbstractServiceTest.php
2014-11-06 06:41:47 -05:00

402 lines
17 KiB
PHP

<?php
namespace OAuthTest\Unit\OAuth2\Service;
use OAuthTest\Mocks\OAuth2\Service\Mock;
use OAuth\Common\Http\Uri\Uri;
use OAuth\Common\Token\TokenInterface;
class AbstractServiceTest extends \PHPUnit_Framework_TestCase
{
/**
* @covers OAuth\OAuth2\Service\AbstractService::__construct
*/
public function testConstructCorrectInterface()
{
$service = $this->getMockForAbstractClass(
'\\OAuth\\OAuth2\\Service\\AbstractService',
array(
$this->getMock('\\OAuth\\Common\\Consumer\\CredentialsInterface'),
$this->getMock('\\OAuth\\Common\\Http\\Client\\ClientInterface'),
$this->getMock('\\OAuth\\Common\\Storage\\TokenStorageInterface'),
array(),
)
);
$this->assertInstanceOf('\\OAuth\\OAuth2\\Service\\ServiceInterface', $service);
}
/**
* @covers OAuth\OAuth2\Service\AbstractService::__construct
*/
public function testConstructCorrectParent()
{
$service = $this->getMockForAbstractClass(
'\\OAuth\\OAuth2\\Service\\AbstractService',
array(
$this->getMock('\\OAuth\\Common\\Consumer\\CredentialsInterface'),
$this->getMock('\\OAuth\\Common\\Http\\Client\\ClientInterface'),
$this->getMock('\\OAuth\\Common\\Storage\\TokenStorageInterface'),
array(),
)
);
$this->assertInstanceOf('\\OAuth\\Common\\Service\\AbstractService', $service);
}
/**
* @covers OAuth\OAuth2\Service\AbstractService::__construct
*/
public function testConstructCorrectParentCustomUri()
{
$service = $this->getMockForAbstractClass(
'\\OAuth\\OAuth2\\Service\\AbstractService',
array(
$this->getMock('\\OAuth\\Common\\Consumer\\CredentialsInterface'),
$this->getMock('\\OAuth\\Common\\Http\\Client\\ClientInterface'),
$this->getMock('\\OAuth\\Common\\Storage\\TokenStorageInterface'),
array(),
$this->getMock('\\OAuth\\Common\\Http\\Uri\\UriInterface'),
)
);
$this->assertInstanceOf('\\OAuth\\Common\\Service\\AbstractService', $service);
}
/**
* @covers OAuth\OAuth2\Service\AbstractService::__construct
* @covers OAuth\OAuth2\Service\AbstractService::isValidScope
*/
public function testConstructThrowsExceptionOnInvalidScope()
{
$this->setExpectedException('\\OAuth\\OAuth2\\Service\\Exception\\InvalidScopeException');
$service = new Mock(
$this->getMock('\\OAuth\\Common\\Consumer\\CredentialsInterface'),
$this->getMock('\\OAuth\\Common\\Http\\Client\\ClientInterface'),
$this->getMock('\\OAuth\\Common\\Storage\\TokenStorageInterface'),
array('invalidscope')
);
}
/**
* @covers OAuth\OAuth2\Service\AbstractService::__construct
* @covers OAuth\OAuth2\Service\AbstractService::getAuthorizationUri
* @covers OAuth\OAuth2\Service\AbstractService::getAuthorizationEndpoint
*/
public function testGetAuthorizationUriWithoutParametersOrScopes()
{
$credentials = $this->getMock('\\OAuth\\Common\\Consumer\\CredentialsInterface');
$credentials->expects($this->once())->method('getConsumerId')->will($this->returnValue('foo'));
$credentials->expects($this->once())->method('getCallbackUrl')->will($this->returnValue('bar'));
$service = new Mock(
$credentials,
$this->getMock('\\OAuth\\Common\\Http\\Client\\ClientInterface'),
$this->getMock('\\OAuth\\Common\\Storage\\TokenStorageInterface')
);
$this->assertSame(
'http://pieterhordijk.com/auth?type=web_server&client_id=foo&redirect_uri=bar&response_type=code&scope=',
$service->getAuthorizationUri()->getAbsoluteUri()
);
}
/**
* @covers OAuth\OAuth2\Service\AbstractService::__construct
* @covers OAuth\OAuth2\Service\AbstractService::getAuthorizationUri
* @covers OAuth\OAuth2\Service\AbstractService::getAuthorizationEndpoint
*/
public function testGetAuthorizationUriWithParametersWithoutScopes()
{
$credentials = $this->getMock('\\OAuth\\Common\\Consumer\\CredentialsInterface');
$credentials->expects($this->once())->method('getConsumerId')->will($this->returnValue('foo'));
$credentials->expects($this->once())->method('getCallbackUrl')->will($this->returnValue('bar'));
$service = new Mock(
$credentials,
$this->getMock('\\OAuth\\Common\\Http\\Client\\ClientInterface'),
$this->getMock('\\OAuth\\Common\\Storage\\TokenStorageInterface')
);
$this->assertSame(
'http://pieterhordijk.com/auth?foo=bar&baz=beer&type=web_server&client_id=foo&redirect_uri=bar&response_type=code&scope=',
$service->getAuthorizationUri(array('foo' => 'bar', 'baz' => 'beer'))->getAbsoluteUri()
);
}
/**
* @covers OAuth\OAuth2\Service\AbstractService::__construct
* @covers OAuth\OAuth2\Service\AbstractService::isValidScope
* @covers OAuth\OAuth2\Service\AbstractService::getAuthorizationUri
* @covers OAuth\OAuth2\Service\AbstractService::getAuthorizationEndpoint
*/
public function testGetAuthorizationUriWithParametersAndScopes()
{
$credentials = $this->getMock('\\OAuth\\Common\\Consumer\\CredentialsInterface');
$credentials->expects($this->once())->method('getConsumerId')->will($this->returnValue('foo'));
$credentials->expects($this->once())->method('getCallbackUrl')->will($this->returnValue('bar'));
$service = new Mock(
$credentials,
$this->getMock('\\OAuth\\Common\\Http\\Client\\ClientInterface'),
$this->getMock('\\OAuth\\Common\\Storage\\TokenStorageInterface'),
array('mock', 'mock2')
);
$this->assertSame(
'http://pieterhordijk.com/auth?foo=bar&baz=beer&type=web_server&client_id=foo&redirect_uri=bar&response_type=code&scope=mock+mock2',
$service->getAuthorizationUri(array('foo' => 'bar', 'baz' => 'beer'))->getAbsoluteUri()
);
}
/**
* @covers OAuth\OAuth2\Service\AbstractService::__construct
* @covers OAuth\OAuth2\Service\AbstractService::requestAccessToken
* @covers OAuth\OAuth2\Service\AbstractService::getAccessTokenEndpoint
* @covers OAuth\OAuth2\Service\AbstractService::getExtraOAuthHeaders
* @covers OAuth\OAuth2\Service\AbstractService::parseAccessTokenResponse
* @covers OAuth\OAuth2\Service\AbstractService::service
*/
public function testRequestAccessToken()
{
$service = new Mock(
$this->getMock('\\OAuth\\Common\\Consumer\\CredentialsInterface'),
$this->getMock('\\OAuth\\Common\\Http\\Client\\ClientInterface'),
$this->getMock('\\OAuth\\Common\\Storage\\TokenStorageInterface')
);
$this->assertInstanceof('\\OAuth\\OAuth2\\Token\\StdOAuth2Token', $service->requestAccessToken('code'));
}
/**
* @covers OAuth\OAuth2\Service\AbstractService::__construct
* @covers OAuth\OAuth2\Service\AbstractService::request
* @covers OAuth\OAuth2\Service\AbstractService::determineRequestUriFromPath
*/
public function testRequestThrowsExceptionWhenTokenIsExpired()
{
$tokenExpiration = new \DateTime('26-03-1984 00:00:00');
$token = $this->getMock('\\OAuth\\OAuth2\\Token\\TokenInterface');
$token->expects($this->any())->method('getEndOfLife')->will($this->returnValue($tokenExpiration->format('U')));
$storage = $this->getMock('\\OAuth\\Common\\Storage\\TokenStorageInterface');
$storage->expects($this->once())->method('retrieveAccessToken')->will($this->returnValue($token));
$service = new Mock(
$this->getMock('\\OAuth\\Common\\Consumer\\CredentialsInterface'),
$this->getMock('\\OAuth\\Common\\Http\\Client\\ClientInterface'),
$storage
);
$this->setExpectedException('\\OAuth\\Common\\Token\\Exception\\ExpiredTokenException', 'Token expired on 03/26/1984 at 12:00:00 AM');
$service->request('https://pieterhordijk.com/my/awesome/path');
}
/**
* @covers OAuth\OAuth2\Service\AbstractService::__construct
* @covers OAuth\OAuth2\Service\AbstractService::request
* @covers OAuth\OAuth2\Service\AbstractService::determineRequestUriFromPath
* @covers OAuth\OAuth2\Service\AbstractService::getAuthorizationMethod
* @covers OAuth\OAuth2\Service\AbstractService::parseAccessTokenResponse
* @covers OAuth\OAuth2\Service\AbstractService::service
* @covers OAuth\OAuth2\Service\AbstractService::getExtraApiHeaders
*/
public function testRequestOauthAuthorizationMethod()
{
$client = $this->getMock('\\OAuth\\Common\\Http\\Client\\ClientInterface');
$client->expects($this->once())->method('retrieveResponse')->will($this->returnArgument(2));
$token = $this->getMock('\\OAuth\\OAuth2\\Token\\TokenInterface');
$token->expects($this->once())->method('getEndOfLife')->will($this->returnValue(TokenInterface::EOL_NEVER_EXPIRES));
$token->expects($this->once())->method('getAccessToken')->will($this->returnValue('foo'));
$storage = $this->getMock('\\OAuth\\Common\\Storage\\TokenStorageInterface');
$storage->expects($this->once())->method('retrieveAccessToken')->will($this->returnValue($token));
$service = new Mock(
$this->getMock('\\OAuth\\Common\\Consumer\\CredentialsInterface'),
$client,
$storage
);
$headers = $service->request('https://pieterhordijk.com/my/awesome/path');
$this->assertTrue(array_key_exists('Authorization', $headers));
$this->assertTrue(in_array('OAuth foo', $headers, true));
}
/**
* @covers OAuth\OAuth2\Service\AbstractService::__construct
* @covers OAuth\OAuth2\Service\AbstractService::request
* @covers OAuth\OAuth2\Service\AbstractService::determineRequestUriFromPath
* @covers OAuth\OAuth2\Service\AbstractService::getAuthorizationMethod
* @covers OAuth\OAuth2\Service\AbstractService::parseAccessTokenResponse
* @covers OAuth\OAuth2\Service\AbstractService::service
* @covers OAuth\OAuth2\Service\AbstractService::getExtraApiHeaders
*/
public function testRequestQueryStringMethod()
{
$client = $this->getMock('\\OAuth\\Common\\Http\\Client\\ClientInterface');
$client->expects($this->once())->method('retrieveResponse')->will($this->returnArgument(0));
$token = $this->getMock('\\OAuth\\OAuth2\\Token\\TokenInterface');
$token->expects($this->once())->method('getEndOfLife')->will($this->returnValue(TokenInterface::EOL_NEVER_EXPIRES));
$token->expects($this->once())->method('getAccessToken')->will($this->returnValue('foo'));
$storage = $this->getMock('\\OAuth\\Common\\Storage\\TokenStorageInterface');
$storage->expects($this->once())->method('retrieveAccessToken')->will($this->returnValue($token));
$service = new Mock(
$this->getMock('\\OAuth\\Common\\Consumer\\CredentialsInterface'),
$client,
$storage
);
$service->setAuthorizationMethod('querystring');
$uri = $service->request('https://pieterhordijk.com/my/awesome/path');
$absoluteUri = parse_url($uri->getAbsoluteUri());
$this->assertSame('access_token=foo', $absoluteUri['query']);
}
/**
* @covers OAuth\OAuth2\Service\AbstractService::__construct
* @covers OAuth\OAuth2\Service\AbstractService::request
* @covers OAuth\OAuth2\Service\AbstractService::determineRequestUriFromPath
* @covers OAuth\OAuth2\Service\AbstractService::getAuthorizationMethod
* @covers OAuth\OAuth2\Service\AbstractService::parseAccessTokenResponse
* @covers OAuth\OAuth2\Service\AbstractService::service
* @covers OAuth\OAuth2\Service\AbstractService::getExtraApiHeaders
*/
public function testRequestQueryStringTwoMethod()
{
$client = $this->getMock('\\OAuth\\Common\\Http\\Client\\ClientInterface');
$client->expects($this->once())->method('retrieveResponse')->will($this->returnArgument(0));
$token = $this->getMock('\\OAuth\\OAuth2\\Token\\TokenInterface');
$token->expects($this->once())->method('getEndOfLife')->will($this->returnValue(TokenInterface::EOL_NEVER_EXPIRES));
$token->expects($this->once())->method('getAccessToken')->will($this->returnValue('foo'));
$storage = $this->getMock('\\OAuth\\Common\\Storage\\TokenStorageInterface');
$storage->expects($this->once())->method('retrieveAccessToken')->will($this->returnValue($token));
$service = new Mock(
$this->getMock('\\OAuth\\Common\\Consumer\\CredentialsInterface'),
$client,
$storage
);
$service->setAuthorizationMethod('querystring2');
$uri = $service->request('https://pieterhordijk.com/my/awesome/path');
$absoluteUri = parse_url($uri->getAbsoluteUri());
$this->assertSame('oauth2_access_token=foo', $absoluteUri['query']);
}
/**
* @covers OAuth\OAuth2\Service\AbstractService::__construct
* @covers OAuth\OAuth2\Service\AbstractService::request
* @covers OAuth\OAuth2\Service\AbstractService::determineRequestUriFromPath
* @covers OAuth\OAuth2\Service\AbstractService::getAuthorizationMethod
* @covers OAuth\OAuth2\Service\AbstractService::parseAccessTokenResponse
* @covers OAuth\OAuth2\Service\AbstractService::service
* @covers OAuth\OAuth2\Service\AbstractService::getExtraApiHeaders
*/
public function testRequestBearerMethod()
{
$client = $this->getMock('\\OAuth\\Common\\Http\\Client\\ClientInterface');
$client->expects($this->once())->method('retrieveResponse')->will($this->returnArgument(2));
$token = $this->getMock('\\OAuth\\OAuth2\\Token\\TokenInterface');
$token->expects($this->once())->method('getEndOfLife')->will($this->returnValue(TokenInterface::EOL_NEVER_EXPIRES));
$token->expects($this->once())->method('getAccessToken')->will($this->returnValue('foo'));
$storage = $this->getMock('\\OAuth\\Common\\Storage\\TokenStorageInterface');
$storage->expects($this->once())->method('retrieveAccessToken')->will($this->returnValue($token));
$service = new Mock(
$this->getMock('\\OAuth\\Common\\Consumer\\CredentialsInterface'),
$client,
$storage
);
$service->setAuthorizationMethod('bearer');
$headers = $service->request('https://pieterhordijk.com/my/awesome/path');
$this->assertTrue(array_key_exists('Authorization', $headers));
$this->assertTrue(in_array('Bearer foo', $headers, true));
}
/**
* @covers OAuth\OAuth2\Service\AbstractService::__construct
* @covers OAuth\OAuth2\Service\AbstractService::getStorage
*/
public function testGetStorage()
{
$service = new Mock(
$this->getMock('\\OAuth\\Common\\Consumer\\CredentialsInterface'),
$this->getMock('\\OAuth\\Common\\Http\\Client\\ClientInterface'),
$this->getMock('\\OAuth\\Common\\Storage\\TokenStorageInterface')
);
$this->assertInstanceOf('\\OAuth\\Common\\Storage\\TokenStorageInterface', $service->getStorage());
}
/**
* @covers OAuth\OAuth2\Service\AbstractService::__construct
* @covers OAuth\OAuth2\Service\AbstractService::refreshAccessToken
* @covers OAuth\OAuth2\Service\AbstractService::getAccessTokenEndpoint
* @covers OAuth\OAuth2\Service\AbstractService::getExtraOAuthHeaders
* @covers OAuth\OAuth2\Service\AbstractService::parseAccessTokenResponse
*/
public function testRefreshAccessTokenSuccess()
{
$service = new Mock(
$this->getMock('\\OAuth\\Common\\Consumer\\CredentialsInterface'),
$this->getMock('\\OAuth\\Common\\Http\\Client\\ClientInterface'),
$this->getMock('\\OAuth\\Common\\Storage\\TokenStorageInterface')
);
$token = $this->getMock('\\OAuth\\OAuth2\\Token\\StdOAuth2Token');
$token->expects($this->once())->method('getRefreshToken')->will($this->returnValue('foo'));
$this->assertInstanceOf('\\OAuth\\OAuth2\\Token\\StdOAuth2Token', $service->refreshAccessToken($token));
}
/**
* @covers OAuth\OAuth2\Service\AbstractService::__construct
* @covers OAuth\OAuth2\Service\AbstractService::isValidScope
*/
public function testIsValidScopeTrue()
{
$service = new Mock(
$this->getMock('\\OAuth\\Common\\Consumer\\CredentialsInterface'),
$this->getMock('\\OAuth\\Common\\Http\\Client\\ClientInterface'),
$this->getMock('\\OAuth\\Common\\Storage\\TokenStorageInterface')
);
$this->assertTrue($service->isValidScope('mock'));
}
/**
* @covers OAuth\OAuth2\Service\AbstractService::__construct
* @covers OAuth\OAuth2\Service\AbstractService::isValidScope
*/
public function testIsValidScopeFalse()
{
$service = new Mock(
$this->getMock('\\OAuth\\Common\\Consumer\\CredentialsInterface'),
$this->getMock('\\OAuth\\Common\\Http\\Client\\ClientInterface'),
$this->getMock('\\OAuth\\Common\\Storage\\TokenStorageInterface')
);
$this->assertFalse($service->isValidScope('invalid'));
}
}