2018-05-13 17:29:07 +01:00
|
|
|
<?php
|
|
|
|
|
2018-05-13 18:02:23 +01:00
|
|
|
namespace LeagueTests\Exception;
|
|
|
|
|
2018-11-13 00:25:22 +01:00
|
|
|
use Exception;
|
2018-05-13 17:29:07 +01:00
|
|
|
use League\OAuth2\Server\Exception\OAuthServerException;
|
|
|
|
use League\OAuth2\Server\Grant\AbstractGrant;
|
|
|
|
use League\OAuth2\Server\Repositories\ClientRepositoryInterface;
|
2018-05-13 17:41:21 +01:00
|
|
|
use PHPUnit\Framework\TestCase;
|
2018-05-13 17:29:07 +01:00
|
|
|
use Zend\Diactoros\Response;
|
|
|
|
use Zend\Diactoros\ServerRequest;
|
|
|
|
|
|
|
|
class OAuthServerExceptionTest extends TestCase
|
|
|
|
{
|
|
|
|
public function testInvalidClientExceptionSetsAuthenticateHeader()
|
|
|
|
{
|
|
|
|
$serverRequest = (new ServerRequest())
|
|
|
|
->withParsedBody([
|
|
|
|
'client_id' => 'foo',
|
|
|
|
])
|
|
|
|
->withAddedHeader('Authorization', 'Basic fakeauthdetails');
|
|
|
|
|
|
|
|
try {
|
|
|
|
$this->issueInvalidClientException($serverRequest);
|
|
|
|
} catch (OAuthServerException $e) {
|
|
|
|
$response = $e->generateHttpResponse(new Response());
|
|
|
|
|
|
|
|
$this->assertTrue($response->hasHeader('WWW-Authenticate'));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testInvalidClientExceptionOmitsAuthenticateHeader()
|
|
|
|
{
|
|
|
|
$serverRequest = (new ServerRequest())
|
|
|
|
->withParsedBody([
|
|
|
|
'client_id' => 'foo',
|
|
|
|
]);
|
|
|
|
|
|
|
|
try {
|
|
|
|
$this->issueInvalidClientException($serverRequest);
|
|
|
|
} catch (OAuthServerException $e) {
|
|
|
|
$response = $e->generateHttpResponse(new Response());
|
|
|
|
|
|
|
|
$this->assertFalse($response->hasHeader('WWW-Authenticate'));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Issue an invalid client exception
|
|
|
|
*
|
|
|
|
* @throws OAuthServerException
|
|
|
|
*/
|
|
|
|
private function issueInvalidClientException($serverRequest)
|
|
|
|
{
|
|
|
|
$clientRepositoryMock = $this->getMockBuilder(ClientRepositoryInterface::class)->getMock();
|
2018-09-01 14:26:22 +01:00
|
|
|
$clientRepositoryMock->method('validateClient')->willReturn(false);
|
2018-05-13 17:29:07 +01:00
|
|
|
|
|
|
|
$grantMock = $this->getMockForAbstractClass(AbstractGrant::class);
|
|
|
|
$grantMock->setClientRepository($clientRepositoryMock);
|
|
|
|
|
2018-05-13 18:02:23 +01:00
|
|
|
$abstractGrantReflection = new \ReflectionClass($grantMock);
|
2018-05-13 17:29:07 +01:00
|
|
|
|
|
|
|
$validateClientMethod = $abstractGrantReflection->getMethod('validateClient');
|
|
|
|
$validateClientMethod->setAccessible(true);
|
|
|
|
|
|
|
|
$validateClientMethod->invoke($grantMock, $serverRequest);
|
|
|
|
}
|
2018-06-24 01:10:02 +01:00
|
|
|
|
2017-02-04 14:48:40 -05:00
|
|
|
public function testHasRedirect()
|
|
|
|
{
|
|
|
|
$exceptionWithRedirect = OAuthServerException::accessDenied('some hint', 'https://example.com/error');
|
2018-05-25 10:00:21 +01:00
|
|
|
|
2017-02-04 14:48:40 -05:00
|
|
|
$this->assertTrue($exceptionWithRedirect->hasRedirect());
|
|
|
|
}
|
2018-05-25 10:00:21 +01:00
|
|
|
|
|
|
|
public function testDoesNotHaveRedirect()
|
|
|
|
{
|
|
|
|
$exceptionWithoutRedirect = OAuthServerException::accessDenied('Some hint');
|
|
|
|
|
|
|
|
$this->assertFalse($exceptionWithoutRedirect->hasRedirect());
|
|
|
|
}
|
2018-11-13 00:25:22 +01:00
|
|
|
|
|
|
|
public function testHasPrevious()
|
|
|
|
{
|
|
|
|
$previous = new Exception('This is the previous');
|
|
|
|
$exceptionWithPrevious = OAuthServerException::accessDenied(null, null, $previous);
|
|
|
|
|
|
|
|
$this->assertSame('This is the previous', $exceptionWithPrevious->getPrevious()->getMessage());
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testDoesNotHavePrevious()
|
|
|
|
{
|
|
|
|
$exceptionWithoutPrevious = OAuthServerException::accessDenied();
|
|
|
|
|
|
|
|
$this->assertNull($exceptionWithoutPrevious->getPrevious());
|
|
|
|
}
|
2018-05-13 17:29:07 +01:00
|
|
|
}
|