2012-08-23 16:52:39 +05:30
|
|
|
<?php
|
|
|
|
|
2012-08-24 16:53:16 +05:30
|
|
|
class Resource_Server_test extends PHPUnit_Framework_TestCase {
|
2012-08-23 16:52:39 +05:30
|
|
|
|
|
|
|
function setUp()
|
|
|
|
{
|
|
|
|
require_once('database_mock.php');
|
|
|
|
$this->server = new Oauth2\Resource\Server();
|
|
|
|
$this->db = new ResourceDB();
|
|
|
|
|
2012-08-27 19:13:12 +05:30
|
|
|
$this->assertInstanceOf('Oauth2\Resource\Database', $this->db);
|
2012-08-23 16:52:39 +05:30
|
|
|
$this->server->registerDbAbstractor($this->db);
|
|
|
|
}
|
|
|
|
|
|
|
|
function test_init_POST()
|
|
|
|
{
|
2012-08-27 18:53:50 +05:30
|
|
|
$_SERVER['REQUEST_METHOD'] = 'POST';
|
2012-08-23 16:52:39 +05:30
|
|
|
$_POST['oauth_token'] = 'test12345';
|
|
|
|
|
|
|
|
$this->server->init();
|
|
|
|
|
2012-08-27 18:53:50 +05:30
|
|
|
$reflector = new ReflectionClass($this->server);
|
|
|
|
|
|
|
|
$_accessToken = $reflector->getProperty('_accessToken');
|
|
|
|
$_accessToken->setAccessible(true);
|
|
|
|
|
|
|
|
$_type = $reflector->getProperty('_type');
|
|
|
|
$_type->setAccessible(true);
|
|
|
|
|
|
|
|
$_typeId = $reflector->getProperty('_typeId');
|
|
|
|
$_typeId->setAccessible(true);
|
|
|
|
|
|
|
|
$_scopes = $reflector->getProperty('_scopes');
|
|
|
|
$_scopes->setAccessible(true);
|
|
|
|
|
|
|
|
$this->assertEquals($_accessToken->getValue($this->server), $_POST['oauth_token']);
|
|
|
|
$this->assertEquals($_type->getValue($this->server), 'user');
|
|
|
|
$this->assertEquals($_typeId->getValue($this->server), 123);
|
|
|
|
$this->assertEquals($_scopes->getValue($this->server), array('foo', 'bar'));
|
2012-08-23 16:52:39 +05:30
|
|
|
}
|
|
|
|
|
|
|
|
function test_init_GET()
|
|
|
|
{
|
|
|
|
$_GET['oauth_token'] = 'test12345';
|
|
|
|
|
|
|
|
$this->server->init();
|
|
|
|
|
2012-08-27 18:53:50 +05:30
|
|
|
$reflector = new ReflectionClass($this->server);
|
|
|
|
|
|
|
|
$_accessToken = $reflector->getProperty('_accessToken');
|
|
|
|
$_accessToken->setAccessible(true);
|
|
|
|
|
|
|
|
$_type = $reflector->getProperty('_type');
|
|
|
|
$_type->setAccessible(true);
|
|
|
|
|
|
|
|
$_typeId = $reflector->getProperty('_typeId');
|
|
|
|
$_typeId->setAccessible(true);
|
|
|
|
|
|
|
|
$_scopes = $reflector->getProperty('_scopes');
|
|
|
|
$_scopes->setAccessible(true);
|
|
|
|
|
|
|
|
$this->assertEquals($_accessToken->getValue($this->server), $_GET['oauth_token']);
|
|
|
|
$this->assertEquals($_type->getValue($this->server), 'user');
|
|
|
|
$this->assertEquals($_typeId->getValue($this->server), 123);
|
|
|
|
$this->assertEquals($_scopes->getValue($this->server), array('foo', 'bar'));
|
2012-08-23 16:52:39 +05:30
|
|
|
}
|
|
|
|
|
|
|
|
function test_init_header()
|
|
|
|
{
|
|
|
|
// Test with authorisation header
|
2012-08-27 19:02:06 +05:30
|
|
|
$this->markTestIncomplete('Authorisation header test has not been implemented yet.');
|
2012-08-23 16:52:39 +05:30
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2012-08-27 19:55:59 +05:30
|
|
|
* @expectedException \Oauth2\Resource\OAuthResourceServerException
|
|
|
|
* @expectedExceptionMessage An access token was not presented with the request
|
2012-08-23 16:52:39 +05:30
|
|
|
*/
|
2012-08-27 18:53:50 +05:30
|
|
|
function test_init_missingToken()
|
|
|
|
{
|
|
|
|
$this->server->init();
|
|
|
|
}
|
|
|
|
|
2012-08-27 19:55:59 +05:30
|
|
|
/**
|
|
|
|
* @expectedException \Oauth2\Resource\OAuthResourceServerException
|
|
|
|
* @expectedExceptionMessage The access token is not registered with the resource server
|
|
|
|
*/
|
2012-08-23 16:52:39 +05:30
|
|
|
function test_init_wrongToken()
|
|
|
|
{
|
2012-08-27 19:55:59 +05:30
|
|
|
$_POST['oauth_token'] = 'blah';
|
2012-08-27 18:53:50 +05:30
|
|
|
$_SERVER['REQUEST_METHOD'] = 'POST';
|
2012-08-23 16:52:39 +05:30
|
|
|
|
|
|
|
$this->server->init();
|
|
|
|
}
|
|
|
|
|
|
|
|
function test_hasScope()
|
|
|
|
{
|
|
|
|
$_POST['oauth_token'] = 'test12345';
|
2012-08-27 18:53:50 +05:30
|
|
|
$_SERVER['REQUEST_METHOD'] = 'POST';
|
2012-08-23 16:52:39 +05:30
|
|
|
|
|
|
|
$this->server->init();
|
|
|
|
|
|
|
|
$this->assertEquals(true, $this->server->hasScope('foo'));
|
|
|
|
$this->assertEquals(true, $this->server->hasScope('bar'));
|
|
|
|
$this->assertEquals(true, $this->server->hasScope(array('foo', 'bar')));
|
|
|
|
|
|
|
|
$this->assertEquals(false, $this->server->hasScope('foobar'));
|
|
|
|
$this->assertEquals(false, $this->server->hasScope(array('foobar')));
|
|
|
|
}
|
|
|
|
|
|
|
|
function test___call()
|
|
|
|
{
|
|
|
|
$_POST['oauth_token'] = 'test12345';
|
2012-08-27 18:53:50 +05:30
|
|
|
$_SERVER['REQUEST_METHOD'] = 'POST';
|
2012-08-23 16:52:39 +05:30
|
|
|
|
|
|
|
$this->server->init();
|
|
|
|
|
|
|
|
$this->assertEquals(123, $this->server->isUser());
|
|
|
|
$this->assertEquals(false, $this->server->isMachine());
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|