mirror of
https://github.com/kamilwylegala/cakephp2-php8.git
synced 2025-01-19 02:56:15 +00:00
Starting to move additional methods from Dispatcher into CakeRequest. Tests have been moved, and updated.
This commit is contained in:
parent
51db3c80ef
commit
85b86164e3
3 changed files with 455 additions and 27 deletions
|
@ -51,6 +51,20 @@ class CakeRequest implements ArrayAccess {
|
||||||
*/
|
*/
|
||||||
public $url;
|
public $url;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Base url path.
|
||||||
|
*
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
public $base = false;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* webroot directory for the request.
|
||||||
|
*
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
public $webroot = '/';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The built in detectors used with `is()` can be modified with `addDetector()`.
|
* The built in detectors used with `is()` can be modified with `addDetector()`.
|
||||||
*
|
*
|
||||||
|
@ -78,9 +92,16 @@ class CakeRequest implements ArrayAccess {
|
||||||
/**
|
/**
|
||||||
* Constructor
|
* Constructor
|
||||||
*
|
*
|
||||||
|
* @param string $url Url string to use
|
||||||
|
* @param array $additionalParams Additional parameters that are melded with other request parameters
|
||||||
* @return void
|
* @return void
|
||||||
*/
|
*/
|
||||||
public function __construct() {
|
public function __construct($url = null, $additionalParams = array()) {
|
||||||
|
$this->base = $this->baseUrl();
|
||||||
|
if (empty($url)) {
|
||||||
|
$url = $this->getUrl();
|
||||||
|
}
|
||||||
|
$this->url = $url;
|
||||||
if (isset($_POST)) {
|
if (isset($_POST)) {
|
||||||
$this->_processPost();
|
$this->_processPost();
|
||||||
}
|
}
|
||||||
|
@ -88,6 +109,10 @@ class CakeRequest implements ArrayAccess {
|
||||||
$this->_processGet();
|
$this->_processGet();
|
||||||
}
|
}
|
||||||
$this->_processFiles();
|
$this->_processFiles();
|
||||||
|
|
||||||
|
if (!empty($additionalParams)) {
|
||||||
|
$this->params = array_merge($this->params, $additionalParams);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -132,9 +157,156 @@ class CakeRequest implements ArrayAccess {
|
||||||
$url = array_merge($this->params['url'], $url);
|
$url = array_merge($this->params['url'], $url);
|
||||||
}
|
}
|
||||||
$this->query = $url;
|
$this->query = $url;
|
||||||
if (isset($this->query['url'])) {
|
|
||||||
$this->url = $this->query['url'];
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the REQUEST_URI from the server environment, or, failing that,
|
||||||
|
* constructs a new one, using the PHP_SELF constant and other variables.
|
||||||
|
*
|
||||||
|
* @return string URI
|
||||||
|
*/
|
||||||
|
public function uri() {
|
||||||
|
foreach (array('HTTP_X_REWRITE_URL', 'REQUEST_URI', 'argv') as $var) {
|
||||||
|
if ($uri = env($var)) {
|
||||||
|
if ($var == 'argv') {
|
||||||
|
$uri = $uri[0];
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
$base = preg_replace('/^\//', '', '' . Configure::read('App.baseUrl'));
|
||||||
|
|
||||||
|
if ($base) {
|
||||||
|
$uri = preg_replace('/^(?:\/)?(?:' . preg_quote($base, '/') . ')?(?:url=)?/', '', $uri);
|
||||||
|
}
|
||||||
|
if (PHP_SAPI == 'isapi') {
|
||||||
|
$uri = preg_replace('/^(?:\/)?(?:\/)?(?:\?)?(?:url=)?/', '', $uri);
|
||||||
|
}
|
||||||
|
if (!empty($uri)) {
|
||||||
|
if (key($_GET) && strpos(key($_GET), '?') !== false) {
|
||||||
|
unset($_GET[key($_GET)]);
|
||||||
|
}
|
||||||
|
$uri = explode('?', $uri, 2);
|
||||||
|
|
||||||
|
if (isset($uri[1])) {
|
||||||
|
parse_str($uri[1], $_GET);
|
||||||
|
}
|
||||||
|
$uri = $uri[0];
|
||||||
|
} else {
|
||||||
|
$uri = env('QUERY_STRING');
|
||||||
|
}
|
||||||
|
if (is_string($uri) && strpos($uri, 'index.php') !== false) {
|
||||||
|
list(, $uri) = explode('index.php', $uri, 2);
|
||||||
|
}
|
||||||
|
if (empty($uri) || $uri == '/' || $uri == '//') {
|
||||||
|
return '';
|
||||||
|
}
|
||||||
|
return str_replace('//', '/', '/' . $uri);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns and sets the $_GET[url] derived from the REQUEST_URI
|
||||||
|
*
|
||||||
|
* @param string $uri Request URI
|
||||||
|
* @param string $base Base path
|
||||||
|
* @return string URL
|
||||||
|
*/
|
||||||
|
public function getUrl($uri = null, $base = null) {
|
||||||
|
if (empty($_GET['url'])) {
|
||||||
|
if ($uri == null) {
|
||||||
|
$uri = $this->uri();
|
||||||
|
}
|
||||||
|
if ($base == null) {
|
||||||
|
$base = $this->base;
|
||||||
|
}
|
||||||
|
$url = null;
|
||||||
|
$tmpUri = preg_replace('/^(?:\?)?(?:\/)?/', '', $uri);
|
||||||
|
$baseDir = preg_replace('/^\//', '', dirname($base)) . '/';
|
||||||
|
|
||||||
|
if ($tmpUri === '/' || $tmpUri == $baseDir || $tmpUri == $base) {
|
||||||
|
$url = '/';
|
||||||
|
} else {
|
||||||
|
if ($base && strpos($uri, $base) !== false) {
|
||||||
|
$elements = explode($base, $uri);
|
||||||
|
} elseif (preg_match('/^[\/\?\/|\/\?|\?\/]/', $uri)) {
|
||||||
|
$elements = array(1 => preg_replace('/^[\/\?\/|\/\?|\?\/]/', '', $uri));
|
||||||
|
} else {
|
||||||
|
$elements = array();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!empty($elements[1])) {
|
||||||
|
$url = $elements[1];
|
||||||
|
} else {
|
||||||
|
$url = '/';
|
||||||
|
}
|
||||||
|
|
||||||
|
if (strpos($url, '/') === 0 && $url != '/') {
|
||||||
|
$url = substr($url, 1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
$url = $_GET['url'];
|
||||||
|
}
|
||||||
|
if ($url{0} == '/') {
|
||||||
|
$url = substr($url, 1);
|
||||||
|
}
|
||||||
|
return $url;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a base URL and sets the proper webroot
|
||||||
|
*
|
||||||
|
* @return string Base URL
|
||||||
|
*/
|
||||||
|
public function baseUrl() {
|
||||||
|
$dir = $webroot = null;
|
||||||
|
$config = Configure::read('App');
|
||||||
|
extract($config);
|
||||||
|
|
||||||
|
if (!$base) {
|
||||||
|
$base = $this->base;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($base !== false) {
|
||||||
|
$this->webroot = $base . '/';
|
||||||
|
return $this->base = $base;
|
||||||
|
}
|
||||||
|
if (!$baseUrl) {
|
||||||
|
$replace = array('<', '>', '*', '\'', '"');
|
||||||
|
$base = str_replace($replace, '', dirname(env('PHP_SELF')));
|
||||||
|
|
||||||
|
if ($webroot === 'webroot' && $webroot === basename($base)) {
|
||||||
|
$base = dirname($base);
|
||||||
|
}
|
||||||
|
if ($dir === 'app' && $dir === basename($base)) {
|
||||||
|
$base = dirname($base);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($base === DS || $base === '.') {
|
||||||
|
$base = '';
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->webroot = $base .'/';
|
||||||
|
return $base;
|
||||||
|
}
|
||||||
|
|
||||||
|
$file = '/' . basename($baseUrl);
|
||||||
|
$base = dirname($baseUrl);
|
||||||
|
|
||||||
|
if ($base === DS || $base === '.') {
|
||||||
|
$base = '';
|
||||||
|
}
|
||||||
|
$this->webroot = $base .'/';
|
||||||
|
|
||||||
|
if (!empty($base)) {
|
||||||
|
if (strpos($this->webroot, $dir) === false) {
|
||||||
|
$this->webroot .= $dir . '/' ;
|
||||||
|
}
|
||||||
|
if (strpos($this->webroot, $webroot) === false) {
|
||||||
|
$this->webroot .= $webroot . '/';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return $base . $file;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -697,6 +697,7 @@ class DispatcherTest extends CakeTestCase {
|
||||||
/**
|
/**
|
||||||
* testFileUploadArrayStructure method
|
* testFileUploadArrayStructure method
|
||||||
*
|
*
|
||||||
|
* @todo moved to CakeRequest. Remove when refactored.
|
||||||
* @return void
|
* @return void
|
||||||
*/
|
*/
|
||||||
public function testFileUploadArrayStructure() {
|
public function testFileUploadArrayStructure() {
|
||||||
|
@ -949,6 +950,7 @@ class DispatcherTest extends CakeTestCase {
|
||||||
/**
|
/**
|
||||||
* testGetUrl method
|
* testGetUrl method
|
||||||
*
|
*
|
||||||
|
* @todo moved to CakeRequest. Remove when refactored.
|
||||||
* @return void
|
* @return void
|
||||||
*/
|
*/
|
||||||
public function testGetUrl() {
|
public function testGetUrl() {
|
||||||
|
@ -988,6 +990,7 @@ class DispatcherTest extends CakeTestCase {
|
||||||
/**
|
/**
|
||||||
* testBaseUrlAndWebrootWithModRewrite method
|
* testBaseUrlAndWebrootWithModRewrite method
|
||||||
*
|
*
|
||||||
|
* @todo moved to CakeRequest. Remove when refactored.
|
||||||
* @return void
|
* @return void
|
||||||
*/
|
*/
|
||||||
public function testBaseUrlAndWebrootWithModRewrite() {
|
public function testBaseUrlAndWebrootWithModRewrite() {
|
||||||
|
@ -1063,6 +1066,7 @@ class DispatcherTest extends CakeTestCase {
|
||||||
/**
|
/**
|
||||||
* testBaseUrlwithModRewriteAlias method
|
* testBaseUrlwithModRewriteAlias method
|
||||||
*
|
*
|
||||||
|
* @todo moved to CakeRequest. Remove when refactored.
|
||||||
* @return void
|
* @return void
|
||||||
*/
|
*/
|
||||||
public function testBaseUrlwithModRewriteAlias() {
|
public function testBaseUrlwithModRewriteAlias() {
|
||||||
|
@ -1097,6 +1101,7 @@ class DispatcherTest extends CakeTestCase {
|
||||||
/**
|
/**
|
||||||
* testBaseUrlAndWebrootWithBaseUrl method
|
* testBaseUrlAndWebrootWithBaseUrl method
|
||||||
*
|
*
|
||||||
|
* @todo moved to CakeRequest. Remove when refactored.
|
||||||
* @return void
|
* @return void
|
||||||
*/
|
*/
|
||||||
public function testBaseUrlAndWebrootWithBaseUrl() {
|
public function testBaseUrlAndWebrootWithBaseUrl() {
|
||||||
|
@ -1166,6 +1171,7 @@ class DispatcherTest extends CakeTestCase {
|
||||||
/**
|
/**
|
||||||
* testBaseUrlAndWebrootWithBase method
|
* testBaseUrlAndWebrootWithBase method
|
||||||
*
|
*
|
||||||
|
* @todo moved to CakeRequest. Remove when refactored.
|
||||||
* @return void
|
* @return void
|
||||||
*/
|
*/
|
||||||
public function testBaseUrlAndWebrootWithBase() {
|
public function testBaseUrlAndWebrootWithBase() {
|
||||||
|
|
|
@ -37,7 +37,7 @@ class CakeRequestTestCase extends CakeTestCase {
|
||||||
'one' => 'param',
|
'one' => 'param',
|
||||||
'two' => 'banana'
|
'two' => 'banana'
|
||||||
);
|
);
|
||||||
$request = new CakeRequest();
|
$request = new CakeRequest('some/path');
|
||||||
$this->assertEqual($request->query, $_GET);
|
$this->assertEqual($request->query, $_GET);
|
||||||
|
|
||||||
$_GET = array(
|
$_GET = array(
|
||||||
|
@ -45,10 +45,9 @@ class CakeRequestTestCase extends CakeTestCase {
|
||||||
'two' => 'banana',
|
'two' => 'banana',
|
||||||
'url' => '/some/path/here'
|
'url' => '/some/path/here'
|
||||||
);
|
);
|
||||||
$request = new CakeRequest();
|
$request = new CakeRequest('some/path');
|
||||||
$this->assertEqual($request->query, $_GET);
|
$this->assertEqual($request->query, $_GET);
|
||||||
$this->assertEqual($request->url, $_GET['url']);
|
$this->assertEqual($request->url, 'some/path');
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -60,11 +59,11 @@ class CakeRequestTestCase extends CakeTestCase {
|
||||||
$_POST = array('data' => array(
|
$_POST = array('data' => array(
|
||||||
'Article' => array('title')
|
'Article' => array('title')
|
||||||
));
|
));
|
||||||
$request = new CakeRequest();
|
$request = new CakeRequest('some/path');
|
||||||
$this->assertEqual($request->data, $_POST['data']);
|
$this->assertEqual($request->data, $_POST['data']);
|
||||||
|
|
||||||
$_POST = array('one' => 1, 'two' => 'three');
|
$_POST = array('one' => 1, 'two' => 'three');
|
||||||
$request = new CakeRequest();
|
$request = new CakeRequest('some/path');
|
||||||
$this->assertEqual($request->params['form'], $_POST);
|
$this->assertEqual($request->params['form'], $_POST);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -121,7 +120,7 @@ class CakeRequestTestCase extends CakeTestCase {
|
||||||
),
|
),
|
||||||
));
|
));
|
||||||
|
|
||||||
$request = new CakeRequest();
|
$request = new CakeRequest('some/path');
|
||||||
$expected = array(
|
$expected = array(
|
||||||
'File' => array(
|
'File' => array(
|
||||||
array('data' => array(
|
array('data' => array(
|
||||||
|
@ -239,7 +238,7 @@ class CakeRequestTestCase extends CakeTestCase {
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
|
||||||
$request = new CakeRequest();
|
$request = new CakeRequest('some/path');
|
||||||
$expected = array(
|
$expected = array(
|
||||||
'Document' => array(
|
'Document' => array(
|
||||||
1 => array(
|
1 => array(
|
||||||
|
@ -303,7 +302,7 @@ class CakeRequestTestCase extends CakeTestCase {
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
|
||||||
$request = new CakeRequest();
|
$request = new CakeRequest('some/path');
|
||||||
$expected = array(
|
$expected = array(
|
||||||
'birth_cert' => array(
|
'birth_cert' => array(
|
||||||
'name' => 'born on.txt',
|
'name' => 'born on.txt',
|
||||||
|
@ -324,7 +323,7 @@ class CakeRequestTestCase extends CakeTestCase {
|
||||||
'size' => 123
|
'size' => 123
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
$request = new CakeRequest();
|
$request = new CakeRequest('some/path');
|
||||||
$this->assertEqual($request->params['form'], $_FILES);
|
$this->assertEqual($request->params['form'], $_FILES);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -336,15 +335,15 @@ class CakeRequestTestCase extends CakeTestCase {
|
||||||
*/
|
*/
|
||||||
function testMethodOverrides() {
|
function testMethodOverrides() {
|
||||||
$_POST = array('_method' => 'POST');
|
$_POST = array('_method' => 'POST');
|
||||||
$request = new CakeRequest();
|
$request = new CakeRequest('some/path');
|
||||||
$this->assertEqual(env('REQUEST_METHOD'), 'POST');
|
$this->assertEqual(env('REQUEST_METHOD'), 'POST');
|
||||||
|
|
||||||
$_POST = array('_method' => 'DELETE');
|
$_POST = array('_method' => 'DELETE');
|
||||||
$request = new CakeRequest();
|
$request = new CakeRequest('some/path');
|
||||||
$this->assertEqual(env('REQUEST_METHOD'), 'DELETE');
|
$this->assertEqual(env('REQUEST_METHOD'), 'DELETE');
|
||||||
|
|
||||||
$_SERVER['HTTP_X_HTTP_METHOD_OVERRIDE'] = 'PUT';
|
$_SERVER['HTTP_X_HTTP_METHOD_OVERRIDE'] = 'PUT';
|
||||||
$request = new CakeRequest();
|
$request = new CakeRequest('some/path');
|
||||||
$this->assertEqual(env('REQUEST_METHOD'), 'PUT');
|
$this->assertEqual(env('REQUEST_METHOD'), 'PUT');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -357,7 +356,7 @@ class CakeRequestTestCase extends CakeTestCase {
|
||||||
$_SERVER['HTTP_X_FORWARDED_FOR'] = '192.168.1.5, 10.0.1.1, proxy.com';
|
$_SERVER['HTTP_X_FORWARDED_FOR'] = '192.168.1.5, 10.0.1.1, proxy.com';
|
||||||
$_SERVER['HTTP_CLIENT_IP'] = '192.168.1.2';
|
$_SERVER['HTTP_CLIENT_IP'] = '192.168.1.2';
|
||||||
$_SERVER['REMOTE_ADDR'] = '192.168.1.3';
|
$_SERVER['REMOTE_ADDR'] = '192.168.1.3';
|
||||||
$request = new CakeRequest();
|
$request = new CakeRequest('some/path');
|
||||||
$this->assertEqual($request->getClientIP(false), '192.168.1.5');
|
$this->assertEqual($request->getClientIP(false), '192.168.1.5');
|
||||||
$this->assertEqual($request->getClientIP(), '192.168.1.2');
|
$this->assertEqual($request->getClientIP(), '192.168.1.2');
|
||||||
|
|
||||||
|
@ -377,7 +376,7 @@ class CakeRequestTestCase extends CakeTestCase {
|
||||||
* @return void
|
* @return void
|
||||||
*/
|
*/
|
||||||
function testReferer() {
|
function testReferer() {
|
||||||
$request = new CakeRequest();
|
$request = new CakeRequest('some/path');
|
||||||
|
|
||||||
$_SERVER['HTTP_REFERER'] = 'http://cakephp.org';
|
$_SERVER['HTTP_REFERER'] = 'http://cakephp.org';
|
||||||
$result = $request->referer();
|
$result = $request->referer();
|
||||||
|
@ -387,13 +386,13 @@ class CakeRequestTestCase extends CakeTestCase {
|
||||||
$result = $request->referer();
|
$result = $request->referer();
|
||||||
$this->assertIdentical($result, '/');
|
$this->assertIdentical($result, '/');
|
||||||
|
|
||||||
$_SERVER['HTTP_REFERER'] = FULL_BASE_URL . '/some/path';
|
$_SERVER['HTTP_REFERER'] = FULL_BASE_URL . 'some/path';
|
||||||
$result = $request->referer(true);
|
$result = $request->referer(true);
|
||||||
$this->assertIdentical($result, '/some/path');
|
$this->assertIdentical($result, '/some/path');
|
||||||
|
|
||||||
$_SERVER['HTTP_REFERER'] = FULL_BASE_URL . '/some/path';
|
$_SERVER['HTTP_REFERER'] = FULL_BASE_URL . 'some/path';
|
||||||
$result = $request->referer();
|
$result = $request->referer();
|
||||||
$this->assertIdentical($result, FULL_BASE_URL . '/some/path');
|
$this->assertIdentical($result, FULL_BASE_URL . 'some/path');
|
||||||
|
|
||||||
$_SERVER['HTTP_REFERER'] = FULL_BASE_URL . 'some/path';
|
$_SERVER['HTTP_REFERER'] = FULL_BASE_URL . 'some/path';
|
||||||
$result = $request->referer(true);
|
$result = $request->referer(true);
|
||||||
|
@ -410,7 +409,7 @@ class CakeRequestTestCase extends CakeTestCase {
|
||||||
* @return void
|
* @return void
|
||||||
*/
|
*/
|
||||||
function testIsHttpMethods() {
|
function testIsHttpMethods() {
|
||||||
$request = new CakeRequest();
|
$request = new CakeRequest('some/path');
|
||||||
|
|
||||||
$this->assertFalse($request->is('undefined-behavior'));
|
$this->assertFalse($request->is('undefined-behavior'));
|
||||||
|
|
||||||
|
@ -438,7 +437,7 @@ class CakeRequestTestCase extends CakeTestCase {
|
||||||
* @return void
|
* @return void
|
||||||
*/
|
*/
|
||||||
function testisAjaxFlashAndFriends() {
|
function testisAjaxFlashAndFriends() {
|
||||||
$request = new CakeRequest();
|
$request = new CakeRequest('some/path');
|
||||||
|
|
||||||
$_SERVER['HTTP_USER_AGENT'] = 'Shockwave Flash';
|
$_SERVER['HTTP_USER_AGENT'] = 'Shockwave Flash';
|
||||||
$this->assertTrue($request->is('flash'));
|
$this->assertTrue($request->is('flash'));
|
||||||
|
@ -464,7 +463,7 @@ class CakeRequestTestCase extends CakeTestCase {
|
||||||
* @return void
|
* @return void
|
||||||
*/
|
*/
|
||||||
function testIsSsl() {
|
function testIsSsl() {
|
||||||
$request = new CakeRequest();
|
$request = new CakeRequest('some/path');
|
||||||
|
|
||||||
$_SERVER['HTTPS'] = 1;
|
$_SERVER['HTTPS'] = 1;
|
||||||
$this->assertTrue($request->is('ssl'));
|
$this->assertTrue($request->is('ssl'));
|
||||||
|
@ -497,7 +496,7 @@ class CakeRequestTestCase extends CakeTestCase {
|
||||||
* @return void
|
* @return void
|
||||||
*/
|
*/
|
||||||
function test__get() {
|
function test__get() {
|
||||||
$request = new CakeRequest();
|
$request = new CakeRequest('some/path');
|
||||||
$request->params = array('controller' => 'posts', 'action' => 'view', 'plugin' => 'blogs');
|
$request->params = array('controller' => 'posts', 'action' => 'view', 'plugin' => 'blogs');
|
||||||
|
|
||||||
$this->assertEqual($request->controller, 'posts');
|
$this->assertEqual($request->controller, 'posts');
|
||||||
|
@ -512,7 +511,7 @@ class CakeRequestTestCase extends CakeTestCase {
|
||||||
* @return void
|
* @return void
|
||||||
*/
|
*/
|
||||||
function testArrayAccess() {
|
function testArrayAccess() {
|
||||||
$request = new CakeRequest();
|
$request = new CakeRequest('some/path');
|
||||||
$request->params = array('controller' => 'posts', 'action' => 'view', 'plugin' => 'blogs');
|
$request->params = array('controller' => 'posts', 'action' => 'view', 'plugin' => 'blogs');
|
||||||
|
|
||||||
$this->assertEqual($request['controller'], 'posts');
|
$this->assertEqual($request['controller'], 'posts');
|
||||||
|
@ -537,7 +536,7 @@ class CakeRequestTestCase extends CakeTestCase {
|
||||||
* @return void
|
* @return void
|
||||||
*/
|
*/
|
||||||
function testAddDetector() {
|
function testAddDetector() {
|
||||||
$request = new CakeRequest();
|
$request = new CakeRequest('some/path');
|
||||||
$request->addDetector('compare', array('env' => 'TEST_VAR', 'value' => 'something'));
|
$request->addDetector('compare', array('env' => 'TEST_VAR', 'value' => 'something'));
|
||||||
|
|
||||||
$_SERVER['TEST_VAR'] = 'something';
|
$_SERVER['TEST_VAR'] = 'something';
|
||||||
|
@ -577,4 +576,255 @@ class CakeRequestTestCase extends CakeTestCase {
|
||||||
function _detectCallback($request) {
|
function _detectCallback($request) {
|
||||||
return $request->return == true;
|
return $request->return == true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* testGetUrl method
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function testGetUrl() {
|
||||||
|
$request = new CakeRequest();
|
||||||
|
$request->base = '/app/webroot/index.php';
|
||||||
|
$uri = '/app/webroot/index.php/posts/add';
|
||||||
|
unset($_GET['url']);
|
||||||
|
|
||||||
|
$result = $request->getUrl($uri);
|
||||||
|
$expected = 'posts/add';
|
||||||
|
$this->assertEqual($expected, $result);
|
||||||
|
|
||||||
|
Configure::write('App.baseUrl', '/app/webroot/index.php');
|
||||||
|
|
||||||
|
$uri = '/posts/add';
|
||||||
|
$result = $request->getUrl($uri);
|
||||||
|
$expected = 'posts/add';
|
||||||
|
$this->assertEqual($expected, $result);
|
||||||
|
|
||||||
|
$_GET['url'] = array();
|
||||||
|
Configure::write('App.base', '/control');
|
||||||
|
$request = new CakeRequest();
|
||||||
|
unset($_GET['url']);
|
||||||
|
|
||||||
|
$request->baseUrl();
|
||||||
|
$uri = '/control/students/browse';
|
||||||
|
$result = $request->getUrl($uri);
|
||||||
|
$expected = 'students/browse';
|
||||||
|
$this->assertEqual($expected, $result);
|
||||||
|
|
||||||
|
$request = new CakeRequest();
|
||||||
|
$_GET['url'] = array();
|
||||||
|
|
||||||
|
$request->base = '';
|
||||||
|
$uri = '/?/home';
|
||||||
|
$result = $request->getUrl($uri);
|
||||||
|
$expected = '?/home';
|
||||||
|
$this->assertEqual($expected, $result);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* testBaseUrlAndWebrootWithModRewrite method
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function testBaseUrlAndWebrootWithModRewrite() {
|
||||||
|
$request = new CakeRequest();
|
||||||
|
|
||||||
|
$request->base = false;
|
||||||
|
$_SERVER['DOCUMENT_ROOT'] = '/cake/repo/branches';
|
||||||
|
$_SERVER['SCRIPT_FILENAME'] = '/cake/repo/branches/1.2.x.x/app/webroot/index.php';
|
||||||
|
$_SERVER['PHP_SELF'] = '/1.2.x.x/app/webroot/index.php';
|
||||||
|
$result = $request->baseUrl();
|
||||||
|
$expected = '/1.2.x.x';
|
||||||
|
$this->assertEqual($expected, $result);
|
||||||
|
$expectedWebroot = '/1.2.x.x/';
|
||||||
|
$this->assertEqual($expectedWebroot, $request->webroot);
|
||||||
|
|
||||||
|
$request->base = false;
|
||||||
|
$_SERVER['DOCUMENT_ROOT'] = '/cake/repo/branches/1.2.x.x/app/webroot';
|
||||||
|
$_SERVER['SCRIPT_FILENAME'] = '/cake/repo/branches/1.2.x.x/app/webroot/index.php';
|
||||||
|
$_SERVER['PHP_SELF'] = '/index.php';
|
||||||
|
$result = $request->baseUrl();
|
||||||
|
$expected = '';
|
||||||
|
$this->assertEqual($expected, $result);
|
||||||
|
$expectedWebroot = '/';
|
||||||
|
$this->assertEqual($expectedWebroot, $request->webroot);
|
||||||
|
|
||||||
|
$request->base = false;
|
||||||
|
$_SERVER['DOCUMENT_ROOT'] = '/cake/repo/branches/1.2.x.x/test/';
|
||||||
|
$_SERVER['SCRIPT_FILENAME'] = '/cake/repo/branches/1.2.x.x/test/webroot/index.php';
|
||||||
|
$_SERVER['PHP_SELF'] = '/webroot/index.php';
|
||||||
|
$result = $request->baseUrl();
|
||||||
|
$expected = '';
|
||||||
|
$this->assertEqual($expected, $result);
|
||||||
|
$expectedWebroot = '/';
|
||||||
|
$this->assertEqual($expectedWebroot, $request->webroot);
|
||||||
|
|
||||||
|
$request->base = false;
|
||||||
|
$_SERVER['DOCUMENT_ROOT'] = '/some/apps/where';
|
||||||
|
$_SERVER['SCRIPT_FILENAME'] = '/some/apps/where/app/webroot/index.php';
|
||||||
|
$_SERVER['PHP_SELF'] = '/some/apps/where/app/webroot/index.php';
|
||||||
|
$result = $request->baseUrl();
|
||||||
|
$expected = '/some/apps/where';
|
||||||
|
$this->assertEqual($expected, $result);
|
||||||
|
$expectedWebroot = '/some/apps/where/';
|
||||||
|
$this->assertEqual($expectedWebroot, $request->webroot);
|
||||||
|
|
||||||
|
|
||||||
|
Configure::write('App.dir', 'auth');
|
||||||
|
|
||||||
|
$request->base = false;
|
||||||
|
$_SERVER['DOCUMENT_ROOT'] = '/cake/repo/branches';
|
||||||
|
$_SERVER['SCRIPT_FILENAME'] = '/cake/repo/branches/demos/auth/webroot/index.php';
|
||||||
|
$_SERVER['PHP_SELF'] = '/demos/auth/webroot/index.php';
|
||||||
|
|
||||||
|
$result = $request->baseUrl();
|
||||||
|
$expected = '/demos/auth';
|
||||||
|
$this->assertEqual($expected, $result);
|
||||||
|
$expectedWebroot = '/demos/auth/';
|
||||||
|
$this->assertEqual($expectedWebroot, $request->webroot);
|
||||||
|
|
||||||
|
Configure::write('App.dir', 'code');
|
||||||
|
|
||||||
|
$request->base = false;
|
||||||
|
$_SERVER['DOCUMENT_ROOT'] = '/Library/WebServer/Documents';
|
||||||
|
$_SERVER['SCRIPT_FILENAME'] = '/Library/WebServer/Documents/clients/PewterReport/code/webroot/index.php';
|
||||||
|
$_SERVER['PHP_SELF'] = '/clients/PewterReport/code/webroot/index.php';
|
||||||
|
$result = $request->baseUrl();
|
||||||
|
$expected = '/clients/PewterReport/code';
|
||||||
|
$this->assertEqual($expected, $result);
|
||||||
|
$expectedWebroot = '/clients/PewterReport/code/';
|
||||||
|
$this->assertEqual($expectedWebroot, $request->webroot);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* testBaseUrlwithModRewriteAlias method
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function testBaseUrlwithModRewriteAlias() {
|
||||||
|
$_SERVER['DOCUMENT_ROOT'] = '/home/aplusnur/public_html';
|
||||||
|
$_SERVER['SCRIPT_FILENAME'] = '/home/aplusnur/cake2/app/webroot/index.php';
|
||||||
|
$_SERVER['PHP_SELF'] = '/control/index.php';
|
||||||
|
|
||||||
|
Configure::write('App.base', '/control');
|
||||||
|
|
||||||
|
$request = new CakeRequest();
|
||||||
|
$result = $request->baseUrl();
|
||||||
|
$expected = '/control';
|
||||||
|
$this->assertEqual($expected, $result);
|
||||||
|
$expectedWebroot = '/control/';
|
||||||
|
$this->assertEqual($expectedWebroot, $request->webroot);
|
||||||
|
|
||||||
|
Configure::write('App.base', false);
|
||||||
|
Configure::write('App.dir', 'affiliate');
|
||||||
|
Configure::write('App.webroot', 'newaffiliate');
|
||||||
|
|
||||||
|
$_SERVER['DOCUMENT_ROOT'] = '/var/www/abtravaff/html';
|
||||||
|
$_SERVER['SCRIPT_FILENAME'] = '/var/www/abtravaff/html/newaffiliate/index.php';
|
||||||
|
$_SERVER['PHP_SELF'] = '/newaffiliate/index.php';
|
||||||
|
$request = new CakeRequest();
|
||||||
|
$result = $request->baseUrl();
|
||||||
|
$expected = '/newaffiliate';
|
||||||
|
$this->assertEqual($expected, $result);
|
||||||
|
$expectedWebroot = '/newaffiliate/';
|
||||||
|
$this->assertEqual($expectedWebroot, $request->webroot);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* testBaseUrlAndWebrootWithBaseUrl method
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function testBaseUrlAndWebrootWithBaseUrl() {
|
||||||
|
Configure::write('App.dir', 'app');
|
||||||
|
Configure::write('App.baseUrl', '/app/webroot/index.php');
|
||||||
|
|
||||||
|
$request = new CakeRequest();
|
||||||
|
$expected = '/app/webroot/index.php';
|
||||||
|
$this->assertEqual($request->base, $expected);
|
||||||
|
$expectedWebroot = '/app/webroot/';
|
||||||
|
$this->assertEqual($request->webroot, $expectedWebroot);
|
||||||
|
|
||||||
|
Configure::write('App.baseUrl', '/app/webroot/test.php');
|
||||||
|
$request = new CakeRequest();
|
||||||
|
$expected = '/app/webroot/test.php';
|
||||||
|
$this->assertEqual($request->base, $expected);
|
||||||
|
$expectedWebroot = '/app/webroot/';
|
||||||
|
$this->assertEqual($request->webroot, $expectedWebroot);
|
||||||
|
|
||||||
|
Configure::write('App.baseUrl', '/app/index.php');
|
||||||
|
$request = new CakeRequest();
|
||||||
|
$expected = '/app/index.php';
|
||||||
|
$this->assertEqual($request->base, $expected);
|
||||||
|
$expectedWebroot = '/app/webroot/';
|
||||||
|
$this->assertEqual($request->webroot, $expectedWebroot);
|
||||||
|
|
||||||
|
Configure::write('App.baseUrl', '/index.php');
|
||||||
|
$request = new CakeRequest();
|
||||||
|
$expected = '/index.php';
|
||||||
|
$this->assertEqual($request->base, $expected);
|
||||||
|
$expectedWebroot = '/';
|
||||||
|
$this->assertEqual($expectedWebroot, $request->webroot);
|
||||||
|
|
||||||
|
Configure::write('App.baseUrl', '/CakeBB/app/webroot/index.php');
|
||||||
|
$request = new CakeRequest();
|
||||||
|
$expected = '/CakeBB/app/webroot/index.php';
|
||||||
|
$this->assertEqual($expected, $request->base);
|
||||||
|
$expectedWebroot = '/CakeBB/app/webroot/';
|
||||||
|
$this->assertEqual($expectedWebroot, $request->webroot);
|
||||||
|
|
||||||
|
Configure::write('App.baseUrl', '/CakeBB/app/index.php');
|
||||||
|
$request = new CakeRequest();
|
||||||
|
$expected = '/CakeBB/app/index.php';
|
||||||
|
$this->assertEqual($expected, $request->base);
|
||||||
|
$expectedWebroot = '/CakeBB/app/webroot/';
|
||||||
|
$this->assertEqual($expectedWebroot, $request->webroot);
|
||||||
|
|
||||||
|
Configure::write('App.baseUrl', '/CakeBB/index.php');
|
||||||
|
$request = new CakeRequest();
|
||||||
|
$expected = '/CakeBB/index.php';
|
||||||
|
$this->assertEqual($expected, $request->base);
|
||||||
|
$expectedWebroot = '/CakeBB/app/webroot/';
|
||||||
|
$this->assertEqual($expectedWebroot, $request->webroot);
|
||||||
|
|
||||||
|
Configure::write('App.baseUrl', '/dbhauser/index.php');
|
||||||
|
$_SERVER['DOCUMENT_ROOT'] = '/kunden/homepages/4/d181710652/htdocs/joomla';
|
||||||
|
$_SERVER['SCRIPT_FILENAME'] = '/kunden/homepages/4/d181710652/htdocs/joomla/dbhauser/index.php';
|
||||||
|
$request = new CakeRequest();
|
||||||
|
$expected = '/dbhauser/index.php';
|
||||||
|
$this->assertEqual($expected, $request->base);
|
||||||
|
$expectedWebroot = '/dbhauser/app/webroot/';
|
||||||
|
$this->assertEqual($expectedWebroot, $request->webroot);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* testBaseUrlAndWebrootWithBase method
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function testBaseUrlAndWebrootWithBase() {
|
||||||
|
$request = new CakeRequest();
|
||||||
|
$request->base = '/app';
|
||||||
|
$result = $request->baseUrl();
|
||||||
|
$expected = '/app';
|
||||||
|
$this->assertEqual($expected, $result);
|
||||||
|
$expectedWebroot = '/app/';
|
||||||
|
$this->assertEqual($expectedWebroot, $request->webroot);
|
||||||
|
|
||||||
|
$request->base = '';
|
||||||
|
$result = $request->baseUrl();
|
||||||
|
$expected = '';
|
||||||
|
$this->assertEqual($expected, $result);
|
||||||
|
$expectedWebroot = '/';
|
||||||
|
$this->assertEqual($expectedWebroot, $request->webroot);
|
||||||
|
|
||||||
|
Configure::write('App.dir', 'testbed');
|
||||||
|
$request->base = '/cake/testbed/webroot';
|
||||||
|
$result = $request->baseUrl();
|
||||||
|
$expected = '/cake/testbed/webroot';
|
||||||
|
$this->assertEqual($expected, $result);
|
||||||
|
$expectedWebroot = '/cake/testbed/webroot/';
|
||||||
|
$this->assertEqual($expectedWebroot, $request->webroot);
|
||||||
|
}
|
||||||
}
|
}
|
Loading…
Add table
Reference in a new issue