mirror of
https://github.com/kamilwylegala/cakephp2-php8.git
synced 2025-01-18 18:46:17 +00:00
Merge branch '1.2' into 1.3-merger
Conflicts: cake/console/libs/tasks/controller.php cake/console/libs/tasks/model.php
This commit is contained in:
commit
58383d3cb9
13 changed files with 72 additions and 36 deletions
|
@ -280,7 +280,7 @@ class Dispatcher extends Object {
|
|||
$params['form']['_method'] = env('HTTP_X_HTTP_METHOD_OVERRIDE');
|
||||
}
|
||||
if (isset($params['form']['_method'])) {
|
||||
if (isset($_SERVER) && !empty($_SERVER)) {
|
||||
if (!empty($_SERVER)) {
|
||||
$_SERVER['REQUEST_METHOD'] = $params['form']['_method'];
|
||||
} else {
|
||||
$_ENV['REQUEST_METHOD'] = $params['form']['_method'];
|
||||
|
|
17
cake/libs/cache/memcache.php
vendored
17
cake/libs/cache/memcache.php
vendored
|
@ -36,9 +36,11 @@ class MemcacheEngine extends CacheEngine {
|
|||
var $__Memcache = null;
|
||||
|
||||
/**
|
||||
* settings
|
||||
* servers = string or array of memcache servers, default => 127.0.0.1
|
||||
* compress = boolean, default => false
|
||||
* Settings
|
||||
*
|
||||
* - servers = string or array of memcache servers, default => 127.0.0.1. If an
|
||||
* array MemcacheEngine will use them as a pool.
|
||||
* - compress = boolean, default => false
|
||||
*
|
||||
* @var array
|
||||
* @access public
|
||||
|
@ -60,7 +62,10 @@ class MemcacheEngine extends CacheEngine {
|
|||
return false;
|
||||
}
|
||||
parent::init(array_merge(array(
|
||||
'engine'=> 'Memcache', 'prefix' => Inflector::slug(APP_DIR) . '_', 'servers' => array('127.0.0.1'), 'compress'=> false
|
||||
'engine'=> 'Memcache',
|
||||
'prefix' => Inflector::slug(APP_DIR) . '_',
|
||||
'servers' => array('127.0.0.1'),
|
||||
'compress'=> false
|
||||
), $settings)
|
||||
);
|
||||
|
||||
|
@ -100,7 +105,7 @@ class MemcacheEngine extends CacheEngine {
|
|||
*/
|
||||
function write($key, &$value, $duration) {
|
||||
$expires = time() + $duration;
|
||||
$this->__Memcache->set($key.'_expires', $expires, $this->settings['compress'], $expires);
|
||||
$this->__Memcache->set($key . '_expires', $expires, $this->settings['compress'], $expires);
|
||||
return $this->__Memcache->set($key, $value, $this->settings['compress'], $expires);
|
||||
}
|
||||
|
||||
|
@ -113,7 +118,7 @@ class MemcacheEngine extends CacheEngine {
|
|||
*/
|
||||
function read($key) {
|
||||
$time = time();
|
||||
$cachetime = intval($this->__Memcache->get($key.'_expires'));
|
||||
$cachetime = intval($this->__Memcache->get($key . '_expires'));
|
||||
if ($cachetime < $time || ($time + $this->settings['duration']) < $cachetime) {
|
||||
return false;
|
||||
}
|
||||
|
|
|
@ -267,20 +267,7 @@ class Configure extends Object {
|
|||
$content = '';
|
||||
|
||||
foreach ($data as $key => $value) {
|
||||
$content .= "\$config['$type']['$key']";
|
||||
|
||||
if (is_array($value)) {
|
||||
$content .= " = array(";
|
||||
|
||||
foreach ($value as $key1 => $value2) {
|
||||
$value2 = addslashes($value2);
|
||||
$content .= "'$key1' => '$value2', ";
|
||||
}
|
||||
$content .= ");\n";
|
||||
} else {
|
||||
$value = addslashes($value);
|
||||
$content .= " = '$value';\n";
|
||||
}
|
||||
$content .= "\$config['$type']['$key'] = " . var_export($value, true) . ";\n";
|
||||
}
|
||||
if (is_null($type)) {
|
||||
$write = false;
|
||||
|
|
|
@ -577,7 +577,8 @@ class HttpSocket extends CakeSocket {
|
|||
$stripIfEmpty = array(
|
||||
'query' => '?%query',
|
||||
'fragment' => '#%fragment',
|
||||
'user' => '%user:%pass@'
|
||||
'user' => '%user:%pass@',
|
||||
'host' => '%host:%port/'
|
||||
);
|
||||
|
||||
foreach ($stripIfEmpty as $key => $strip) {
|
||||
|
@ -590,7 +591,6 @@ class HttpSocket extends CakeSocket {
|
|||
if (array_key_exists($uri['scheme'], $defaultPorts) && $defaultPorts[$uri['scheme']] == $uri['port']) {
|
||||
$uriTemplate = str_replace(':%port', null, $uriTemplate);
|
||||
}
|
||||
|
||||
foreach ($uri as $property => $value) {
|
||||
$uriTemplate = str_replace('%'.$property, $value, $uriTemplate);
|
||||
}
|
||||
|
|
|
@ -139,6 +139,7 @@ class Inflector {
|
|||
'/(m)en$/i' => '\1an',
|
||||
'/(c)hildren$/i' => '\1\2hild',
|
||||
'/(n)ews$/i' => '\1\2ews',
|
||||
'/eaus$/' => 'eau',
|
||||
'/^(.*us)$/' => '\\1',
|
||||
'/s$/i' => ''
|
||||
),
|
||||
|
|
|
@ -851,12 +851,12 @@ class DboSource extends DataSource {
|
|||
if (count($ins) > 1) {
|
||||
$query = str_replace('{$__cakeID__$}', '(' .join(', ', $ins) .')', $query);
|
||||
$query = str_replace('= (', 'IN (', $query);
|
||||
$query = str_replace('= (', 'IN (', $query);
|
||||
$query = str_replace('= (', 'IN (', $query);
|
||||
} else {
|
||||
$query = str_replace('{$__cakeID__$}',$ins[0], $query);
|
||||
}
|
||||
|
||||
$query = str_replace(' WHERE 1 = 1', '', $query);
|
||||
$query = str_replace(' WHERE 1 = 1', '', $query);
|
||||
}
|
||||
|
||||
$foreignKey = $model->hasAndBelongsToMany[$association]['foreignKey'];
|
||||
|
@ -930,7 +930,7 @@ class DboSource extends DataSource {
|
|||
$this->__mergeAssociation($resultSet[$i], $fetch, $association, $type, $selfJoin);
|
||||
}
|
||||
if (isset($resultSet[$i][$association])) {
|
||||
$resultSet[$i][$association] = $linkModel->afterFind($resultSet[$i][$association]);
|
||||
$resultSet[$i][$association] = $linkModel->afterFind($resultSet[$i][$association], false);
|
||||
}
|
||||
} else {
|
||||
$tempArray[0][$association] = false;
|
||||
|
@ -952,7 +952,7 @@ class DboSource extends DataSource {
|
|||
$query = str_replace('{$__cakeID__$}', join(', ', $ids), $query);
|
||||
if (count($ids) > 1) {
|
||||
$query = str_replace('= (', 'IN (', $query);
|
||||
$query = str_replace('= (', 'IN (', $query);
|
||||
$query = str_replace('= (', 'IN (', $query);
|
||||
}
|
||||
return $this->fetchAll($query, $model->cacheQueries, $model->alias);
|
||||
}
|
||||
|
|
|
@ -597,6 +597,7 @@ class Router {
|
|||
if (strcasecmp($name, $match) === 0) {
|
||||
$url = substr($url, 0, strpos($url, '.' . $name));
|
||||
$ext = $match;
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
16
cake/tests/cases/libs/cache/memcache.test.php
vendored
16
cake/tests/cases/libs/cache/memcache.test.php
vendored
|
@ -83,13 +83,15 @@ class MemcacheEngineTest extends CakeTestCase {
|
|||
*/
|
||||
function testSettings() {
|
||||
$settings = Cache::settings();
|
||||
$expecting = array('prefix' => 'cake_',
|
||||
'duration'=> 3600,
|
||||
'probability' => 100,
|
||||
'servers' => array('127.0.0.1'),
|
||||
'compress' => false,
|
||||
'engine' => 'Memcache'
|
||||
);
|
||||
unset($settings['serialize'], $settings['path']);
|
||||
$expecting = array(
|
||||
'prefix' => 'cake_',
|
||||
'duration'=> 3600,
|
||||
'probability' => 100,
|
||||
'servers' => array('127.0.0.1'),
|
||||
'compress' => false,
|
||||
'engine' => 'Memcache'
|
||||
);
|
||||
$this->assertEqual($settings, $expecting);
|
||||
}
|
||||
|
||||
|
|
|
@ -233,14 +233,17 @@ class ConfigureTest extends CakeTestCase {
|
|||
function testStoreAndLoad() {
|
||||
Configure::write('Cache.disable', false);
|
||||
|
||||
$expected = array('data' => 'value');
|
||||
$expected = array('data' => 'value with backslash \, \'singlequote\' and "doublequotes"');
|
||||
Configure::store('SomeExample', 'test', $expected);
|
||||
|
||||
Configure::load('test');
|
||||
$config = Configure::read('SomeExample');
|
||||
$this->assertEqual($config, $expected);
|
||||
|
||||
$expected = array('data' => array('first' => 'value', 'second' => 'value2'));
|
||||
$expected = array(
|
||||
'data' => array('first' => 'value with backslash \, \'singlequote\' and "doublequotes"', 'second' => 'value2'),
|
||||
'data2' => 'value'
|
||||
);
|
||||
Configure::store('AnotherExample', 'test.config', $expected);
|
||||
|
||||
Configure::load('test.config');
|
||||
|
|
|
@ -1068,6 +1068,9 @@ class HttpSocketTest extends CakeTestCase {
|
|||
$r = $this->Socket->buildUri(array('host' => 'www.cakephp.org', 'port' => 23));
|
||||
$this->assertIdentical($r, 'http://www.cakephp.org:23/');
|
||||
|
||||
$r = $this->Socket->buildUri(array('path' => 'www.google.com/search', 'query' => 'q=cakephp'));
|
||||
$this->assertIdentical($r, 'http://www.google.com/search?q=cakephp');
|
||||
|
||||
$r = $this->Socket->buildUri(array('host' => 'www.cakephp.org', 'scheme' => 'https', 'port' => 79));
|
||||
$this->assertIdentical($r, 'https://www.cakephp.org:79/');
|
||||
|
||||
|
|
|
@ -114,6 +114,7 @@ class InflectorTest extends CakeTestCase {
|
|||
$this->assertEqual(Inflector::singularize('waxes'), 'wax');
|
||||
$this->assertEqual(Inflector::singularize('niches'), 'niche');
|
||||
$this->assertEqual(Inflector::singularize('waves'), 'wave');
|
||||
$this->assertEqual(Inflector::singularize('bureaus'), 'bureau');
|
||||
$this->assertEqual(Inflector::singularize(''), '');
|
||||
}
|
||||
|
||||
|
@ -160,6 +161,7 @@ class InflectorTest extends CakeTestCase {
|
|||
$this->assertEqual(Inflector::pluralize('crisis'), 'crises');
|
||||
$this->assertEqual(Inflector::pluralize('tax'), 'taxes');
|
||||
$this->assertEqual(Inflector::pluralize('wave'), 'waves');
|
||||
$this->assertEqual(Inflector::pluralize('bureau'), 'bureaus');
|
||||
$this->assertEqual(Inflector::pluralize(''), '');
|
||||
}
|
||||
|
||||
|
@ -266,6 +268,7 @@ class InflectorTest extends CakeTestCase {
|
|||
$this->assertEqual(Inflector::classify('artists_genres'), 'ArtistsGenre');
|
||||
$this->assertEqual(Inflector::classify('file_systems'), 'FileSystem');
|
||||
$this->assertEqual(Inflector::classify('news'), 'News');
|
||||
$this->assertEqual(Inflector::classify('bureaus'), 'Bureau');
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -278,6 +281,7 @@ class InflectorTest extends CakeTestCase {
|
|||
$this->assertEqual(Inflector::tableize('ArtistsGenre'), 'artists_genres');
|
||||
$this->assertEqual(Inflector::tableize('FileSystem'), 'file_systems');
|
||||
$this->assertEqual(Inflector::tableize('News'), 'news');
|
||||
$this->assertEqual(Inflector::tableize('Bureau'), 'bureaus');
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
|
@ -4887,6 +4887,21 @@ class ModelReadTest extends BaseModelTest {
|
|||
$this->assertFalse($TestModel->find('all', array('connection' => 'foo')));
|
||||
}
|
||||
|
||||
/**
|
||||
* Tests that the database configuration assigned to the model can be changed using
|
||||
* (before|after)Find callbacks
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
function testCallbackSourceChange() {
|
||||
$this->loadFixtures('Post');
|
||||
$TestModel = new Post();
|
||||
$this->assertEqual(3, count($TestModel->find('all')));
|
||||
|
||||
$this->expectError(new PatternExpectation('/Non-existent data source foo/i'));
|
||||
$this->expectError(new PatternExpectation('/Only variable references/i'));
|
||||
$this->assertFalse($TestModel->find('all', array('connection' => 'foo')));
|
||||
}
|
||||
/**
|
||||
* testMultipleBelongsToWithSameClass method
|
||||
*
|
||||
|
|
|
@ -5064,6 +5064,21 @@ class FormHelperTest extends CakeTestCase {
|
|||
'/fieldset'
|
||||
);
|
||||
$this->assertTags($result, $expected);
|
||||
|
||||
$this->Form->data = array();
|
||||
$this->Form->params['controller'] = 'contacts';
|
||||
$this->Form->params['models'] = array('Contact');
|
||||
$result = $this->Form->create(array('url' => array('action' => 'index', 'param')));
|
||||
$expected = array(
|
||||
'form' => array(
|
||||
'id' => 'ContactAddForm', 'method' => 'post', 'action' => '/contacts/index/param'
|
||||
),
|
||||
'fieldset' => array('style' => 'preg:/display\s*\:\s*none;\s*/'),
|
||||
'input' => array('type' => 'hidden', 'name' => '_method', 'value' => 'POST'),
|
||||
'/fieldset'
|
||||
);
|
||||
$this->assertTags($result, $expected);
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
Loading…
Add table
Reference in a new issue