Knocked out unit tests for the new Router
This commit is contained in:
parent
273af98883
commit
da379d0849
4 changed files with 54 additions and 58 deletions
|
@ -1,63 +1,47 @@
|
|||
<?php
|
||||
|
||||
class RouterTest extends PHPUnit_Framework_TestCase
|
||||
namespace Resources\v1
|
||||
{
|
||||
private $config;
|
||||
|
||||
public function setUp()
|
||||
class resource extends \Pickles\Resource
|
||||
{
|
||||
$this->config = Pickles\Config::getInstance();
|
||||
$this->config->data['pickles']['disabled'] = false;
|
||||
$this->config->data['pickles']['profiler'] = false;
|
||||
|
||||
setUpRequest('home');
|
||||
|
||||
$module = '<?php class home extends Resource { }';
|
||||
|
||||
file_put_contents(SITE_MODULE_PATH . 'home.php', $module);
|
||||
}
|
||||
|
||||
public function testForceSecure()
|
||||
{
|
||||
setUpRequest('secure');
|
||||
|
||||
$module = '<?php class secure extends Resource { public $secure = true; }';
|
||||
|
||||
file_put_contents(SITE_MODULE_PATH . 'secure.php', $module);
|
||||
|
||||
new Pickles\Router();
|
||||
|
||||
$this->assertTrue(in_array('Location: https://testsite.com/secure', xdebug_get_headers()));
|
||||
}
|
||||
|
||||
public function testForceInsecure()
|
||||
{
|
||||
setUpRequest('insecure');
|
||||
$_SERVER['HTTPS'] = 'on';
|
||||
|
||||
$module = '<?php class insecure extends Resource { public $secure = false; }';
|
||||
|
||||
file_put_contents(SITE_MODULE_PATH . 'insecure.php', $module);
|
||||
|
||||
new Pickles\Router();
|
||||
|
||||
$this->assertTrue(in_array('Location: http://testsite.com/insecure', xdebug_get_headers()));
|
||||
}
|
||||
|
||||
public function testValidationErrors()
|
||||
{
|
||||
setUpRequest('validationerrors');
|
||||
|
||||
$module = '<?php class validationerrors extends Resource { '
|
||||
. 'public $validate = ["test"];'
|
||||
. 'public function __default() { return ["foo" => "bar"]; }'
|
||||
. '}';
|
||||
|
||||
file_put_contents(SITE_MODULE_PATH . 'validationerrors.php', $module);
|
||||
|
||||
new Pickles\Router();
|
||||
|
||||
$this->expectOutputString('{"status":"error","message":"The test field is required."}');
|
||||
}
|
||||
}
|
||||
|
||||
namespace
|
||||
{
|
||||
class RouterTest extends PHPUnit_Framework_TestCase
|
||||
{
|
||||
public function testServerError()
|
||||
{
|
||||
$this->expectOutputRegex('/{"status":500,"message":"Undefined index: request"}/');
|
||||
|
||||
$_SERVER['REQUEST_METHOD'] = 'GET';
|
||||
|
||||
new Pickles\Router();
|
||||
}
|
||||
|
||||
public function testNotFound()
|
||||
{
|
||||
$this->expectOutputRegex('/{"status":404,"message":"Not Found."}/');
|
||||
|
||||
$_SERVER['REQUEST_METHOD'] = 'GET';
|
||||
$_REQUEST['request'] = 'v1/test';
|
||||
|
||||
new Pickles\Router();
|
||||
}
|
||||
|
||||
// We're just testing that the class can be loaded, not that it will
|
||||
// work. That logic is off in ResourceTest
|
||||
public function testFound()
|
||||
{
|
||||
$this->expectOutputRegex('/{"status":405,"message":"Method not allowed."}/');
|
||||
|
||||
$_SERVER['REQUEST_METHOD'] = 'GET';
|
||||
$_REQUEST['request'] = 'v1/resource/1';
|
||||
|
||||
new Pickles\Router();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue