From 707c0b4130877c07967c210b07ec75995e05f818 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Renan=20Gonc=CC=A7alves?= Date: Fri, 16 Sep 2011 15:06:10 +0200 Subject: [PATCH] Fixed bug in CakeSchema where it determines the field position. - Respective tests were added. - Schema files will now have 'after' => 'previous_field' on it. --- cake/libs/model/cake_schema.php | 2 +- cake/tests/cases/libs/model/cake_schema.test.php | 16 ++++++++-------- 2 files changed, 9 insertions(+), 9 deletions(-) diff --git a/cake/libs/model/cake_schema.php b/cake/libs/model/cake_schema.php index 940b4a1f3..2944e6aff 100644 --- a/cake/libs/model/cake_schema.php +++ b/cake/libs/model/cake_schema.php @@ -491,7 +491,7 @@ class CakeSchema extends Object { } } - if (isset($add[$table][$field])) { + if (isset($tables[$table]['add'][$field]) && $field !== 'indexes' && $field !== 'tableParameters') { $wrapper = array_keys($fields); if ($column = array_search($field, $wrapper)) { if (isset($wrapper[$column - 1])) { diff --git a/cake/tests/cases/libs/model/cake_schema.test.php b/cake/tests/cases/libs/model/cake_schema.test.php index 65ca3ce59..3e646145d 100644 --- a/cake/tests/cases/libs/model/cake_schema.test.php +++ b/cake/tests/cases/libs/model/cake_schema.test.php @@ -741,8 +741,8 @@ class CakeSchemaTest extends CakeTestCase { $expected = array( 'comments' => array( 'add' => array( - 'post_id' => array('type' => 'integer', 'null' => false, 'default' => 0), - 'title' => array('type' => 'string', 'null' => false, 'length' => 100), + 'post_id' => array('type' => 'integer', 'null' => false, 'default' => 0, 'after' => 'id'), + 'title' => array('type' => 'string', 'null' => false, 'length' => 100, 'after' => 'user_id'), ), 'drop' => array( 'article_id' => array('type' => 'integer', 'null' => false), @@ -754,7 +754,7 @@ class CakeSchemaTest extends CakeTestCase { ), 'posts' => array( 'add' => array( - 'summary' => array('type' => 'text', 'null' => 1), + 'summary' => array('type' => 'text', 'null' => 1, 'after' => 'body'), ), 'drop' => array( 'tableParameters' => array(), @@ -795,11 +795,11 @@ class CakeSchemaTest extends CakeTestCase { 'ratings' => array( 'add' => array( 'id' => array('type' => 'integer', 'null' => false, 'default' => NULL, 'key' => 'primary'), - 'foreign_key' => array('type' => 'integer', 'null' => false, 'default' => NULL), - 'model' => array('type' => 'varchar', 'null' => false, 'default' => NULL), - 'value' => array('type' => 'float', 'null' => false, 'length' => '5,2', 'default' => NULL), - 'created' => array('type' => 'datetime', 'null' => false, 'default' => NULL), - 'modified' => array('type' => 'datetime', 'null' => false, 'default' => NULL), + 'foreign_key' => array('type' => 'integer', 'null' => false, 'default' => NULL, 'after' => 'id'), + 'model' => array('type' => 'varchar', 'null' => false, 'default' => NULL, 'after' => 'foreign_key'), + 'value' => array('type' => 'float', 'null' => false, 'length' => '5,2', 'default' => NULL, 'after' => 'model'), + 'created' => array('type' => 'datetime', 'null' => false, 'default' => NULL, 'after' => 'value'), + 'modified' => array('type' => 'datetime', 'null' => false, 'default' => NULL, 'after' => 'created'), 'indexes' => array('PRIMARY' => array('column' => 'id', 'unique' => 1)), 'tableParameters' => array('charset' => 'latin1', 'collate' => 'latin1_swedish_ci', 'engine' => 'MyISAM') )