oauth2-server/tests/resource/server_test.php

124 lines
3.8 KiB
PHP
Raw Normal View History

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