2023-03-01 15:19:07 +13:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace SilverStripe\ORM\Tests\DBFieldTest;
|
|
|
|
|
|
|
|
use SilverStripe\Core\Config\Config;
|
|
|
|
use SilverStripe\Dev\TestOnly;
|
|
|
|
use SilverStripe\ORM\DB;
|
|
|
|
use SilverStripe\ORM\FieldType\DBField;
|
2024-08-28 10:54:31 +12:00
|
|
|
use SilverStripe\View\ViewableData;
|
2023-03-01 15:19:07 +13:00
|
|
|
|
|
|
|
class TestDbField extends DBField implements TestOnly
|
|
|
|
{
|
2024-08-28 10:54:31 +12:00
|
|
|
public function requireField(): void
|
2023-03-01 15:19:07 +13:00
|
|
|
{
|
|
|
|
// Basically the same as DBVarchar but we don't want to test with DBVarchar in case something
|
|
|
|
// changes in that class eventually.
|
|
|
|
$charset = Config::inst()->get(MySQLDatabase::class, 'charset');
|
|
|
|
$collation = Config::inst()->get(MySQLDatabase::class, 'collation');
|
|
|
|
|
|
|
|
$parts = [
|
|
|
|
'datatype' => 'varchar',
|
|
|
|
'precision' => 255,
|
|
|
|
'character set' => $charset,
|
|
|
|
'collate' => $collation,
|
|
|
|
'arrayValue' => $this->arrayValue
|
|
|
|
];
|
|
|
|
|
|
|
|
$values = [
|
|
|
|
'type' => 'varchar',
|
|
|
|
'parts' => $parts
|
|
|
|
];
|
|
|
|
|
|
|
|
DB::require_field($this->tableName, $this->name, $values);
|
|
|
|
}
|
|
|
|
|
|
|
|
public $saveIntoCalledCount = 0;
|
|
|
|
|
2024-08-28 10:54:31 +12:00
|
|
|
public function saveInto(ViewableData $model): void
|
2023-03-01 15:19:07 +13:00
|
|
|
{
|
|
|
|
$this->saveIntoCalledCount++;
|
2024-08-28 10:54:31 +12:00
|
|
|
parent::saveInto($model);
|
2023-03-01 15:19:07 +13:00
|
|
|
}
|
|
|
|
}
|