mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 14:05:37 +02:00
301 lines
12 KiB
PHP
301 lines
12 KiB
PHP
<?php
|
|
|
|
/**
|
|
*
|
|
* Tests for DBField objects.
|
|
* @package framework
|
|
* @subpackage tests
|
|
*
|
|
*/
|
|
class DBFieldTest extends SapphireTest {
|
|
|
|
/**
|
|
* Test the nullValue() method on DBField.
|
|
*/
|
|
public function testNullValue() {
|
|
/* Float and Double use 0 for "null" value representation */
|
|
$this->assertEquals(0, singleton('Float')->nullValue());
|
|
$this->assertEquals(0, singleton('Double')->nullValue());
|
|
}
|
|
|
|
/**
|
|
* Test the prepValueForDB() method on DBField.
|
|
*/
|
|
public function testPrepValueForDB() {
|
|
$db = DB::get_conn();
|
|
|
|
/* Float behaviour, asserting we have 0 */
|
|
$this->assertEquals(0, singleton('Float')->prepValueForDB(0));
|
|
$this->assertEquals(0, singleton('Float')->prepValueForDB(null));
|
|
$this->assertEquals(0, singleton('Float')->prepValueForDB(false));
|
|
$this->assertEquals(0, singleton('Float')->prepValueForDB(''));
|
|
$this->assertEquals('0', singleton('Float')->prepValueForDB('0'));
|
|
|
|
/* Double behaviour, asserting we have 0 */
|
|
$this->assertEquals(0, singleton('Double')->prepValueForDB(0));
|
|
$this->assertEquals(0, singleton('Double')->prepValueForDB(null));
|
|
$this->assertEquals(0, singleton('Double')->prepValueForDB(false));
|
|
$this->assertEquals(0, singleton('Double')->prepValueForDB(''));
|
|
$this->assertEquals('0', singleton('Double')->prepValueForDB('0'));
|
|
|
|
/* Integer behaviour, asserting we have 0 */
|
|
$this->assertEquals(0, singleton('Int')->prepValueForDB(0));
|
|
$this->assertEquals(0, singleton('Int')->prepValueForDB(null));
|
|
$this->assertEquals(0, singleton('Int')->prepValueForDB(false));
|
|
$this->assertEquals(0, singleton('Int')->prepValueForDB(''));
|
|
$this->assertEquals('0', singleton('Int')->prepValueForDB('0'));
|
|
|
|
/* Integer behaviour, asserting we have 1 */
|
|
$this->assertEquals(1, singleton('Int')->prepValueForDB(true));
|
|
$this->assertEquals(1, singleton('Int')->prepValueForDB(1));
|
|
$this->assertEquals('1', singleton('Int')->prepValueForDB('1'));
|
|
|
|
/* Decimal behaviour, asserting we have 0 */
|
|
$this->assertEquals(0, singleton('Decimal')->prepValueForDB(0));
|
|
$this->assertEquals(0, singleton('Decimal')->prepValueForDB(null));
|
|
$this->assertEquals(0, singleton('Decimal')->prepValueForDB(false));
|
|
$this->assertEquals(0, singleton('Decimal')->prepValueForDB(''));
|
|
$this->assertEquals('0', singleton('Decimal')->prepValueForDB('0'));
|
|
|
|
/* Decimal behaviour, asserting we have 1 */
|
|
$this->assertEquals(1, singleton('Decimal')->prepValueForDB(true));
|
|
$this->assertEquals(1, singleton('Decimal')->prepValueForDB(1));
|
|
$this->assertEquals('1', singleton('Decimal')->prepValueForDB('1'));
|
|
|
|
/* Boolean behaviour, asserting we have 0 */
|
|
$this->assertEquals(false, singleton('Boolean')->prepValueForDB(0));
|
|
$this->assertEquals(false, singleton('Boolean')->prepValueForDB(null));
|
|
$this->assertEquals(false, singleton('Boolean')->prepValueForDB(false));
|
|
$this->assertEquals(false, singleton('Boolean')->prepValueForDB('false'));
|
|
$this->assertEquals(false, singleton('Boolean')->prepValueForDB('f'));
|
|
$this->assertEquals(false, singleton('Boolean')->prepValueForDB(''));
|
|
$this->assertEquals(false, singleton('Boolean')->prepValueForDB('0'));
|
|
|
|
/* Boolean behaviour, asserting we have 1 */
|
|
$this->assertEquals(true, singleton('Boolean')->prepValueForDB(true));
|
|
$this->assertEquals(true, singleton('Boolean')->prepValueForDB('true'));
|
|
$this->assertEquals(true, singleton('Boolean')->prepValueForDB('t'));
|
|
$this->assertEquals(true, singleton('Boolean')->prepValueForDB(1));
|
|
$this->assertEquals(true, singleton('Boolean')->prepValueForDB('1'));
|
|
|
|
// @todo - Revisit Varchar to evaluate correct behaviour of nullifyEmpty
|
|
|
|
/* Varchar behaviour */
|
|
$this->assertEquals(0, singleton('Varchar')->prepValueForDB(0));
|
|
$this->assertEquals(null, singleton('Varchar')->prepValueForDB(null));
|
|
$this->assertEquals(null, singleton('Varchar')->prepValueForDB(false));
|
|
$this->assertEquals(null, singleton('Varchar')->prepValueForDB(''));
|
|
$this->assertEquals('0', singleton('Varchar')->prepValueForDB('0'));
|
|
$this->assertEquals(1, singleton('Varchar')->prepValueForDB(1));
|
|
$this->assertEquals(true, singleton('Varchar')->prepValueForDB(true));
|
|
$this->assertEquals('1', singleton('Varchar')->prepValueForDB('1'));
|
|
$this->assertEquals('00000', singleton('Varchar')->prepValueForDB('00000'));
|
|
$this->assertEquals(0, singleton('Varchar')->prepValueForDB(0000));
|
|
$this->assertEquals('test', singleton('Varchar')->prepValueForDB('test'));
|
|
$this->assertEquals(123, singleton('Varchar')->prepValueForDB(123));
|
|
|
|
/* AllowEmpty Varchar behaviour */
|
|
$varcharField = new Varchar("testfield", 50, array("nullifyEmpty"=>false));
|
|
$this->assertSame(0, $varcharField->prepValueForDB(0));
|
|
$this->assertSame(null, $varcharField->prepValueForDB(null));
|
|
$this->assertSame(null, $varcharField->prepValueForDB(false));
|
|
$this->assertSame('', $varcharField->prepValueForDB(''));
|
|
$this->assertSame('0', $varcharField->prepValueForDB('0'));
|
|
$this->assertSame(1, $varcharField->prepValueForDB(1));
|
|
$this->assertSame(true, $varcharField->prepValueForDB(true));
|
|
$this->assertSame('1', $varcharField->prepValueForDB('1'));
|
|
$this->assertSame('00000', $varcharField->prepValueForDB('00000'));
|
|
$this->assertSame(0, $varcharField->prepValueForDB(0000));
|
|
$this->assertSame('test', $varcharField->prepValueForDB('test'));
|
|
$this->assertSame(123, $varcharField->prepValueForDB(123));
|
|
unset($varcharField);
|
|
|
|
/* Text behaviour */
|
|
$this->assertEquals(0, singleton('Text')->prepValueForDB(0));
|
|
$this->assertEquals(null, singleton('Text')->prepValueForDB(null));
|
|
$this->assertEquals(null, singleton('Text')->prepValueForDB(false));
|
|
$this->assertEquals(null, singleton('Text')->prepValueForDB(''));
|
|
$this->assertEquals('0', singleton('Text')->prepValueForDB('0'));
|
|
$this->assertEquals(1, singleton('Text')->prepValueForDB(1));
|
|
$this->assertEquals(true, singleton('Text')->prepValueForDB(true));
|
|
$this->assertEquals('1', singleton('Text')->prepValueForDB('1'));
|
|
$this->assertEquals('00000', singleton('Text')->prepValueForDB('00000'));
|
|
$this->assertEquals(0, singleton('Text')->prepValueForDB(0000));
|
|
$this->assertEquals('test', singleton('Text')->prepValueForDB('test'));
|
|
$this->assertEquals(123, singleton('Text')->prepValueForDB(123));
|
|
|
|
/* AllowEmpty Text behaviour */
|
|
$textField = new Text("testfield", array("nullifyEmpty"=>false));
|
|
$this->assertSame(0, $textField->prepValueForDB(0));
|
|
$this->assertSame(null, $textField->prepValueForDB(null));
|
|
$this->assertSame(null, $textField->prepValueForDB(false));
|
|
$this->assertSame('', $textField->prepValueForDB(''));
|
|
$this->assertSame('0', $textField->prepValueForDB('0'));
|
|
$this->assertSame(1, $textField->prepValueForDB(1));
|
|
$this->assertSame(true, $textField->prepValueForDB(true));
|
|
$this->assertSame('1', $textField->prepValueForDB('1'));
|
|
$this->assertSame('00000', $textField->prepValueForDB('00000'));
|
|
$this->assertSame(0, $textField->prepValueForDB(0000));
|
|
$this->assertSame('test', $textField->prepValueForDB('test'));
|
|
$this->assertSame(123, $textField->prepValueForDB(123));
|
|
unset($textField);
|
|
|
|
/* Time behaviour */
|
|
$time = singleton('Time');
|
|
$time->setValue('00:01am');
|
|
$this->assertEquals("00:01:00", $time->getValue());
|
|
$time->setValue('00:59am');
|
|
$this->assertEquals("00:59:00", $time->getValue());
|
|
$time->setValue('11:59am');
|
|
$this->assertEquals("11:59:00", $time->getValue());
|
|
$time->setValue('12:00pm');
|
|
$this->assertEquals("12:00:00", $time->getValue());
|
|
$time->setValue('12:59am');
|
|
$this->assertEquals("12:59:00", $time->getValue());
|
|
$time->setValue('1:00pm');
|
|
$this->assertEquals("13:00:00", $time->getValue());
|
|
$time->setValue('11:59pm');
|
|
$this->assertEquals("23:59:00", $time->getValue());
|
|
$time->setValue('00:00am');
|
|
$this->assertEquals("00:00:00", $time->getValue());
|
|
$time->setValue('00:00:00');
|
|
$this->assertEquals("00:00:00", $time->getValue());
|
|
|
|
/* BigInt behaviour */
|
|
$bigInt = singleton('BigInt');
|
|
$bigInt->setValue(PHP_INT_MAX);
|
|
$this->assertEquals(PHP_INT_MAX, $bigInt->getValue());
|
|
}
|
|
|
|
/**
|
|
* @dataProvider dataProviderPrepValueForDBArrayValue
|
|
*/
|
|
public function testPrepValueForDBArrayValue($dbFieldName, $scalarValueOnly, $extraArgs = array())
|
|
{
|
|
$reflection = new ReflectionClass($dbFieldName);
|
|
/** @var DBField $dbField */
|
|
$dbField = $reflection->newInstanceArgs($extraArgs);
|
|
$dbField->setName('SomeField');
|
|
$payload = array('GREATEST(0,?)' => '2');
|
|
$preparedValue = $dbField->prepValueForDB($payload);
|
|
$this->assertTrue(
|
|
!$scalarValueOnly || !is_array($preparedValue),
|
|
'`prepValueForDB` can not return an array if scalarValueOnly is true'
|
|
);
|
|
$this->assertEquals($scalarValueOnly, $dbField->scalarValueOnly());
|
|
}
|
|
|
|
public function dataProviderPrepValueForDBArrayValue()
|
|
{
|
|
return array(
|
|
array('BigInt', true),
|
|
array('Boolean', true),
|
|
array('Currency', true),
|
|
array('Date', true),
|
|
array('SS_Datetime', true),
|
|
array('DBLocale', true),
|
|
array('Decimal', true),
|
|
array('Double', true),
|
|
array('Enum', true),
|
|
array('Float', true),
|
|
array('ForeignKey', true, array('SomeField')),
|
|
array('HTMLText', true),
|
|
array('HTMLVarchar', true),
|
|
array('Int', true),
|
|
array('Money', false),
|
|
array('MultiEnum', true, array('SomeField', array('One', 'Two', 'Three'))),
|
|
array('Percentage', true),
|
|
array('PolymorphicForeignKey', false, array('SomeField')),
|
|
array('PrimaryKey', true, array('SomeField', singleton('Image'))),
|
|
array('Text', true),
|
|
array('Time', true),
|
|
array('Varchar', true),
|
|
array('Year', true),
|
|
);
|
|
}
|
|
|
|
public function testExists() {
|
|
$varcharField = new Varchar("testfield");
|
|
$this->assertTrue($varcharField->getNullifyEmpty());
|
|
$varcharField->setValue('abc');
|
|
$this->assertTrue($varcharField->exists());
|
|
$varcharField->setValue('');
|
|
$this->assertFalse($varcharField->exists());
|
|
$varcharField->setValue(null);
|
|
$this->assertFalse($varcharField->exists());
|
|
|
|
$varcharField = new Varchar("testfield", 50, array('nullifyEmpty'=>false));
|
|
$this->assertFalse($varcharField->getNullifyEmpty());
|
|
$varcharField->setValue('abc');
|
|
$this->assertTrue($varcharField->exists());
|
|
$varcharField->setValue('');
|
|
$this->assertTrue($varcharField->exists());
|
|
$varcharField->setValue(null);
|
|
$this->assertFalse($varcharField->exists());
|
|
|
|
$textField = new Text("testfield");
|
|
$this->assertTrue($textField->getNullifyEmpty());
|
|
$textField->setValue('abc');
|
|
$this->assertTrue($textField->exists());
|
|
$textField->setValue('');
|
|
$this->assertFalse($textField->exists());
|
|
$textField->setValue(null);
|
|
$this->assertFalse($textField->exists());
|
|
|
|
$textField = new Text("testfield", array('nullifyEmpty'=>false));
|
|
$this->assertFalse($textField->getNullifyEmpty());
|
|
$textField->setValue('abc');
|
|
$this->assertTrue($textField->exists());
|
|
$textField->setValue('');
|
|
$this->assertTrue($textField->exists());
|
|
$textField->setValue(null);
|
|
$this->assertFalse($textField->exists());
|
|
}
|
|
|
|
public function testStringFieldsWithMultibyteData() {
|
|
$plainFields = array('Varchar', 'Text');
|
|
$htmlFields = array('HTMLVarchar', 'HTMLText');
|
|
$allFields = array_merge($plainFields, $htmlFields);
|
|
|
|
$value = 'üåäöÜÅÄÖ';
|
|
foreach ($allFields as $stringField) {
|
|
$stringField = DBField::create_field($stringField, $value);
|
|
for ($i = 1; $i < mb_strlen($value); $i++) {
|
|
$expected = mb_substr($value, 0, $i) . '...';
|
|
$this->assertEquals($expected, $stringField->LimitCharacters($i));
|
|
}
|
|
}
|
|
|
|
$value = '<p>üåäö&ÜÅÄÖ</p>';
|
|
foreach ($htmlFields as $stringField) {
|
|
$stringField = DBField::create_field($stringField, $value);
|
|
$this->assertEquals('üåäö&ÜÅÄ...', $stringField->LimitCharacters(8));
|
|
}
|
|
|
|
$this->assertEquals('ÅÄÖ', DBField::create_field('Text', 'åäö')->UpperCase());
|
|
$this->assertEquals('åäö', DBField::create_field('Text', 'ÅÄÖ')->LowerCase());
|
|
}
|
|
|
|
public function testIntFloatPhp5Behaviour() {
|
|
if (PHP_MAJOR_VERSION < 7) {
|
|
// PHP 5 - Int class exists and is an instance of DBInt
|
|
// Can't use the reserved words for these classes or we'll get a compile error on PHP7
|
|
$classname = "int";
|
|
$obj = new $classname();
|
|
$this->assertInstanceOf('DBInt', $obj);
|
|
|
|
$classname = "float";
|
|
$obj = new $classname();
|
|
$this->assertInstanceOf('DBFloat', $obj);
|
|
|
|
} else {
|
|
// PHP 7 - classes don't exist
|
|
$this->assertFalse(class_exists("Int"));
|
|
$this->assertFalse(class_exists("Float"));
|
|
}
|
|
|
|
}
|
|
}
|
|
|
|
|