2018-10-18 22:52:14 +13:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace SilverStripe\Forms\Tests;
|
|
|
|
|
|
|
|
use SilverStripe\Forms\Tests\CheckboxSetFieldTest\MultiEnumArticle;
|
|
|
|
use SilverStripe\ORM\DB;
|
|
|
|
use SilverStripe\Dev\SapphireTest;
|
|
|
|
use SilverStripe\Control\Controller;
|
|
|
|
use SilverStripe\Forms\CheckboxSetField;
|
|
|
|
use SilverStripe\Forms\FieldList;
|
|
|
|
use SilverStripe\Forms\Form;
|
|
|
|
use SilverStripe\ORM\Connect\MySQLDatabase;
|
|
|
|
|
2023-08-21 15:49:09 +01:00
|
|
|
class CheckboxSetFieldMultiEnumTest extends SapphireTest
|
2018-10-18 22:52:14 +13:00
|
|
|
{
|
|
|
|
|
|
|
|
protected $usesDatabase = true;
|
|
|
|
|
|
|
|
public static function getExtraDataObjects()
|
|
|
|
{
|
|
|
|
// Don't add this for other database
|
|
|
|
if (DB::get_conn() instanceof MySQLDatabase) {
|
|
|
|
return [
|
|
|
|
MultiEnumArticle::class,
|
|
|
|
];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-10-27 15:39:47 +13:00
|
|
|
protected function setUp(): void
|
2018-10-18 22:52:14 +13:00
|
|
|
{
|
|
|
|
if (!(DB::get_conn() instanceof MySQLDatabase)) {
|
|
|
|
$this->markTestSkipped('DBMultiEnum only supported by MySQL');
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
parent::setUp();
|
|
|
|
}
|
|
|
|
|
2021-10-27 15:39:47 +13:00
|
|
|
protected function tearDown(): void
|
2018-10-18 22:52:14 +13:00
|
|
|
{
|
|
|
|
if (!(DB::get_conn() instanceof MySQLDatabase)) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
parent::tearDown();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testLoadDataFromMultiEnum()
|
|
|
|
{
|
|
|
|
$article = new MultiEnumArticle();
|
|
|
|
$article->Colours = 'Red,Green';
|
|
|
|
|
|
|
|
$field = new CheckboxSetField(
|
|
|
|
'Colours',
|
|
|
|
'Colours',
|
|
|
|
[
|
|
|
|
'Red' => 'Red',
|
|
|
|
'Blue' => 'Blue',
|
|
|
|
'Green' => 'Green',
|
|
|
|
]
|
|
|
|
);
|
|
|
|
|
|
|
|
$form = new Form(
|
|
|
|
Controller::curr(),
|
|
|
|
'Form',
|
|
|
|
new FieldList($field),
|
|
|
|
new FieldList()
|
|
|
|
);
|
|
|
|
$form->loadDataFrom($article);
|
|
|
|
$value = $field->Value();
|
|
|
|
$this->assertEquals(['Red', 'Green'], $value);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testSavingIntoMultiEnum()
|
|
|
|
{
|
|
|
|
$field = new CheckboxSetField(
|
|
|
|
'Colours',
|
|
|
|
'Colours',
|
|
|
|
[
|
|
|
|
'Red' => 'Red',
|
|
|
|
'Blue' => 'Blue',
|
|
|
|
'Green' => 'Green',
|
|
|
|
]
|
|
|
|
);
|
|
|
|
$article = new MultiEnumArticle();
|
2020-04-20 18:58:09 +01:00
|
|
|
$field->setValue(['Red' => 'Red', 'Blue' => 'Blue']);
|
2018-10-18 22:52:14 +13:00
|
|
|
$field->saveInto($article);
|
|
|
|
$article->write();
|
|
|
|
|
|
|
|
$dbValue = DB::query(
|
|
|
|
sprintf(
|
|
|
|
'SELECT "Colours" FROM "CheckboxSetFieldTest_MultiEnumArticle" WHERE "ID" = %s',
|
|
|
|
$article->ID
|
|
|
|
)
|
|
|
|
)->value();
|
|
|
|
|
|
|
|
// JSON encoded values
|
|
|
|
$this->assertEquals('Red,Blue', $dbValue);
|
|
|
|
}
|
|
|
|
}
|