mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 12:05:37 +00:00
Merge pull request #9818 from creative-commoners/pulls/4.7/check-object-for-key
FIX Type checking in objectForKey() to fix postgres bug
This commit is contained in:
commit
d13d3a1134
@ -812,10 +812,13 @@ class TreeDropdownField extends FormField
|
|||||||
* Get the object where the $keyField is equal to a certain value
|
* Get the object where the $keyField is equal to a certain value
|
||||||
*
|
*
|
||||||
* @param string|int $key
|
* @param string|int $key
|
||||||
* @return DataObject
|
* @return DataObject|null
|
||||||
*/
|
*/
|
||||||
protected function objectForKey($key)
|
protected function objectForKey($key)
|
||||||
{
|
{
|
||||||
|
if (!is_string($key) && !is_int($key)) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
return DataObject::get($this->getSourceObject())
|
return DataObject::get($this->getSourceObject())
|
||||||
->filter($this->getKeyField(), $key)
|
->filter($this->getKeyField(), $key)
|
||||||
->first();
|
->first();
|
||||||
|
@ -149,12 +149,16 @@ class TreeMultiselectField extends TreeDropdownField
|
|||||||
|
|
||||||
// Parse ids from value string / array
|
// Parse ids from value string / array
|
||||||
$ids = [];
|
$ids = [];
|
||||||
|
|
||||||
if (is_string($value)) {
|
if (is_string($value)) {
|
||||||
$ids = preg_split("#\s*,\s*#", trim($value));
|
$ids = preg_split("#\s*,\s*#", trim($value));
|
||||||
} elseif (is_array($value)) {
|
} elseif (is_array($value)) {
|
||||||
$ids = array_values($value);
|
$ids = array_values($value);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Filter out empty strings
|
||||||
|
$ids = array_filter($ids);
|
||||||
|
|
||||||
// No value
|
// No value
|
||||||
if (empty($ids)) {
|
if (empty($ids)) {
|
||||||
return ArrayList::create();
|
return ArrayList::create();
|
||||||
|
@ -8,7 +8,10 @@ use SilverStripe\Control\Session;
|
|||||||
use SilverStripe\Dev\CSSContentParser;
|
use SilverStripe\Dev\CSSContentParser;
|
||||||
use SilverStripe\Dev\SapphireTest;
|
use SilverStripe\Dev\SapphireTest;
|
||||||
use SilverStripe\Control\HTTPRequest;
|
use SilverStripe\Control\HTTPRequest;
|
||||||
|
use SilverStripe\Forms\FieldList;
|
||||||
|
use SilverStripe\Forms\Form;
|
||||||
use SilverStripe\Forms\TreeDropdownField;
|
use SilverStripe\Forms\TreeDropdownField;
|
||||||
|
use SilverStripe\ORM\DataObject;
|
||||||
use SilverStripe\ORM\Tests\HierarchyTest\TestObject;
|
use SilverStripe\ORM\Tests\HierarchyTest\TestObject;
|
||||||
|
|
||||||
class TreeDropdownFieldTest extends SapphireTest
|
class TreeDropdownFieldTest extends SapphireTest
|
||||||
@ -246,4 +249,21 @@ class TreeDropdownFieldTest extends SapphireTest
|
|||||||
$result
|
$result
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This is to test setting $key to an Object in the protected function objectForKey()
|
||||||
|
* This is to fix an issue where postgres will not fail gracefully when you do this
|
||||||
|
*/
|
||||||
|
public function testObjectForKeyObjectValue()
|
||||||
|
{
|
||||||
|
$form = Form::create();
|
||||||
|
$fieldList = FieldList::create();
|
||||||
|
$field = TreeDropdownField::create('TestTree', 'Test tree', File::class);
|
||||||
|
$fieldList->add($field);
|
||||||
|
$form->setFields($fieldList);
|
||||||
|
$field->setValue(DataObject::create());
|
||||||
|
// The following previously errored in postgres
|
||||||
|
$field->getSchemaStateDefaults();
|
||||||
|
$this->assertTrue(true);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -340,5 +340,12 @@ class TreeMultiselectFieldTest extends SapphireTest
|
|||||||
[],
|
[],
|
||||||
$field->getItems()
|
$field->getItems()
|
||||||
);
|
);
|
||||||
|
|
||||||
|
// Andle empty string none value
|
||||||
|
$field->setValue('');
|
||||||
|
$this->assertListEquals(
|
||||||
|
[],
|
||||||
|
$field->getItems()
|
||||||
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user