silverstripe-framework/tests/WebserverRoutingTest.php
Sam Minnee 0bb067eddf BUGFIX: Made use of new BasicAuth::protect_entire_site() consistent.
git-svn-id: svn://svn.silverstripe.com/silverstripe/open/modules/sapphire/trunk@91658 467b73ca-7a2a-4603-9d3b-597d59a354a9
2009-11-15 23:43:30 +00:00

47 lines
1.2 KiB
PHP

<?php
/**
* Test that SilverStripe is accessible through the webserver
* by using curl with an actual HTTP request, instead of an in-memory
* test through {@link Director::test()}.
* This can help to uncover e.g. webserver routing problems with .htaccess files.
*
* @todo Exclude this test from a standard test run - not all test environments
* might have a webserver installed, or have it accessible for HTTP requests
* from localhost.
*
* @package sapphire
* @subpackage tests
*/
class WebserverRoutingTest extends SapphireTest {
function testCanAccessWebserverThroughCurl() {
if(!function_exists('curl_init')) return;
$url = Director::absoluteBaseURL() . 'WebserverRoutingTest_Controller/?usetestmanifest=1&flush=1';
$ch = curl_init();
curl_setopt ($ch, CURLOPT_URL,$url );
curl_setopt ($ch, CURLOPT_RETURNTRANSFER, 1);
$response = curl_exec($ch);
$info = curl_getinfo($ch);
$this->assertEquals(curl_error($ch), '');
$this->assertEquals($response, 'ok');
curl_close($ch);
}
}
/**
* @package sapphire
* @subpackage tests
*/
class WebserverRoutingTest_Controller extends Controller {
function index() {
BasicAuth::protect_entire_site(false);
return "ok";
}
}
?>