oauth2-server/tests/unit/Entity/AuthCodeEntityTest.php

74 lines
2.6 KiB
PHP
Raw Normal View History

<?php
2014-05-02 15:12:15 +01:00
namespace LeagueTests\Entity;
2014-05-02 15:12:15 +01:00
use League\OAuth2\Server\Entity\ScopeEntity;
use League\OAuth2\Server\Entity\SessionEntity;
use League\OAuth2\Server\Entity\AuthCodeEntity;
2014-04-06 19:14:46 +01:00
use League\OAuth2\Server\AuthorizationServer;
use \Mockery as M;
class AuthCodeTest extends \PHPUnit_Framework_TestCase
{
2014-05-03 10:55:25 +01:00
public function testSetGet()
2014-04-06 19:14:46 +01:00
{
2014-05-02 15:12:15 +01:00
$server = M::mock('League\OAuth2\Server\AbstractServer');
2014-04-06 19:14:46 +01:00
2014-05-02 15:12:15 +01:00
$session = M::mock('League\OAuth2\Server\Entity\SessionEntity');
$code = new AuthCodeEntity($server);
2014-04-06 19:14:46 +01:00
$code->setRedirectUri('http://foo/bar');
2014-07-11 18:19:10 +01:00
$code->setId('foobar');
2014-04-06 19:14:46 +01:00
$code->setSession($session);
$this->assertEquals('http://foo/bar', $code->getRedirectUri());
$this->assertEquals('http://foo/bar?code=foobar', $code->generateRedirectUri());
2014-05-02 15:12:15 +01:00
$this->assertTrue($code->getSession() instanceof \League\OAuth2\Server\Entity\SessionEntity);
2014-04-06 19:14:46 +01:00
}
2014-05-03 10:55:25 +01:00
public function testSave()
{
2014-05-02 15:12:15 +01:00
$server = M::mock('League\OAuth2\Server\AbstractServer');
$server->shouldReceive('setAuthCodeStorage');
$server->shouldReceive('setSessionStorage');
$authCodeStorage = M::mock('League\OAuth2\Server\Storage\AuthCodeInterface');
$authCodeStorage->shouldReceive('create');
$authCodeStorage->shouldReceive('associateScope');
$authCodeStorage->shouldReceive('setServer');
$authCodeStorage->shouldReceive('getScopes')->andReturn([
2014-07-11 18:19:10 +01:00
(new ScopeEntity($server))->hydrate(['id' => 'foo'])
]);
$server->shouldReceive('getAuthCodeStorage')->andReturn($authCodeStorage);
2014-05-02 15:12:15 +01:00
$sessionStorage = M::mock('League\OAuth2\Server\Storage\SessionInterface');
$sessionStorage->shouldReceive('getByAuthCode')->andReturn(
2014-05-02 15:12:15 +01:00
(new SessionEntity($server))
);
$sessionStorage->shouldReceive('setServer');
$server->shouldReceive('getSessionStorage')->andReturn($sessionStorage);
2014-05-02 15:12:15 +01:00
$server->setAuthCodeStorage($authCodeStorage);
$server->setSessionStorage($sessionStorage);
2014-05-02 15:12:15 +01:00
$entity = new AuthCodeEntity($server);
$this->assertTrue($entity->save() instanceof AuthCodeEntity);
}
2014-05-03 10:55:25 +01:00
public function testExpire()
{
2014-04-06 19:14:46 +01:00
$server = new AuthorizationServer();
$authCodeStorage = M::mock('League\OAuth2\Server\Storage\AuthCodeInterface');
$authCodeStorage->shouldReceive('delete');
$authCodeStorage->shouldReceive('setServer');
$server->setAuthCodeStorage($authCodeStorage);
2014-05-02 15:12:15 +01:00
$entity = new AuthCodeEntity($server);
$this->assertSame($entity->expire(), null);
}
}