silverstripe-framework/tests/php/ORM/DataListTest.php

1287 lines
44 KiB
PHP
Raw Normal View History

<?php
2016-10-14 14:30:05 +13:00
namespace SilverStripe\ORM\Tests;
use SilverStripe\Core\Convert;
use SilverStripe\ORM\DataList;
use SilverStripe\ORM\DB;
2016-09-09 18:43:05 +12:00
use SilverStripe\ORM\Filterable;
use SilverStripe\Dev\SapphireTest;
2016-10-14 14:30:05 +13:00
use SilverStripe\ORM\Tests\DataObjectTest\EquipmentCompany;
use SilverStripe\ORM\Tests\DataObjectTest\Fan;
use SilverStripe\ORM\Tests\DataObjectTest\Player;
use SilverStripe\ORM\Tests\DataObjectTest\Sortable;
use SilverStripe\ORM\Tests\DataObjectTest\SubTeam;
use SilverStripe\ORM\Tests\DataObjectTest\Team;
use SilverStripe\ORM\Tests\DataObjectTest\TeamComment;
use SilverStripe\ORM\Tests\DataObjectTest\ValidatedObject;
class DataListTest extends SapphireTest {
2014-08-15 18:53:05 +12:00
// Borrow the model from DataObjectTest
protected static $fixture_file = 'DataObjectTest.yml';
2016-11-13 20:35:43 +13:00
protected function getExtraDataObjects()
{
return array_merge(
DataObjectTest::$extra_data_objects,
ManyManyListTest::$extra_data_objects
);
}
public function testFilterDataObjectByCreatedDate() {
// create an object to test with
2016-10-14 14:30:05 +13:00
$obj1 = new ValidatedObject();
$obj1->Name = 'test obj 1';
$obj1->write();
$this->assertTrue($obj1->isInDB());
// reload the object from the database and reset its Created timestamp to a known value
2016-10-14 14:30:05 +13:00
$obj1 = ValidatedObject::get()->filter(array('Name' => 'test obj 1'))->first();
$this->assertTrue(is_object($obj1));
$this->assertEquals('test obj 1', $obj1->Name);
$obj1->Created = '2013-01-01 00:00:00';
$obj1->write();
// reload the object again and make sure that our Created date was properly persisted
2016-10-14 14:30:05 +13:00
$obj1 = ValidatedObject::get()->filter(array('Name' => 'test obj 1'))->first();
$this->assertTrue(is_object($obj1));
$this->assertEquals('test obj 1', $obj1->Name);
$this->assertEquals('2013-01-01 00:00:00', $obj1->Created);
// now save a second object to the DB with an automatically-set Created value
2016-10-14 14:30:05 +13:00
$obj2 = new ValidatedObject();
$obj2->Name = 'test obj 2';
$obj2->write();
$this->assertTrue($obj2->isInDB());
// and a third object
2016-10-14 14:30:05 +13:00
$obj3 = new ValidatedObject();
$obj3->Name = 'test obj 3';
$obj3->write();
$this->assertTrue($obj3->isInDB());
// now test the filtering based on Created timestamp
2016-10-14 14:30:05 +13:00
$list = ValidatedObject::get()
->filter(array('Created:GreaterThan' => '2013-02-01 00:00:00'))
->toArray();
$this->assertEquals(2, count($list));
}
public function testSubtract(){
2016-10-14 14:30:05 +13:00
$comment1 = $this->objFromFixture(DataObjectTest\TeamComment::class, 'comment1');
$subtractList = TeamComment::get()->filter('ID', $comment1->ID);
$fullList = TeamComment::get();
$newList = $fullList->subtract($subtractList);
$this->assertEquals(2, $newList->Count(), 'List should only contain two objects after subtraction');
}
2014-08-15 18:53:05 +12:00
public function testSubtractBadDataclassThrowsException(){
$this->setExpectedException('InvalidArgumentException');
2016-10-14 14:30:05 +13:00
$teamsComments = TeamComment::get();
$teams = Team::get();
$teamsComments->subtract($teams);
}
2014-08-15 18:53:05 +12:00
public function testListCreationSortAndLimit() {
// By default, a DataList will contain all items of that class
2016-10-14 14:30:05 +13:00
$list = TeamComment::get()->sort('ID');
2014-08-15 18:53:05 +12:00
// We can iterate on the DataList
$names = array();
foreach($list as $item) {
$names[] = $item->Name;
}
$this->assertEquals(array('Joe', 'Bob', 'Phil'), $names);
2014-08-15 18:53:05 +12:00
// If we don't want to iterate, we can extract a single column from the list with column()
$this->assertEquals(array('Joe', 'Bob', 'Phil'), $list->column('Name'));
2014-08-15 18:53:05 +12:00
// We can sort a list
$list = $list->sort('Name');
$this->assertEquals(array('Bob', 'Joe', 'Phil'), $list->column('Name'));
2014-08-15 18:53:05 +12:00
// We can also restrict the output to a range
$this->assertEquals(array('Joe', 'Phil'), $list->limit(2, 1)->column('Name'));
}
public function testLimitAndOffset() {
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
$check = $list->limit(3);
$this->assertEquals(3, $check->count());
$check = $list->limit(1);
$this->assertEquals(1, $check->count());
$check = $list->limit(1, 1);
$this->assertEquals(1, $check->count());
$check = $list->limit(false);
$this->assertEquals(3, $check->count());
$check = $list->limit(null);
$this->assertEquals(3, $check->count());
$check = $list->limit(null, 2);
$this->assertEquals(1, $check->count());
// count()/first()/last() methods may alter limit/offset, so run the query and manually check the count
$check = $list->limit(null, 1)->toArray();
$this->assertEquals(2, count($check));
}
2014-08-15 18:53:05 +12:00
public function testDistinct() {
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
2014-11-19 11:05:07 +13:00
$this->assertContains('SELECT DISTINCT', $list->dataQuery()->sql($params), 'Query is set as distinct by default');
$list = $list->distinct(false);
2014-11-19 11:05:07 +13:00
$this->assertNotContains('SELECT DISTINCT', $list->dataQuery()->sql($params), 'Query does not contain distinct');
$list = $list->distinct(true);
2014-11-19 11:05:07 +13:00
$this->assertContains('SELECT DISTINCT', $list->dataQuery()->sql($params), 'Query contains distinct');
}
public function testDataClass() {
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
$this->assertEquals(DataObjectTest\TeamComment::class,$list->dataClass());
}
2014-08-15 18:53:05 +12:00
2015-02-27 00:10:32 +00:00
public function testDataClassCaseInsensitive() {
2016-10-14 14:30:05 +13:00
$list = DataList::create(strtolower(DataObjectTest\TeamComment::class));
2015-02-27 00:10:32 +00:00
$this->assertTrue($list->exists());
}
public function testClone() {
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
$this->assertEquals($list, clone($list));
}
2014-08-15 18:53:05 +12:00
public function testSql() {
$db = DB::get_conn();
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
$expected = 'SELECT DISTINCT "DataObjectTest_TeamComment"."ClassName", '
. '"DataObjectTest_TeamComment"."LastEdited", "DataObjectTest_TeamComment"."Created", '
. '"DataObjectTest_TeamComment"."Name", "DataObjectTest_TeamComment"."Comment", '
. '"DataObjectTest_TeamComment"."TeamID", "DataObjectTest_TeamComment"."ID", '
. 'CASE WHEN "DataObjectTest_TeamComment"."ClassName" IS NOT NULL '
. 'THEN "DataObjectTest_TeamComment"."ClassName" ELSE '
2016-10-14 14:30:05 +13:00
. $db->quoteString(DataObjectTest\TeamComment::class)
. ' END AS "RecordClassName" FROM "DataObjectTest_TeamComment"'
. ' ORDER BY "DataObjectTest_TeamComment"."Name" ASC';
$this->assertSQLEquals($expected, $list->sql($parameters));
}
2014-08-15 18:53:05 +12:00
public function testInnerJoin() {
$db = DB::get_conn();
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
$list = $list->innerJoin(
'DataObjectTest_Team',
'"DataObjectTest_Team"."ID" = "DataObjectTest_TeamComment"."TeamID"',
'Team'
);
$expected = 'SELECT DISTINCT "DataObjectTest_TeamComment"."ClassName", '
. '"DataObjectTest_TeamComment"."LastEdited", "DataObjectTest_TeamComment"."Created", '
. '"DataObjectTest_TeamComment"."Name", "DataObjectTest_TeamComment"."Comment", '
. '"DataObjectTest_TeamComment"."TeamID", "DataObjectTest_TeamComment"."ID", '
. 'CASE WHEN "DataObjectTest_TeamComment"."ClassName" IS NOT NULL'
. ' THEN "DataObjectTest_TeamComment"."ClassName" ELSE '
2016-10-14 14:30:05 +13:00
. $db->quoteString(DataObjectTest\TeamComment::class)
. ' END AS "RecordClassName" FROM "DataObjectTest_TeamComment" INNER JOIN '
. '"DataObjectTest_Team" AS "Team" ON "DataObjectTest_Team"."ID" = '
. '"DataObjectTest_TeamComment"."TeamID"'
. ' ORDER BY "DataObjectTest_TeamComment"."Name" ASC';
$this->assertSQLEquals($expected, $list->sql($parameters));
$this->assertEmpty($parameters);
}
public function testInnerJoinParameterised() {
$db = DB::get_conn();
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
$list = $list->innerJoin(
'DataObjectTest_Team',
'"DataObjectTest_Team"."ID" = "DataObjectTest_TeamComment"."TeamID" '
. 'AND "DataObjectTest_Team"."Title" LIKE ?',
'Team',
20,
array('Team%')
);
$expected = 'SELECT DISTINCT "DataObjectTest_TeamComment"."ClassName", '
. '"DataObjectTest_TeamComment"."LastEdited", "DataObjectTest_TeamComment"."Created", '
. '"DataObjectTest_TeamComment"."Name", "DataObjectTest_TeamComment"."Comment", '
. '"DataObjectTest_TeamComment"."TeamID", "DataObjectTest_TeamComment"."ID", '
. 'CASE WHEN "DataObjectTest_TeamComment"."ClassName" IS NOT NULL'
. ' THEN "DataObjectTest_TeamComment"."ClassName" ELSE '
2016-10-14 14:30:05 +13:00
. $db->quoteString(DataObjectTest\TeamComment::class)
. ' END AS "RecordClassName" FROM "DataObjectTest_TeamComment" INNER JOIN '
. '"DataObjectTest_Team" AS "Team" ON "DataObjectTest_Team"."ID" = '
. '"DataObjectTest_TeamComment"."TeamID" '
. 'AND "DataObjectTest_Team"."Title" LIKE ?'
. ' ORDER BY "DataObjectTest_TeamComment"."Name" ASC';
$this->assertSQLEquals($expected, $list->sql($parameters));
$this->assertEquals(array('Team%'), $parameters);
}
2014-08-15 18:53:05 +12:00
public function testLeftJoin() {
$db = DB::get_conn();
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
$list = $list->leftJoin(
'DataObjectTest_Team',
'"DataObjectTest_Team"."ID" = "DataObjectTest_TeamComment"."TeamID"',
'Team'
);
$expected = 'SELECT DISTINCT "DataObjectTest_TeamComment"."ClassName", '
. '"DataObjectTest_TeamComment"."LastEdited", "DataObjectTest_TeamComment"."Created", '
. '"DataObjectTest_TeamComment"."Name", "DataObjectTest_TeamComment"."Comment", '
. '"DataObjectTest_TeamComment"."TeamID", "DataObjectTest_TeamComment"."ID", '
. 'CASE WHEN "DataObjectTest_TeamComment"."ClassName" IS NOT NULL '
. 'THEN "DataObjectTest_TeamComment"."ClassName" ELSE '
2016-10-14 14:30:05 +13:00
. $db->quoteString(DataObjectTest\TeamComment::class)
. ' END AS "RecordClassName" FROM "DataObjectTest_TeamComment" LEFT JOIN "DataObjectTest_Team" '
. 'AS "Team" ON "DataObjectTest_Team"."ID" = "DataObjectTest_TeamComment"."TeamID"'
. ' ORDER BY "DataObjectTest_TeamComment"."Name" ASC';
$this->assertSQLEquals($expected, $list->sql($parameters));
$this->assertEmpty($parameters);
}
2014-08-15 18:53:05 +12:00
public function testLeftJoinParameterised() {
$db = DB::get_conn();
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
$list = $list->leftJoin(
'DataObjectTest_Team',
'"DataObjectTest_Team"."ID" = "DataObjectTest_TeamComment"."TeamID" '
. 'AND "DataObjectTest_Team"."Title" LIKE ?',
'Team',
20,
array('Team%')
);
$expected = 'SELECT DISTINCT "DataObjectTest_TeamComment"."ClassName", '
. '"DataObjectTest_TeamComment"."LastEdited", "DataObjectTest_TeamComment"."Created", '
. '"DataObjectTest_TeamComment"."Name", "DataObjectTest_TeamComment"."Comment", '
. '"DataObjectTest_TeamComment"."TeamID", "DataObjectTest_TeamComment"."ID", '
. 'CASE WHEN "DataObjectTest_TeamComment"."ClassName" IS NOT NULL'
. ' THEN "DataObjectTest_TeamComment"."ClassName" ELSE '
2016-10-14 14:30:05 +13:00
. $db->quoteString(DataObjectTest\TeamComment::class)
. ' END AS "RecordClassName" FROM "DataObjectTest_TeamComment" LEFT JOIN '
. '"DataObjectTest_Team" AS "Team" ON "DataObjectTest_Team"."ID" = '
. '"DataObjectTest_TeamComment"."TeamID" '
. 'AND "DataObjectTest_Team"."Title" LIKE ?'
. ' ORDER BY "DataObjectTest_TeamComment"."Name" ASC';
$this->assertSQLEquals($expected, $list->sql($parameters));
$this->assertEquals(array('Team%'), $parameters);
}
public function testToNestedArray() {
2016-10-14 14:30:05 +13:00
$list = TeamComment::get()->sort('ID');
$nestedArray = $list->toNestedArray();
$expected = array(
0=>
array(
2016-10-14 14:30:05 +13:00
'ClassName'=>DataObjectTest\TeamComment::class,
'Name'=>'Joe',
'Comment'=>'This is a team comment by Joe',
2016-10-14 14:30:05 +13:00
'TeamID'=> $this->objFromFixture(DataObjectTest\TeamComment::class, 'comment1')->TeamID,
),
1=>
array(
2016-10-14 14:30:05 +13:00
'ClassName'=>DataObjectTest\TeamComment::class,
'Name'=>'Bob',
'Comment'=>'This is a team comment by Bob',
2016-10-14 14:30:05 +13:00
'TeamID'=> $this->objFromFixture(DataObjectTest\TeamComment::class, 'comment2')->TeamID,
),
2=>
array(
2016-10-14 14:30:05 +13:00
'ClassName'=>DataObjectTest\TeamComment::class,
'Name'=>'Phil',
'Comment'=>'Phil is a unique guy, and comments on team2',
2016-10-14 14:30:05 +13:00
'TeamID'=> $this->objFromFixture(DataObjectTest\TeamComment::class, 'comment3')->TeamID,
),
);
$this->assertEquals(3, count($nestedArray));
$this->assertEquals($expected[0]['Name'], $nestedArray[0]['Name']);
$this->assertEquals($expected[1]['Comment'], $nestedArray[1]['Comment']);
$this->assertEquals($expected[2]['TeamID'], $nestedArray[2]['TeamID']);
}
2014-08-15 18:53:05 +12:00
public function testMap() {
2016-10-14 14:30:05 +13:00
$map = TeamComment::get()->map()->toArray();
$expected = array(
2016-10-14 14:30:05 +13:00
$this->idFromFixture(DataObjectTest\TeamComment::class, 'comment1') => 'Joe',
$this->idFromFixture(DataObjectTest\TeamComment::class, 'comment2') => 'Bob',
$this->idFromFixture(DataObjectTest\TeamComment::class, 'comment3') => 'Phil'
);
2014-08-15 18:53:05 +12:00
$this->assertEquals($expected, $map);
2016-10-14 14:30:05 +13:00
$otherMap = TeamComment::get()->map('Name', 'TeamID')->toArray();
$otherExpected = array(
2016-10-14 14:30:05 +13:00
'Joe' => $this->objFromFixture(DataObjectTest\TeamComment::class, 'comment1')->TeamID,
'Bob' => $this->objFromFixture(DataObjectTest\TeamComment::class, 'comment2')->TeamID,
'Phil' => $this->objFromFixture(DataObjectTest\TeamComment::class, 'comment3')->TeamID
);
2014-08-15 18:53:05 +12:00
$this->assertEquals($otherExpected, $otherMap);
}
2014-08-15 18:53:05 +12:00
public function testAmbiguousAggregate() {
// Test that we avoid ambiguity error when a field exists on two joined tables
// Fetch the sponsors in a round-about way to simulate this
2016-10-14 14:30:05 +13:00
$teamID = $this->idFromFixture(DataObjectTest\Team::class,'team2');
$sponsors = EquipmentCompany::get()->filter('SponsoredTeams.ID', $teamID);
$this->assertNotNull($sponsors->Max('ID'));
$this->assertNotNull($sponsors->Min('ID'));
$this->assertNotNull($sponsors->Avg('ID'));
$this->assertNotNull($sponsors->Sum('ID'));
// Test non-orm many_many_extraFields
2016-11-24 13:15:49 +00:00
$company = $this->objFromFixture(EquipmentCompany::class, 'equipmentcompany1');
$this->assertNotNull($company->SponsoredTeams()->Max('SponsorFee'));
$this->assertNotNull($company->SponsoredTeams()->Min('SponsorFee'));
$this->assertNotNull($company->SponsoredTeams()->Avg('SponsorFee'));
$this->assertNotNull($company->SponsoredTeams()->Sum('SponsorFee'));
}
public function testEach() {
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
2014-08-15 18:53:05 +12:00
$count = 0;
2016-10-14 14:30:05 +13:00
$list->each(function($item) use (&$count) {
$count++;
2016-10-14 14:30:05 +13:00
$this->assertInstanceOf(TeamComment::class, $item);
});
2014-08-15 18:53:05 +12:00
2016-10-14 14:30:05 +13:00
$this->assertEquals($count, $list->count());
}
2013-06-08 20:29:36 +12:00
public function testWhere() {
// We can use raw SQL queries with where. This is only recommended for advanced uses;
// if you can, you should use filter().
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
2014-08-15 18:53:05 +12:00
// where() returns a new DataList, like all the other modifiers, so it can be chained.
$list2 = $list->where('"Name" = \'Joe\'');
$this->assertEquals(array('This is a team comment by Joe'), $list2->column('Comment'));
2014-08-15 18:53:05 +12:00
// The where() clauses are chained together with AND
$list3 = $list2->where('"Name" = \'Bob\'');
$this->assertEquals(array(), $list3->column('Comment'));
}
2014-08-15 18:53:05 +12:00
/**
* Test DataList->byID()
*/
public function testByID() {
// We can get a single item by ID.
2016-10-14 14:30:05 +13:00
$id = $this->idFromFixture(DataObjectTest\Team::class,'team2');
$team = Team::get()->byID($id);
2014-08-15 18:53:05 +12:00
// byID() returns a DataObject, rather than a DataList
2016-10-14 14:30:05 +13:00
$this->assertInstanceOf(DataObjectTest\Team::class, $team);
2011-11-15 16:51:17 +01:00
$this->assertEquals('Team 2', $team->Title);
// Assert that filtering on ID searches by the base table, not the child table field
2016-10-14 14:30:05 +13:00
$query = SubTeam::get()->filter('ID', 4)->sql($parameters);
$this->assertContains('WHERE ("DataObjectTest_Team"."ID" = ?)', $query);
$this->assertNotContains('WHERE ("DataObjectTest_SubTeam"."ID" = ?)', $query);
}
2014-08-15 18:53:05 +12:00
public function testByIDs() {
2016-10-14 14:30:05 +13:00
$knownIDs = $this->allFixtureIDs(DataObjectTest\Player::class);
$removedID = array_pop($knownIDs);
2016-10-14 14:30:05 +13:00
$filteredPlayers = Player::get()->byIDs($knownIDs);
foreach ($filteredPlayers as $player) {
$this->assertContains($player->ID, $knownIDs);
$this->assertNotEquals($removedID, $player->ID);
}
}
/**
* Test DataList->removeByID()
*/
public function testRemoveByID() {
2016-10-14 14:30:05 +13:00
$list = Team::get();
$id = $this->idFromFixture(DataObjectTest\Team::class,'team2');
2014-08-15 18:53:05 +12:00
2011-11-15 16:51:17 +01:00
$this->assertNotNull($list->byID($id));
$list->removeByID($id);
2011-11-15 16:51:17 +01:00
$this->assertNull($list->byID($id));
}
2014-08-15 18:53:05 +12:00
/**
* Test DataList->canSortBy()
*/
public function testCanSortBy() {
2011-11-15 16:51:17 +01:00
// Basic check
2016-10-14 14:30:05 +13:00
$team = Team::get();
2011-11-15 16:51:17 +01:00
$this->assertTrue($team->canSortBy("Title"));
$this->assertFalse($team->canSortBy("SomethingElse"));
2014-08-15 18:53:05 +12:00
2011-11-15 16:51:17 +01:00
// Subclasses
2016-10-14 14:30:05 +13:00
$subteam = SubTeam::get();
2011-11-15 16:51:17 +01:00
$this->assertTrue($subteam->canSortBy("Title"));
$this->assertTrue($subteam->canSortBy("SubclassDatabaseField"));
}
2014-08-15 18:53:05 +12:00
public function testDataListArrayAccess() {
2016-10-14 14:30:05 +13:00
$list = Team::get()->sort('Title');
2014-08-15 18:53:05 +12:00
// We can use array access to refer to single items in the DataList, as if it were an array
2011-11-15 16:51:17 +01:00
$this->assertEquals("Subteam 1", $list[0]->Title);
$this->assertEquals("Subteam 3", $list[2]->Title);
$this->assertEquals("Team 2", $list[4]->Title);
}
2014-08-15 18:53:05 +12:00
public function testFind() {
2016-10-14 14:30:05 +13:00
$list = Team::get();
$record = $list->find('Title', 'Team 1');
2016-10-14 14:30:05 +13:00
$this->assertEquals($this->idFromFixture(DataObjectTest\Team::class, 'team1'), $record->ID);
}
2014-08-15 18:53:05 +12:00
public function testFindById() {
2016-10-14 14:30:05 +13:00
$list = Team::get();
$record = $list->find('ID', $this->idFromFixture(DataObjectTest\Team::class, 'team1'));
$this->assertEquals('Team 1', $record->Title);
// Test that you can call it twice on the same list
2016-10-14 14:30:05 +13:00
$record = $list->find('ID', $this->idFromFixture(DataObjectTest\Team::class, 'team2'));
$this->assertEquals('Team 2', $record->Title);
}
2014-08-15 18:53:05 +12:00
public function testSimpleSort() {
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
$list = $list->sort('Name');
$this->assertEquals('Bob', $list->first()->Name, 'First comment should be from Bob');
$this->assertEquals('Phil', $list->last()->Name, 'Last comment should be from Phil');
}
2014-08-15 18:53:05 +12:00
public function testSimpleSortOneArgumentASC() {
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
$list = $list->sort('Name ASC');
$this->assertEquals('Bob', $list->first()->Name, 'First comment should be from Bob');
$this->assertEquals('Phil', $list->last()->Name, 'Last comment should be from Phil');
}
2014-08-15 18:53:05 +12:00
public function testSimpleSortOneArgumentDESC() {
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
$list = $list->sort('Name DESC');
$this->assertEquals('Phil', $list->first()->Name, 'Last comment should be from Phil');
$this->assertEquals('Bob', $list->last()->Name, 'First comment should be from Bob');
}
2014-08-15 18:53:05 +12:00
public function testSortOneArgumentMultipleColumns() {
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
$list = $list->sort('TeamID ASC, Name DESC');
$this->assertEquals('Joe', $list->first()->Name, 'First comment should be from Bob');
$this->assertEquals('Phil', $list->last()->Name, 'Last comment should be from Phil');
}
2014-08-15 18:53:05 +12:00
public function testSimpleSortASC() {
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
$list = $list->sort('Name', 'asc');
$this->assertEquals('Bob', $list->first()->Name, 'First comment should be from Bob');
$this->assertEquals('Phil', $list->last()->Name, 'Last comment should be from Phil');
}
2014-08-15 18:53:05 +12:00
public function testSimpleSortDESC() {
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
$list = $list->sort('Name', 'desc');
$this->assertEquals('Phil', $list->first()->Name, 'Last comment should be from Phil');
$this->assertEquals('Bob', $list->last()->Name, 'First comment should be from Bob');
}
2014-08-15 18:53:05 +12:00
public function testSortWithArraySyntaxSortASC() {
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
$list = $list->sort(array('Name'=>'asc'));
$this->assertEquals('Bob', $list->first()->Name, 'First comment should be from Bob');
$this->assertEquals('Phil', $list->last()->Name, 'Last comment should be from Phil');
}
2014-08-15 18:53:05 +12:00
public function testSortWithArraySyntaxSortDESC() {
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
$list = $list->sort(array('Name'=>'desc'));
$this->assertEquals('Phil', $list->first()->Name, 'Last comment should be from Phil');
$this->assertEquals('Bob', $list->last()->Name, 'First comment should be from Bob');
}
2014-08-15 18:53:05 +12:00
public function testSortWithMultipleArraySyntaxSort() {
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
$list = $list->sort(array('TeamID'=>'asc','Name'=>'desc'));
$this->assertEquals('Joe', $list->first()->Name, 'First comment should be from Bob');
$this->assertEquals('Phil', $list->last()->Name, 'Last comment should be from Phil');
}
2014-08-15 18:53:05 +12:00
public function testSortWithCompositeSyntax() {
// Phil commented on team with founder surname "Aaron"
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
$list = $list->sort('Team.Founder.Surname', 'asc');
$this->assertEquals('Phil', $list->first()->Name);
$list = $list->sort('Team.Founder.Surname', 'desc');
$this->assertEquals('Phil', $list->last()->Name);
}
public function testSortInvalidParameters() {
$this->setExpectedException(
'InvalidArgumentException',
2016-10-14 14:30:05 +13:00
'Fans is not a linear relation on model '.Player::class
);
2016-10-14 14:30:05 +13:00
$list = Team::get();
$list->sort('Founder.Fans.Surname'); // Can't sort on has_many
}
public function testSortNumeric() {
2016-10-14 14:30:05 +13:00
$list = Sortable::get();
$list1 = $list->sort('Sort', 'ASC');
$this->assertEquals(array(
-10,
-2,
-1,
0,
1,
2,
10
), $list1->column('Sort'));
}
public function testSortMixedCase() {
2016-10-14 14:30:05 +13:00
$list = Sortable::get();
$list1 = $list->sort('Name', 'ASC');
$this->assertEquals(array(
'Bob',
'bonny',
'jane',
'John',
'sam',
'Steve',
'steven'
), $list1->column('Name'));
}
/**
* Test DataList->canFilterBy()
*/
public function testCanFilterBy() {
// Basic check
2016-10-14 14:30:05 +13:00
$team = Team::get();
$this->assertTrue($team->canFilterBy("Title"));
$this->assertFalse($team->canFilterBy("SomethingElse"));
// Has one
$this->assertTrue($team->canFilterBy("CaptainID"));
$this->assertTrue($team->canFilterBy("Captain.ShirtNumber"));
$this->assertFalse($team->canFilterBy("SomethingElse.ShirtNumber"));
$this->assertFalse($team->canFilterBy("Captain.SomethingElse"));
$this->assertTrue($team->canFilterBy("Captain.FavouriteTeam.Captain.ShirtNumber"));
// Has many
$this->assertTrue($team->canFilterBy("Fans.Name"));
$this->assertFalse($team->canFilterBy("SomethingElse.Name"));
$this->assertFalse($team->canFilterBy("Fans.SomethingElse"));
// Many many
$this->assertTrue($team->canFilterBy("Players.FirstName"));
$this->assertFalse($team->canFilterBy("SomethingElse.FirstName"));
$this->assertFalse($team->canFilterBy("Players.SomethingElse"));
// Subclasses
2016-10-14 14:30:05 +13:00
$subteam = SubTeam::get();
$this->assertTrue($subteam->canFilterBy("Title"));
$this->assertTrue($subteam->canFilterBy("SubclassDatabaseField"));
}
/**
* $list->filter('Name', 'bob'); // only bob in the list
*/
public function testSimpleFilter() {
2016-10-14 14:30:05 +13:00
$list = Team::get();
$list = $list->filter('Title','Team 2');
$this->assertEquals(1, $list->count());
$this->assertEquals('Team 2', $list->first()->Title, 'List should only contain Team 2');
$this->assertEquals('Team 2', $list->last()->Title, 'Last should only contain Team 2');
}
2014-08-15 18:53:05 +12:00
public function testSimpleFilterEndsWith() {
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
$list = $list->filter('Name:EndsWith', 'b');
$this->assertEquals(1, $list->count());
$this->assertEquals('Bob', $list->first()->Name, 'First comment should be from Bob');
}
public function testSimpleFilterExactMatchFilter() {
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
$list = $list->filter('Name:ExactMatch', 'Bob');
$this->assertEquals(1, $list->count());
$this->assertEquals('Bob', $list->first()->Name, 'First comment should be from Bob');
}
public function testSimpleFilterGreaterThanFilter() {
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
$list = $list->filter('TeamID:GreaterThan', $this->idFromFixture(DataObjectTest\Team::class, 'team1'));
$this->assertEquals(1, $list->count());
$this->assertEquals('Phil', $list->first()->Name, 'First comment should be from Phil');
}
public function testSimpleFilterGreaterThanOrEqualFilter() {
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
$list = $list->filter('TeamID:GreaterThanOrEqual',
2016-10-14 14:30:05 +13:00
$this->idFromFixture(DataObjectTest\Team::class, 'team1'))->sort("ID");
$this->assertEquals(3, $list->count());
$this->assertEquals('Joe', $list->first()->Name, 'First comment should be from Joe');
$this->assertEquals('Phil', $list->last()->Name, 'Last comment should be from Phil');
}
public function testSimpleFilterLessThanFilter() {
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
$list = $list->filter('TeamID:LessThan',
2016-10-14 14:30:05 +13:00
$this->idFromFixture(DataObjectTest\Team::class, 'team2'))->sort('Name');
$this->assertEquals(2, $list->count());
$this->assertEquals('Bob', $list->first()->Name, 'First comment should be from Bob');
$this->assertEquals('Joe', $list->Last()->Name, 'Last comment should be from Joe');
}
public function testSimpleFilterLessThanOrEqualFilter() {
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
$list = $list->filter('TeamID:LessThanOrEqual',
2016-10-14 14:30:05 +13:00
$this->idFromFixture(DataObjectTest\Team::class, 'team1'))->sort('ID');
$this->assertEquals(2, $list->count());
$this->assertEquals('Joe', $list->first()->Name, 'First comment should be from Joe');
$this->assertEquals('Bob', $list->Last()->Name, 'Last comment should be from Bob');
}
public function testSimplePartialMatchFilter() {
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
$list = $list->filter('Name:PartialMatch', 'o')->sort('Name');
$this->assertEquals(2, $list->count());
$this->assertEquals('Bob', $list->first()->Name, 'First comment should be from Bob');
$this->assertEquals('Joe', $list->last()->Name, 'First comment should be from Joe');
}
public function testSimpleFilterStartsWith() {
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
$list = $list->filter('Name:StartsWith', 'B');
$this->assertEquals(1, $list->count());
$this->assertEquals('Bob', $list->first()->Name, 'First comment should be from Bob');
}
public function testSimpleFilterWithNonExistingComparisator() {
$this->setExpectedException(
'ReflectionException',
'Class DataListFilter.Bogus does not exist'
);
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
$list->filter('Comment:Bogus', 'team comment');
}
public function testInvalidModifier() {
// Invalid modifiers are treated as failed filter construction
$this->setExpectedException(
'ReflectionException',
'Class DataListFilter.invalidmodifier does not exist'
);
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
$list->filter('Comment:invalidmodifier', 'team comment');
}
/**
* $list->filter('Name', array('aziz', 'bob'); // aziz and bob in list
*/
public function testSimpleFilterWithMultiple() {
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
$list = $list->filter('Name', array('Bob','Phil'));
$list = $list->sort('Name', 'ASC');
$this->assertEquals(2, $list->count());
$this->assertEquals('Bob', $list->first()->Name, 'First comment should be from Bob');
$this->assertEquals('Phil', $list->last()->Name, 'Last comment should be from Phil');
}
2014-08-15 18:53:05 +12:00
public function testMultipleFilterWithNoMatch() {
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
$list = $list->filter(array('Name'=>'Bob', 'Comment'=>'Phil is a unique guy, and comments on team2'));
$this->assertEquals(0, $list->count());
}
/**
* $list->filter(array('Name'=>'bob, 'Age'=>21)); // bob with the age 21
*/
public function testFilterMultipleArray() {
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
$list = $list->filter(array('Name'=>'Bob', 'Comment'=>'This is a team comment by Bob'));
$list = $list->sort('Name', 'ASC');
$this->assertEquals(1, $list->count());
$this->assertEquals('Bob', $list->first()->Name, 'Only comment should be from Bob');
}
2014-08-15 18:53:05 +12:00
public function testFilterMultipleWithTwoMatches() {
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
$list = $list->filter(array('TeamID'=>$this->idFromFixture(DataObjectTest\Team::class, 'team1')));
$this->assertEquals(2, $list->count());
}
2014-08-15 18:53:05 +12:00
public function testFilterMultipleWithArrayFilter() {
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
$list = $list->filter(array('Name'=>array('Bob','Phil')));
$list = $list->sort('Name', 'ASC');
$this->assertEquals(2, $list->count(), 'There should be two comments');
$this->assertEquals('Bob', $list->first()->Name, 'First comment should be from Bob');
$this->assertEquals('Phil', $list->last()->Name, 'Last comment should be from Phil');
}
public function testFilterMultipleWithArrayFilterAndModifiers() {
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
$list = $list->filter(array('Name:StartsWith'=>array('Bo', 'Jo')));
$list = $list->sort('Name', 'ASC');
$this->assertEquals(2, $list->count());
$this->assertEquals('Bob', $list->first()->Name);
$this->assertEquals('Joe', $list->last()->Name);
}
2014-08-15 18:53:05 +12:00
/**
* $list->filter(array('Name'=>array('aziz','bob'), 'Age'=>array(21, 43)));
*/
public function testFilterArrayInArray() {
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
$list = $list->filter(array(
'Name'=>array('Bob','Phil'),
2016-10-14 14:30:05 +13:00
'TeamID'=>array($this->idFromFixture(DataObjectTest\Team::class, 'team1'))));
$this->assertEquals(1, $list->count(), 'There should be one comment');
$this->assertEquals('Bob', $list->first()->Name, 'Only comment should be from Bob');
}
public function testFilterWithModifiers() {
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
$nocaseList = $list->filter('Name:nocase', 'bob');
$this->assertEquals(1, $nocaseList->count(), 'There should be one comment');
$caseList = $list->filter('Name:case', 'bob');
$this->assertEquals(0, $caseList->count(), 'There should be no comments');
$gtList = $list->filter('TeamID:GreaterThan:not',
2016-10-14 14:30:05 +13:00
$this->idFromFixture(DataObjectTest\Team::class, 'team1'));
$this->assertEquals(2, $gtList->count());
}
2012-10-12 12:24:03 +02:00
public function testFilterAny() {
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
2012-10-12 12:24:03 +02:00
$list = $list->filterAny('Name', 'Bob');
$this->assertEquals(1, $list->count());
2014-08-15 18:53:05 +12:00
}
2012-10-12 12:24:03 +02:00
public function testFilterAnyMultipleArray() {
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
2012-10-12 12:24:03 +02:00
$list = $list->filterAny(array('Name'=>'Bob', 'Comment'=>'This is a team comment by Bob'));
$this->assertEquals(1, $list->count());
$this->assertEquals('Bob', $list->first()->Name, 'Only comment should be from Bob');
}
public function testFilterAnyOnFilter() {
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
2012-10-12 12:24:03 +02:00
$list = $list->filter(array(
2016-10-14 14:30:05 +13:00
'TeamID'=>$this->idFromFixture(DataObjectTest\Team::class, 'team1')
2012-10-12 12:24:03 +02:00
));
$list = $list->filterAny(array(
'Name'=>array('Phil', 'Joe'),
'Comment'=>'This is a team comment by Bob'
));
$list = $list->sort('Name');
$this->assertEquals(2, $list->count());
$this->assertEquals(
2014-08-15 18:53:05 +12:00
'Bob',
$list->offsetGet(0)->Name,
2012-10-12 12:24:03 +02:00
'Results should include comments from Bob, matched by comment and team'
);
$this->assertEquals(
2014-08-15 18:53:05 +12:00
'Joe',
$list->offsetGet(1)->Name,
2012-10-12 12:24:03 +02:00
'Results should include comments by Joe, matched by name and team (not by comment)'
);
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
2012-10-12 12:24:03 +02:00
$list = $list->filter(array(
2016-10-14 14:30:05 +13:00
'TeamID'=>$this->idFromFixture(DataObjectTest\Team::class, 'team1')
2012-10-12 12:24:03 +02:00
));
$list = $list->filterAny(array(
'Name'=>array('Phil', 'Joe'),
'Comment'=>'This is a team comment by Bob'
));
$list = $list->sort('Name');
$list = $list->filter(array('Name' => 'Bob'));
$this->assertEquals(1, $list->count());
$this->assertEquals(
2014-08-15 18:53:05 +12:00
'Bob',
$list->offsetGet(0)->Name,
2012-10-12 12:24:03 +02:00
'Results should include comments from Bob, matched by name and team'
);
}
2014-08-15 18:53:05 +12:00
2012-10-12 12:24:03 +02:00
public function testFilterAnyMultipleWithArrayFilter() {
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
2012-10-12 12:24:03 +02:00
$list = $list->filterAny(array('Name'=>array('Bob','Phil')));
$this->assertEquals(2, $list->count(), 'There should be two comments');
$this->assertEquals('Bob', $list->first()->Name, 'First comment should be from Bob');
$this->assertEquals('Phil', $list->last()->Name, 'Last comment should be from Phil');
}
2014-08-15 18:53:05 +12:00
2012-10-12 12:24:03 +02:00
public function testFilterAnyArrayInArray() {
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
2012-10-12 12:24:03 +02:00
$list = $list->filterAny(array(
'Name'=>array('Bob','Phil'),
2016-10-14 14:30:05 +13:00
'TeamID'=>array($this->idFromFixture(DataObjectTest\Team::class, 'team1'))))
2012-10-12 12:24:03 +02:00
->sort('Name');
$this->assertEquals(3, $list->count());
$this->assertEquals(
2014-08-15 18:53:05 +12:00
'Bob',
$list->offsetGet(0)->Name,
2012-10-12 12:24:03 +02:00
'Results should include comments from Bob, matched by name and team'
);
$this->assertEquals(
2014-08-15 18:53:05 +12:00
'Joe',
$list->offsetGet(1)->Name,
2012-10-12 12:24:03 +02:00
'Results should include comments by Joe, matched by team (not by name)'
);
$this->assertEquals(
2014-08-15 18:53:05 +12:00
'Phil',
$list->offsetGet(2)->Name,
2012-10-12 12:24:03 +02:00
'Results should include comments from Phil, matched by name (even if he\'s not in Team1)'
);
}
2013-06-08 20:29:36 +12:00
public function testFilterOnJoin() {
2016-10-14 14:30:05 +13:00
$list = TeamComment::get()
2013-06-08 20:29:36 +12:00
->leftJoin('DataObjectTest_Team',
'"DataObjectTest_Team"."ID" = "DataObjectTest_TeamComment"."TeamID"'
)->filter(array(
'Title' => 'Team 1'
));
$this->assertEquals(2, $list->count());
$values = $list->column('Name');
$this->assertEquals(array_intersect($values, array('Joe', 'Bob')), $values);
2013-06-08 20:29:36 +12:00
}
public function testFilterOnImplicitJoin() {
// Many to many
2016-10-14 14:30:05 +13:00
$list = Team::get()
->filter('Players.FirstName', array('Captain', 'Captain 2'));
$this->assertEquals(2, $list->count());
// Has many
2016-10-14 14:30:05 +13:00
$list = Team::get()
->filter('Comments.Name', array('Joe', 'Phil'));
$this->assertEquals(2, $list->count());
// Has one
2016-10-14 14:30:05 +13:00
$list = Player::get()
->filter('FavouriteTeam.Title', 'Team 1');
$this->assertEquals(1, $list->count());
$this->assertEquals('007', $list->first()->ShirtNumber);
}
public function testFilterOnInvalidRelation() {
$this->setExpectedException(
'InvalidArgumentException',
2016-10-14 14:30:05 +13:00
"MascotAnimal is not a relation on model ".Team::class
);
// Filter on missing relation 'MascotAnimal'
2016-10-14 14:30:05 +13:00
Team::get()
->filter('MascotAnimal.Name', 'Richard')
->toArray();
}
public function testFilterAndExcludeById() {
2016-10-14 14:30:05 +13:00
$id = $this->idFromFixture(SubTeam::class, 'subteam1');
$list = SubTeam::get()->filter('ID', $id);
$this->assertEquals($id, $list->first()->ID);
2016-10-14 14:30:05 +13:00
$list = SubTeam::get();
$this->assertEquals(3, count($list));
$this->assertEquals(2, count($list->exclude('ID', $id)));
}
/**
* @skipUpgrade
*/
public function testFilterByNull() {
2016-10-14 14:30:05 +13:00
$list = Fan::get();
// Force DataObjectTest_Fan/fan5::Email to empty string
2016-10-14 14:30:05 +13:00
$fan5id = $this->idFromFixture(Fan::class, 'fan5');
DB::prepared_query("UPDATE \"DataObjectTest_Fan\" SET \"Email\" = '' WHERE \"ID\" = ?", array($fan5id));
// Filter by null email
$nullEmails = $list->filter('Email', null);
$this->assertDOSEquals(array(
array(
'Name' => 'Stephen',
),
array(
'Name' => 'Mitch',
)
), $nullEmails);
// Filter by non-null
$nonNullEmails = $list->filter('Email:not', null);
$this->assertDOSEquals(array(
array(
'Name' => 'Damian',
'Email' => 'damian@thefans.com',
),
array(
'Name' => 'Richard',
'Email' => 'richie@richers.com',
),
array(
'Name' => 'Hamish',
)
), $nonNullEmails);
// Filter by empty only
$emptyOnly = $list->filter('Email', '');
$this->assertDOSEquals(array(
array(
'Name' => 'Hamish',
)
), $emptyOnly);
// Non-empty only. This should include null values, since ExactMatchFilter works around
// the caveat that != '' also excludes null values in ANSI SQL-92 behaviour.
$nonEmptyOnly = $list->filter('Email:not', '');
$this->assertDOSEquals(array(
array(
'Name' => 'Damian',
'Email' => 'damian@thefans.com',
),
array(
'Name' => 'Richard',
'Email' => 'richie@richers.com',
),
array(
'Name' => 'Stephen',
),
array(
'Name' => 'Mitch',
)
), $nonEmptyOnly);
// Filter by many including null, empty string, and non-empty
$items1 = $list->filter('Email', array(null, '', 'damian@thefans.com'));
$this->assertDOSEquals(array(
array(
'Name' => 'Damian',
'Email' => 'damian@thefans.com',
),
array(
'Name' => 'Stephen',
),
array(
'Name' => 'Mitch',
),
array(
'Name' => 'Hamish',
)
), $items1);
// Filter exclusion of above list
$items2 = $list->filter('Email:not', array(null, '', 'damian@thefans.com'));
$this->assertDOSEquals(array(
array(
'Name' => 'Richard',
'Email' => 'richie@richers.com',
),
), $items2);
// Filter by many including empty string and non-empty
$items3 = $list->filter('Email', array('', 'damian@thefans.com'));
$this->assertDOSEquals(array(
array(
'Name' => 'Damian',
'Email' => 'damian@thefans.com',
),
array(
'Name' => 'Hamish',
)
), $items3);
// Filter by many including empty string and non-empty
// This also relies no the workaround for null comparison as in the $nonEmptyOnly test
$items4 = $list->filter('Email:not', array('', 'damian@thefans.com'));
$this->assertDOSEquals(array(
array(
'Name' => 'Richard',
'Email' => 'richie@richers.com',
),
array(
'Name' => 'Stephen',
),
array(
'Name' => 'Mitch',
)
), $items4);
// Filter by many including empty string and non-empty
// The extra null check isn't necessary, but check that this doesn't fail
$items5 = $list->filterAny(array(
'Email:not' => array('', 'damian@thefans.com'),
'Email' => null
));
$this->assertDOSEquals(array(
array(
'Name' => 'Richard',
'Email' => 'richie@richers.com',
),
array(
'Name' => 'Stephen',
),
array(
'Name' => 'Mitch',
)
), $items5);
// Filter by null or empty values
$items6 = $list->filter('Email', array(null, ''));
$this->assertDOSEquals(array(
array(
'Name' => 'Stephen',
),
array(
'Name' => 'Mitch',
),
array(
'Name' => 'Hamish',
)
), $items6);
}
/**
* Test null checks with case modifiers
*/
public function testFilterByNullCase() {
// Test with case (case/nocase both use same code path)
// Test with and without null, and with inclusion/exclusion permutations
2016-10-14 14:30:05 +13:00
$list = Fan::get();
// Only an explicit NOT NULL should include null values
$items6 = $list->filter('Email:not:case', array(null, '', 'damian@thefans.com'));
$this->assertSQLContains(' AND "DataObjectTest_Fan"."Email" IS NOT NULL', $items6->sql());
// These should all include values where Email IS NULL
$items7 = $list->filter('Email:nocase', array(null, '', 'damian@thefans.com'));
$this->assertSQLContains(' OR "DataObjectTest_Fan"."Email" IS NULL', $items7->sql());
$items8 = $list->filter('Email:not:case', array('', 'damian@thefans.com'));
$this->assertSQLContains(' OR "DataObjectTest_Fan"."Email" IS NULL', $items8->sql());
// These should not contain any null checks at all
$items9 = $list->filter('Email:nocase', array('', 'damian@thefans.com'));
$this->assertSQLNotContains('"DataObjectTest_Fan"."Email" IS NULL', $items9->sql());
$this->assertSQLNotContains('"DataObjectTest_Fan"."Email" IS NOT NULL', $items9->sql());
}
/**
* $list = $list->filterByCallback(function($item, $list) { return $item->Age == 21; })
*/
public function testFilterByCallback() {
2016-10-14 14:30:05 +13:00
$team1ID = $this->idFromFixture(DataObjectTest\Team::class, 'team1');
$list = TeamComment::get();
$list = $list->filterByCallback(function ($item, $list) use ($team1ID) {
return $item->TeamID == $team1ID;
});
$result = $list->column('Name');
$expected = array_intersect($result, array('Joe', 'Bob'));
$this->assertEquals(2, $list->count());
$this->assertEquals($expected, $result, 'List should only contain comments from Team 1 (Joe and Bob)');
2016-09-09 18:43:05 +12:00
$this->assertTrue($list instanceof Filterable, 'The List should be of type SS_Filterable');
}
/**
* $list->exclude('Name', 'bob'); // exclude bob from list
*/
public function testSimpleExclude() {
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
$list = $list->exclude('Name', 'Bob');
$list = $list->sort('Name');
$this->assertEquals(2, $list->count());
$this->assertEquals('Joe', $list->first()->Name, 'First comment should be from Joe');
$this->assertEquals('Phil', $list->last()->Name, 'Last comment should be from Phil');
}
2014-08-15 18:53:05 +12:00
//
/**
* $list->exclude('Name', array('aziz', 'bob'); // exclude aziz and bob from list
*/
public function testSimpleExcludeWithMultiple() {
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
$list = $list->exclude('Name', array('Joe','Phil'));
$this->assertEquals(1, $list->count());
$this->assertEquals('Bob', $list->first()->Name, 'First comment should be from Bob');
}
/**
* $list->exclude(array('Name'=>'bob, 'Age'=>21)); // negative version
*/
public function testMultipleExcludeWithMiss() {
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
$list = $list->exclude(array('Name'=>'Bob', 'Comment'=>'Does not match any comments'));
$this->assertEquals(3, $list->count());
}
2014-08-15 18:53:05 +12:00
/**
* $list->exclude(array('Name'=>'bob, 'Age'=>21)); // exclude bob that has Age 21
*/
public function testMultipleExclude() {
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
$list = $list->exclude(array('Name'=>'Bob', 'Comment'=>'This is a team comment by Bob'));
$this->assertEquals(2, $list->count());
}
/**
* Test that if an exclude() is applied to a filter(), the filter() is still preserved.
*/
public function testExcludeOnFilter() {
2016-10-14 14:30:05 +13:00
/** @var DataList $list */
$list = TeamComment::get();
$list = $list->filter('Comment', 'Phil is a unique guy, and comments on team2');
$list = $list->exclude('Name', 'Bob');
2014-08-15 18:53:05 +12:00
$sql = $list->sql($parameters);
$this->assertSQLContains(
'WHERE ("DataObjectTest_TeamComment"."Comment" = ?) AND (("DataObjectTest_TeamComment"."Name" != ? '
. 'OR "DataObjectTest_TeamComment"."Name" IS NULL))',
$sql);
$this->assertEquals(array('Phil is a unique guy, and comments on team2', 'Bob'), $parameters);
}
public function testExcludeWithSearchFilter() {
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
$list = $list->exclude('Name:LessThan', 'Bob');
2014-08-15 18:53:05 +12:00
$sql = $list->sql($parameters);
$this->assertSQLContains('WHERE (("DataObjectTest_TeamComment"."Name" >= ?))', $sql);
$this->assertEquals(array('Bob'), $parameters);
}
2014-08-15 18:53:05 +12:00
/**
* Test exact match filter with empty array items
*/
public function testEmptyFilter() {
2016-10-14 14:30:05 +13:00
$this->setExpectedException(
"InvalidArgumentException",
'Cannot filter "DataObjectTest_TeamComment"."Name" against an empty set'
);
$list = TeamComment::get();
Merge remote-tracking branch 'origin/3' # Conflicts: # control/Director.php # control/HTTP.php # core/startup/ParameterConfirmationToken.php # docs/en/00_Getting_Started/01_Installation/05_Common_Problems.md # docs/en/00_Getting_Started/04_Directory_Structure.md # docs/en/00_Getting_Started/05_Coding_Conventions.md # docs/en/01_Tutorials/01_Building_A_Basic_Site.md # docs/en/01_Tutorials/02_Extending_A_Basic_Site.md # docs/en/01_Tutorials/03_Forms.md # docs/en/01_Tutorials/04_Site_Search.md # docs/en/01_Tutorials/05_Dataobject_Relationship_Management.md # docs/en/02_Developer_Guides/12_Search/01_Searchcontext.md # docs/en/02_Developer_Guides/13_i18n/index.md # docs/en/02_Developer_Guides/15_Customising_the_Admin_Interface/06_Javascript_Development.md # docs/en/03_Upgrading/index.md # docs/en/changelogs/index.md # docs/en/howto/customize-cms-menu.md # docs/en/howto/navigation-menu.md # docs/en/index.md # docs/en/installation/index.md # docs/en/installation/windows-manual-iis-6.md # docs/en/misc/contributing/code.md # docs/en/misc/contributing/issues.md # docs/en/misc/module-release-process.md # docs/en/reference/dataobject.md # docs/en/reference/execution-pipeline.md # docs/en/reference/grid-field.md # docs/en/reference/modeladmin.md # docs/en/reference/rssfeed.md # docs/en/reference/templates.md # docs/en/topics/commandline.md # docs/en/topics/debugging.md # docs/en/topics/email.md # docs/en/topics/forms.md # docs/en/topics/index.md # docs/en/topics/module-development.md # docs/en/topics/modules.md # docs/en/topics/page-type-templates.md # docs/en/topics/page-types.md # docs/en/topics/search.md # docs/en/topics/testing/index.md # docs/en/topics/testing/testing-guide-troubleshooting.md # docs/en/topics/theme-development.md # docs/en/tutorials/1-building-a-basic-site.md # docs/en/tutorials/2-extending-a-basic-site.md # docs/en/tutorials/3-forms.md # docs/en/tutorials/4-site-search.md # docs/en/tutorials/5-dataobject-relationship-management.md # docs/en/tutorials/building-a-basic-site.md # docs/en/tutorials/dataobject-relationship-management.md # docs/en/tutorials/extending-a-basic-site.md # docs/en/tutorials/forms.md # docs/en/tutorials/index.md # docs/en/tutorials/site-search.md # main.php # model/SQLQuery.php # security/ChangePasswordForm.php # security/MemberLoginForm.php # tests/control/ControllerTest.php # tests/core/startup/ParameterConfirmationTokenTest.php # tests/model/SQLQueryTest.php # tests/security/SecurityTest.php # tests/view/SSViewerTest.php # view/SSTemplateParser.php # view/SSTemplateParser.php.inc # view/SSViewer.php
2016-01-20 13:16:27 +13:00
$list->exclude('Name', array());
}
/**
* $list->exclude(array('Name'=>'bob, 'Age'=>array(21, 43))); // exclude bob with Age 21 or 43
*/
public function testMultipleExcludeWithMultipleThatCheersEitherTeam() {
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
$list = $list->exclude(array('Name'=>'Bob', 'TeamID'=>array(
2016-10-14 14:30:05 +13:00
$this->idFromFixture(DataObjectTest\Team::class, 'team1'),
$this->idFromFixture(DataObjectTest\Team::class, 'team2')
2012-02-11 14:24:49 +13:00
)));
$list = $list->sort('Name');
$this->assertEquals(2, $list->count());
$this->assertEquals('Joe', $list->first()->Name, 'First comment should be from Phil');
$this->assertEquals('Phil', $list->last()->Name, 'First comment should be from Phil');
}
2014-08-15 18:53:05 +12:00
/**
* $list->exclude(array('Name'=>'bob, 'Age'=>array(21, 43))); // negative version
*/
public function testMultipleExcludeWithMultipleThatCheersOnNonExistingTeam() {
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
$list = $list->exclude(array('Name'=>'Bob', 'TeamID'=>array(3)));
$this->assertEquals(3, $list->count());
}
2014-08-15 18:53:05 +12:00
/**
* $list->exclude(array('Name'=>array('bob','phil'), 'Age'=>array(21, 43))); //negative version
*/
public function testMultipleExcludeWithNoExclusion() {
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
$list = $list->exclude(array(
'Name'=>array('Bob','Joe'),
'Comment' => 'Phil is a unique guy, and comments on team2'));
$this->assertEquals(3, $list->count());
}
2014-08-15 18:53:05 +12:00
/**
2014-08-15 18:53:05 +12:00
* $list->exclude(array('Name'=>array('bob','phil'), 'Age'=>array(21, 43)));
*/
public function testMultipleExcludeWithTwoArray() {
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
$list = $list->exclude(array('Name' => array('Bob','Joe'), 'TeamID' => array(
2016-10-14 14:30:05 +13:00
$this->idFromFixture(DataObjectTest\Team::class, 'team1'),
$this->idFromFixture(DataObjectTest\Team::class, 'team2')
2012-02-11 14:24:49 +13:00
)));
$this->assertEquals(1, $list->count());
$this->assertEquals('Phil', $list->last()->Name, 'Only comment should be from Phil');
}
2014-08-15 18:53:05 +12:00
/**
2014-08-15 18:53:05 +12:00
* $list->exclude(array('Name'=>array('bob','phil'), 'Age'=>array(21, 43)));
*/
public function testMultipleExcludeWithTwoArrayOneTeam() {
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
$list = $list->exclude(array(
'Name' => array('Bob', 'Phil'),
2016-10-14 14:30:05 +13:00
'TeamID' => array($this->idFromFixture(DataObjectTest\Team::class, 'team1'))));
$list = $list->sort('Name');
$this->assertEquals(2, $list->count());
$this->assertEquals('Joe', $list->first()->Name, 'First comment should be from Joe');
$this->assertEquals('Phil', $list->last()->Name, 'Last comment should be from Phil');
}
/**
2014-08-15 18:53:05 +12:00
*
*/
public function testSortByRelation() {
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
$list = $list->sort(array('Team.Title' => 'DESC'));
$this->assertEquals(3, $list->count());
2016-10-14 14:30:05 +13:00
$this->assertEquals($this->idFromFixture(DataObjectTest\Team::class, 'team2'), $list->first()->TeamID,
'First comment should be for Team 2');
2016-10-14 14:30:05 +13:00
$this->assertEquals($this->idFromFixture(DataObjectTest\Team::class, 'team1'), $list->last()->TeamID,
'Last comment should be for Team 1');
}
2014-08-15 18:53:05 +12:00
public function testReverse() {
2016-10-14 14:30:05 +13:00
$list = TeamComment::get();
$list = $list->sort('Name');
$list = $list->reverse();
2014-08-15 18:53:05 +12:00
$this->assertEquals('Bob', $list->last()->Name, 'Last comment should be from Bob');
$this->assertEquals('Phil', $list->first()->Name, 'First comment should be from Phil');
}
public function testSortByComplexExpression() {
2014-08-15 18:53:05 +12:00
// Test an expression with both spaces and commas. This test also tests that column() can be called
// with a complex sort expression, so keep using column() below
2016-10-14 14:30:05 +13:00
$teamClass = Convert::raw2sql(SubTeam::class);
$list = Team::get()->sort(
'CASE WHEN "DataObjectTest_Team"."ClassName" = \''.$teamClass.'\' THEN 0 ELSE 1 END, "Title" DESC'
);
$this->assertEquals(array(
'Subteam 3',
'Subteam 2',
'Subteam 1',
'Team 3',
'Team 2',
'Team 1',
), $list->column("Title"));
}
}