mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 12:05:37 +00:00
MINOR: Add tests for GroupedDropdownField empty strings
These bugs were never present in SS4 as the relevant code had a substantial rewrite at the same time they were introduced in SS3. In SS3, test C still fails. Fixes #4705 Fixes #4987 Fixes #4793
This commit is contained in:
parent
5851979096
commit
2c71daacfe
@ -14,16 +14,16 @@ class GroupedDropdownFieldTest extends SapphireTest
|
|||||||
$field = GroupedDropdownField::create(
|
$field = GroupedDropdownField::create(
|
||||||
'Test',
|
'Test',
|
||||||
'Testing',
|
'Testing',
|
||||||
array(
|
[
|
||||||
"1" => "One",
|
"1" => "One",
|
||||||
"Group One" => array(
|
"Group One" => [
|
||||||
"2" => "Two",
|
"2" => "Two",
|
||||||
"3" => "Three"
|
"3" => "Three"
|
||||||
),
|
],
|
||||||
"Group Two" => array(
|
"Group Two" => [
|
||||||
"4" => "Four"
|
"4" => "Four"
|
||||||
)
|
],
|
||||||
)
|
]
|
||||||
);
|
);
|
||||||
|
|
||||||
$this->assertEquals(array("1", "2", "3", "4"), $field->getValidValues());
|
$this->assertEquals(array("1", "2", "3", "4"), $field->getValidValues());
|
||||||
@ -59,4 +59,74 @@ class GroupedDropdownFieldTest extends SapphireTest
|
|||||||
|
|
||||||
$this->assertFalse($field->validate($validator));
|
$this->assertFalse($field->validate($validator));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test that empty-string values are supported by GroupDropdownTest
|
||||||
|
*/
|
||||||
|
public function testEmptyString()
|
||||||
|
{
|
||||||
|
// Case A: empty value in the top level of the source
|
||||||
|
$field = GroupedDropdownField::create(
|
||||||
|
'Test',
|
||||||
|
'Testing',
|
||||||
|
[
|
||||||
|
"" => "(Choose A)",
|
||||||
|
"1" => "One",
|
||||||
|
"Group One" => [
|
||||||
|
"2" => "Two",
|
||||||
|
"3" => "Three"
|
||||||
|
],
|
||||||
|
"Group Two" => [
|
||||||
|
"4" => "Four"
|
||||||
|
],
|
||||||
|
]
|
||||||
|
);
|
||||||
|
|
||||||
|
$this->assertRegExp(
|
||||||
|
'/<option value="" selected="selected" >\(Choose A\)<\/option>/',
|
||||||
|
preg_replace('/\s+/', ' ', (string)$field->Field())
|
||||||
|
);
|
||||||
|
|
||||||
|
// Case B: empty value in the nested level of the source
|
||||||
|
$field = GroupedDropdownField::create(
|
||||||
|
'Test',
|
||||||
|
'Testing',
|
||||||
|
[
|
||||||
|
"1" => "One",
|
||||||
|
"Group One" => [
|
||||||
|
"" => "(Choose B)",
|
||||||
|
"2" => "Two",
|
||||||
|
"3" => "Three"
|
||||||
|
],
|
||||||
|
"Group Two" => [
|
||||||
|
"4" => "Four"
|
||||||
|
],
|
||||||
|
]
|
||||||
|
);
|
||||||
|
$this->assertRegExp(
|
||||||
|
'/<option value="" selected="selected" >\(Choose B\)<\/option>/',
|
||||||
|
preg_replace('/\s+/', ' ', (string)$field->Field())
|
||||||
|
);
|
||||||
|
|
||||||
|
// Case C: setEmptyString
|
||||||
|
$field = GroupedDropdownField::create(
|
||||||
|
'Test',
|
||||||
|
'Testing',
|
||||||
|
[
|
||||||
|
"1" => "One",
|
||||||
|
"Group One" => [
|
||||||
|
"2" => "Two",
|
||||||
|
"3" => "Three"
|
||||||
|
],
|
||||||
|
"Group Two" => [
|
||||||
|
"4" => "Four"
|
||||||
|
],
|
||||||
|
]
|
||||||
|
);
|
||||||
|
$field->setEmptyString('(Choose C)');
|
||||||
|
$this->assertRegExp(
|
||||||
|
'/<option value="" selected="selected" >\(Choose C\)<\/option>/',
|
||||||
|
preg_replace('/\s+/', ' ', (string)$field->Field())
|
||||||
|
);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user