Fixing ClassRegistry that was incorrectly checking class inheritance

Fixing Model class that was incorrectly sending model names to be instantiated
Fixing more FormHelper tests
This commit is contained in:
Jose Lorenzo Rodriguez 2011-07-14 01:30:52 -04:30
parent 1941be6a76
commit ef5650c034
4 changed files with 19 additions and 15 deletions

View file

@ -702,10 +702,13 @@ class Model extends Object {
}
if (!isset($this->{$assoc}) || $this->{$assoc}->name !== $className) {
$model = array('class' => $plugin . '.' . $className, 'alias' => $assoc);
if ($plugin) {
$plugin .= '.';
}
$model = array('class' => $plugin . $className, 'alias' => $assoc);
$this->{$assoc} = ClassRegistry::init($model);
if ($plugin) {
ClassRegistry::addObject($plugin . '.' . $className, $this->{$assoc});
ClassRegistry::addObject($plugin . $className, $this->{$assoc});
}
if ($assoc) {
$this->tableToModel[$this->{$assoc}->table] = $assoc;

View file

@ -1882,7 +1882,7 @@ class FormHelperTest extends CakeTestCase {
'label' => array('for' => 'ObjectField'),
'Field',
'/label',
'input' => array('type' => 'text', 'name' => 'data[Object][field]', 'id' => 'ObjectField'),
'input' => array('type' => 'text', 'name' => 'data[Object][field]', 'id' => 'ModelField'),
'A message to you, Rudy',
'/div'
);

View file

@ -135,16 +135,18 @@ class ClassRegistry {
App::uses($plugin . 'AppModel', $pluginPath . 'Model');
App::uses($class, $pluginPath . 'Model');
if (class_exists($class) && $class instanceof Model) {
if (class_exists($class)) {
${$class} = new $class($settings);
} else {
if ($strict) {
$$class = ($$class instanceof Mdoel) ? $$class : null;
}
if (!isset($$class) && $strict) {
return false;
} elseif ($plugin && class_exists($plugin . 'AppModel')) {
$appModel = $plugin . 'AppModel';
} else {
$appModel = 'AppModel';
}
if (!empty($appModel)) {
$settings['name'] = $class;
${$class} = new $appModel($settings);
}

View file

@ -156,11 +156,10 @@ class FormHelper extends AppHelper {
return $this->fieldset[$model]['key'];
}
if ($key === 'fields') {
if (!isset($this->fieldset[$model]['fields'])) {
$fields = $this->fieldset[$model]['fields'] = $object->schema();
}
if ($key === 'fields') {
if (empty($field)) {
foreach ($object->hasAndBelongsToMany as $alias => $assocData) {
$this->fieldset[$object->alias]['fields'][$alias] = array('type' => 'multiple');