2012-01-31 11:44:16 +01:00
|
|
|
<?php
|
2015-08-30 17:02:55 +12:00
|
|
|
|
2016-10-14 14:30:05 +13:00
|
|
|
namespace SilverStripe\ORM\Tests;
|
2016-06-15 16:03:16 +12:00
|
|
|
|
2016-09-14 18:02:20 +12:00
|
|
|
use SilverStripe\Core\Object;
|
2016-06-15 16:03:16 +12:00
|
|
|
use SilverStripe\ORM\FieldType\DBField;
|
|
|
|
use SilverStripe\ORM\FieldType\DBString;
|
2016-08-19 10:51:35 +12:00
|
|
|
use SilverStripe\Dev\SapphireTest;
|
2016-10-14 14:30:05 +13:00
|
|
|
use SilverStripe\ORM\Tests\DBStringTest\MyStringField;
|
2012-01-31 11:44:16 +01:00
|
|
|
|
2016-12-16 17:34:21 +13:00
|
|
|
class DBStringTest extends SapphireTest
|
|
|
|
{
|
2013-05-30 09:26:58 +01:00
|
|
|
|
2016-12-16 17:34:21 +13:00
|
|
|
/**
|
|
|
|
* @covers \SilverStripe\ORM\FieldType\DBField::forTemplate()
|
|
|
|
*/
|
|
|
|
public function testForTemplate()
|
|
|
|
{
|
|
|
|
$this->assertEquals(
|
|
|
|
"this is<br />\na test!",
|
|
|
|
DBField::create_field(MyStringField::class, "this is\na test!")->forTemplate()
|
|
|
|
);
|
|
|
|
}
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2016-12-16 17:34:21 +13:00
|
|
|
public function testDefault()
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* @var DBString $dbField
|
|
|
|
*/
|
|
|
|
$dbField = Object::create_from_string(
|
|
|
|
DBStringTest\MyStringField::class."(['default' => 'Here is my default text'])",
|
|
|
|
'Myfield'
|
|
|
|
);
|
|
|
|
$this->assertEquals(
|
|
|
|
"Here is my default text",
|
|
|
|
$dbField->getDefaultValue()
|
|
|
|
);
|
|
|
|
}
|
2016-09-14 18:02:20 +12:00
|
|
|
|
2016-12-16 17:34:21 +13:00
|
|
|
/**
|
|
|
|
* @covers \SilverStripe\ORM\FieldType\DBString::LowerCase()
|
|
|
|
*/
|
|
|
|
public function testLowerCase()
|
|
|
|
{
|
|
|
|
$this->assertEquals(
|
|
|
|
'this is a test!',
|
|
|
|
DBField::create_field(MyStringField::class, 'This is a TEST!')->LowerCase()
|
|
|
|
);
|
|
|
|
}
|
2012-01-31 11:44:16 +01:00
|
|
|
|
2016-12-16 17:34:21 +13:00
|
|
|
/**
|
|
|
|
* @covers \SilverStripe\ORM\FieldType\DBString::UpperCase()
|
|
|
|
*/
|
|
|
|
public function testUpperCase()
|
|
|
|
{
|
|
|
|
$this->assertEquals(
|
|
|
|
'THIS IS A TEST!',
|
|
|
|
DBField::create_field(MyStringField::class, 'This is a TEST!')->UpperCase()
|
|
|
|
);
|
|
|
|
}
|
2012-01-31 11:44:16 +01:00
|
|
|
|
2016-12-16 17:34:21 +13:00
|
|
|
public function testExists()
|
|
|
|
{
|
|
|
|
// True exists
|
|
|
|
$this->assertTrue(DBField::create_field(MyStringField::class, true)->exists());
|
|
|
|
$this->assertTrue(DBField::create_field(MyStringField::class, '0')->exists());
|
|
|
|
$this->assertTrue(DBField::create_field(MyStringField::class, '1')->exists());
|
|
|
|
$this->assertTrue(DBField::create_field(MyStringField::class, 1)->exists());
|
|
|
|
$this->assertTrue(DBField::create_field(MyStringField::class, 1.1)->exists());
|
2015-04-01 14:31:55 +13:00
|
|
|
|
2016-12-16 17:34:21 +13:00
|
|
|
// false exists
|
|
|
|
$this->assertFalse(DBField::create_field(MyStringField::class, false)->exists());
|
|
|
|
$this->assertFalse(DBField::create_field(MyStringField::class, '')->exists());
|
|
|
|
$this->assertFalse(DBField::create_field(MyStringField::class, null)->exists());
|
|
|
|
$this->assertFalse(DBField::create_field(MyStringField::class, 0)->exists());
|
|
|
|
$this->assertFalse(DBField::create_field(MyStringField::class, 0.0)->exists());
|
|
|
|
}
|
2012-01-31 11:44:16 +01:00
|
|
|
}
|