2014-01-16 16:51:06 +00:00
|
|
|
<?php
|
|
|
|
|
2014-05-02 15:12:15 +01:00
|
|
|
namespace LeagueTests\Entity;
|
2014-01-16 16:51:06 +00:00
|
|
|
|
2014-05-02 15:12:15 +01:00
|
|
|
use League\OAuth2\Server\Entity\AccessTokenEntity;
|
|
|
|
use League\OAuth2\Server\Entity\ClientEntity;
|
|
|
|
use League\OAuth2\Server\Entity\RefreshTokenEntity;
|
|
|
|
use League\OAuth2\Server\Entity\SessionEntity;
|
|
|
|
use League\OAuth2\Server\Entity\ScopeEntity;
|
2014-05-02 17:21:53 +01:00
|
|
|
use League\OAuth2\Server\AuthorizationServer;
|
2014-01-16 16:51:06 +00:00
|
|
|
use \Mockery as M;
|
|
|
|
|
2014-05-03 10:55:25 +01:00
|
|
|
class SessionTest extends \PHPUnit_Framework_TestCase
|
2014-01-16 16:51:06 +00:00
|
|
|
{
|
|
|
|
public function testSetGet()
|
|
|
|
{
|
|
|
|
$server = M::mock('League\OAuth2\Server\AbstractServer');
|
2014-05-02 17:21:53 +01:00
|
|
|
$entity = new SessionEntity($server);
|
2014-01-16 16:51:06 +00:00
|
|
|
$entity->setId('foobar');
|
|
|
|
$entity->setOwner('user', 123);
|
2014-05-02 17:21:53 +01:00
|
|
|
$entity->associateAccessToken((new AccessTokenEntity($server)));
|
|
|
|
$entity->associateRefreshToken((new RefreshTokenEntity($server)));
|
|
|
|
$entity->associateClient((new ClientEntity($server)));
|
|
|
|
$entity->associateScope((new ScopeEntity($server))->setId('foo'));
|
2014-01-16 16:51:06 +00:00
|
|
|
// $entity->associateAuthCode((new AuthCode($server)));
|
|
|
|
|
|
|
|
$this->assertEquals('foobar', $entity->getId());
|
|
|
|
$this->assertEquals('user', $entity->getOwnerType());
|
|
|
|
$this->assertEquals(123, $entity->getOwnerId());
|
2014-05-02 17:21:53 +01:00
|
|
|
$this->assertTrue($entity->getClient() instanceof ClientEntity);
|
2014-01-16 16:51:06 +00:00
|
|
|
$this->assertTrue($entity->hasScope('foo'));
|
2014-01-16 17:27:05 +00:00
|
|
|
|
|
|
|
$reflector = new \ReflectionClass($entity);
|
|
|
|
$accessTokenProperty = $reflector->getProperty('accessToken');
|
|
|
|
$accessTokenProperty->setAccessible(true);
|
|
|
|
$refreshTokenProperty = $reflector->getProperty('refreshToken');
|
|
|
|
$refreshTokenProperty->setAccessible(true);
|
|
|
|
|
2014-05-02 17:21:53 +01:00
|
|
|
$this->assertTrue($accessTokenProperty->getValue($entity) instanceof AccessTokenEntity);
|
|
|
|
$this->assertTrue($refreshTokenProperty->getValue($entity) instanceof RefreshTokenEntity);
|
2014-01-16 16:51:06 +00:00
|
|
|
// $this->assertTrue($reader($entity, 'authCode') instanceof AuthCode);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testFormatScopes()
|
|
|
|
{
|
|
|
|
$server = M::mock('League\OAuth2\Server\AbstractServer');
|
|
|
|
|
2014-05-02 17:21:53 +01:00
|
|
|
$entity = new SessionEntity($server);
|
|
|
|
$reflectedEntity = new \ReflectionClass('League\OAuth2\Server\Entity\SessionEntity');
|
2014-01-16 16:51:06 +00:00
|
|
|
$method = $reflectedEntity->getMethod('formatScopes');
|
|
|
|
$method->setAccessible(true);
|
|
|
|
|
|
|
|
$scopes = [
|
2014-05-02 17:21:53 +01:00
|
|
|
(new ScopeEntity($server))->setId('scope1')->setDescription('foo'),
|
|
|
|
(new ScopeEntity($server))->setId('scope2')->setDescription('bar')
|
2014-01-16 16:51:06 +00:00
|
|
|
];
|
|
|
|
|
|
|
|
$result = $method->invokeArgs($entity, [$scopes]);
|
|
|
|
|
|
|
|
$this->assertTrue(isset($result['scope1']));
|
|
|
|
$this->assertTrue(isset($result['scope2']));
|
2014-05-02 17:21:53 +01:00
|
|
|
$this->assertTrue($result['scope1'] instanceof ScopeEntity);
|
|
|
|
$this->assertTrue($result['scope2'] instanceof ScopeEntity);
|
2014-01-16 16:51:06 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testGetScopes()
|
|
|
|
{
|
2014-05-02 17:21:53 +01:00
|
|
|
$server = M::mock('League\OAuth2\Server\AuthorizationServer');
|
|
|
|
$server->shouldReceive('setAccessTokenStorage');
|
|
|
|
$server->shouldReceive('setSessionStorage');
|
2014-01-16 16:51:06 +00:00
|
|
|
|
|
|
|
$accessTokenStorage = M::mock('League\OAuth2\Server\Storage\AccessTokenInterface');
|
|
|
|
$accessTokenStorage->shouldReceive('setServer');
|
|
|
|
$server->setAccessTokenStorage($accessTokenStorage);
|
|
|
|
|
2014-05-02 17:21:53 +01:00
|
|
|
$server->shouldReceive('getStorage')->with('access_token')->andReturn($accessTokenStorage);
|
|
|
|
|
2014-01-16 16:51:06 +00:00
|
|
|
$sessionStorage = M::mock('League\OAuth2\Server\Storage\SessionInterface');
|
|
|
|
$sessionStorage->shouldReceive('getScopes')->andReturn(
|
|
|
|
[]
|
|
|
|
);
|
|
|
|
$sessionStorage->shouldReceive('setServer');
|
|
|
|
$server->setSessionStorage($sessionStorage);
|
|
|
|
|
2014-05-02 17:21:53 +01:00
|
|
|
$server->shouldReceive('getStorage')->with('session')->andReturn($sessionStorage);
|
|
|
|
|
|
|
|
$entity = new SessionEntity($server);
|
2014-01-16 16:51:06 +00:00
|
|
|
$this->assertEquals($entity->getScopes(), []);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testHasScopes()
|
|
|
|
{
|
2014-05-02 17:21:53 +01:00
|
|
|
$server = M::mock('League\OAuth2\Server\AuthorizationServer');
|
|
|
|
$server->shouldReceive('setAccessTokenStorage');
|
|
|
|
$server->shouldReceive('setSessionStorage');
|
2014-01-16 16:51:06 +00:00
|
|
|
|
|
|
|
$accessTokenStorage = M::mock('League\OAuth2\Server\Storage\AccessTokenInterface');
|
|
|
|
$accessTokenStorage->shouldReceive('setServer');
|
|
|
|
$server->setAccessTokenStorage($accessTokenStorage);
|
|
|
|
|
2014-05-02 17:21:53 +01:00
|
|
|
$server->shouldReceive('getStorage')->with('access_token')->andReturn($accessTokenStorage);
|
|
|
|
|
2014-01-16 16:51:06 +00:00
|
|
|
$sessionStorage = M::mock('League\OAuth2\Server\Storage\SessionInterface');
|
|
|
|
$sessionStorage->shouldReceive('getScopes')->andReturn(
|
|
|
|
[]
|
|
|
|
);
|
|
|
|
$sessionStorage->shouldReceive('setServer');
|
|
|
|
$server->setSessionStorage($sessionStorage);
|
|
|
|
|
2014-05-02 17:21:53 +01:00
|
|
|
$server->shouldReceive('getStorage')->with('session')->andReturn($sessionStorage);
|
|
|
|
|
|
|
|
$entity = new SessionEntity($server);
|
2014-01-16 16:51:06 +00:00
|
|
|
$this->assertFalse($entity->hasScope('foo'));
|
|
|
|
}
|
|
|
|
|
2014-05-03 10:55:25 +01:00
|
|
|
public function testSave()
|
2014-01-16 16:51:06 +00:00
|
|
|
{
|
2014-05-02 17:21:53 +01:00
|
|
|
$server = M::mock('League\OAuth2\Server\AuthorizationServer');
|
|
|
|
$server->shouldReceive('setSessionStorage');
|
|
|
|
$server->shouldReceive('setClientStorage');
|
2014-01-16 16:51:06 +00:00
|
|
|
|
|
|
|
$sessionStorage = M::mock('League\OAuth2\Server\Storage\SessionInterface');
|
|
|
|
$sessionStorage->shouldReceive('create');
|
|
|
|
$sessionStorage->shouldReceive('associateScope');
|
|
|
|
$sessionStorage->shouldReceive('setServer');
|
|
|
|
$sessionStorage->shouldReceive('getScopes')->andReturn([
|
2014-05-02 17:21:53 +01:00
|
|
|
(new ScopeEntity($server))->setId('foo')
|
2014-01-16 16:51:06 +00:00
|
|
|
]);
|
|
|
|
|
2014-05-02 17:21:53 +01:00
|
|
|
$server->shouldReceive('getStorage')->with('session')->andReturn($sessionStorage);
|
|
|
|
|
2014-01-16 16:51:06 +00:00
|
|
|
$clientStorage = M::mock('League\OAuth2\Server\Storage\ClientInterface');
|
|
|
|
$clientStorage->shouldReceive('getBySession')->andReturn(
|
2014-05-02 17:21:53 +01:00
|
|
|
(new ClientEntity($server))->setId('foo')
|
2014-01-16 16:51:06 +00:00
|
|
|
);
|
|
|
|
$clientStorage->shouldReceive('setServer');
|
|
|
|
|
2014-05-02 17:21:53 +01:00
|
|
|
$server->shouldReceive('getStorage')->with('client')->andReturn($clientStorage);
|
|
|
|
|
2014-01-16 16:51:06 +00:00
|
|
|
$server->setSessionStorage($sessionStorage);
|
|
|
|
$server->setClientStorage($clientStorage);
|
|
|
|
|
2014-05-02 17:21:53 +01:00
|
|
|
$entity = new SessionEntity($server);
|
2014-01-16 16:51:06 +00:00
|
|
|
$this->assertEquals(null, $entity->save());
|
|
|
|
}
|
2014-05-03 10:55:25 +01:00
|
|
|
}
|