mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 14:05:37 +02:00
54 lines
1.6 KiB
PHP
54 lines
1.6 KiB
PHP
<?php
|
|
|
|
namespace SilverStripe\ORM\Tests\DataObjectTest;
|
|
|
|
use SilverStripe\Dev\TestOnly;
|
|
use SilverStripe\ORM\FieldType\DBBoolean;
|
|
use SilverStripe\ORM\FieldType\DBField;
|
|
|
|
/**
|
|
* This is a fake DB field specifically design to test dynamic value assignment. You can set `scalarValueOnly` in
|
|
* the constructor. You can control whatever the field will try to do a dynamic assignment by specifying
|
|
* `$dynamicAssignment` in nthe constructor.
|
|
*
|
|
* If the field is set to false, it will try to do a plain assignment. This is so you can save the initial value no
|
|
* matter what. If the field is set to true, it will try to do a dynamic assignment.
|
|
*/
|
|
class MockDynamicAssignmentDBField extends DBBoolean implements TestOnly
|
|
{
|
|
|
|
private $scalarOnly;
|
|
private $dynamicAssignment;
|
|
|
|
/**
|
|
* @param string $name
|
|
* @param boolean $scalarOnly Whether our fake field should be scalar only.
|
|
* @param boolean $dynamicAssignment Whether our fake field will try to do a dynamic assignment.
|
|
*/
|
|
public function __construct($name = '', $scalarOnly = false, $dynamicAssignment = false)
|
|
{
|
|
$this->scalarOnly = $scalarOnly;
|
|
$this->dynamicAssignment = $dynamicAssignment;
|
|
parent::__construct($name);
|
|
}
|
|
|
|
/**
|
|
* If the field value and $dynamicAssignment are true, we'll try to do a dynamic assignment.
|
|
*/
|
|
public function prepValueForDB(mixed $value): array|int|null
|
|
{
|
|
if ($value) {
|
|
return $this->dynamicAssignment
|
|
? ['ABS(?)' => [1]]
|
|
: 1;
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
public function scalarValueOnly(): bool
|
|
{
|
|
return $this->scalarOnly;
|
|
}
|
|
}
|