mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 14:05:37 +02:00
Merge branch '3.1' into 3.2
This commit is contained in:
commit
e8962b95d0
@ -698,9 +698,11 @@ class DataQuery {
|
|||||||
$componentBaseClass = ClassInfo::baseDataClass($componentClass);
|
$componentBaseClass = ClassInfo::baseDataClass($componentClass);
|
||||||
$this->query->addInnerJoin($relationTable,
|
$this->query->addInnerJoin($relationTable,
|
||||||
"\"$relationTable\".\"$parentField\" = \"$parentBaseClass\".\"ID\"");
|
"\"$relationTable\".\"$parentField\" = \"$parentBaseClass\".\"ID\"");
|
||||||
|
if (!$this->query->isJoinedTo($componentBaseClass)) {
|
||||||
$this->query->addLeftJoin($componentBaseClass,
|
$this->query->addLeftJoin($componentBaseClass,
|
||||||
"\"$relationTable\".\"$componentField\" = \"$componentBaseClass\".\"ID\"");
|
"\"$relationTable\".\"$componentField\" = \"$componentBaseClass\".\"ID\"");
|
||||||
if(ClassInfo::hasTable($componentClass)) {
|
}
|
||||||
|
if(ClassInfo::hasTable($componentClass) && !$this->query->isJoinedTo($componentClass)) {
|
||||||
$this->query->addLeftJoin($componentClass,
|
$this->query->addLeftJoin($componentClass,
|
||||||
"\"$relationTable\".\"$componentField\" = \"$componentClass\".\"ID\"");
|
"\"$relationTable\".\"$componentField\" = \"$componentClass\".\"ID\"");
|
||||||
}
|
}
|
||||||
|
@ -25,6 +25,8 @@ class DataListTest extends SapphireTest {
|
|||||||
'DataObjectTest\NamespacedClass',
|
'DataObjectTest\NamespacedClass',
|
||||||
'DataObjectTest_Company',
|
'DataObjectTest_Company',
|
||||||
'DataObjectTest_Fan',
|
'DataObjectTest_Fan',
|
||||||
|
'ManyManyListTest_Product',
|
||||||
|
'ManyManyListTest_Category',
|
||||||
);
|
);
|
||||||
|
|
||||||
public function testFilterDataObjectByCreatedDate() {
|
public function testFilterDataObjectByCreatedDate() {
|
||||||
|
@ -35,6 +35,9 @@ class DataObjectLazyLoadingTest extends SapphireTest {
|
|||||||
'DataObjectTest_Play',
|
'DataObjectTest_Play',
|
||||||
'DataObjectTest_Ploy',
|
'DataObjectTest_Ploy',
|
||||||
'DataObjectTest_Bogey',
|
'DataObjectTest_Bogey',
|
||||||
|
// From ManyManyListTest
|
||||||
|
'ManyManyListTest_Product',
|
||||||
|
'ManyManyListTest_Category',
|
||||||
// From VersionedTest
|
// From VersionedTest
|
||||||
'VersionedTest_DataObject',
|
'VersionedTest_DataObject',
|
||||||
'VersionedTest_Subclass',
|
'VersionedTest_Subclass',
|
||||||
|
@ -29,6 +29,8 @@ class DataObjectTest extends SapphireTest {
|
|||||||
'DataObjectTest_Play',
|
'DataObjectTest_Play',
|
||||||
'DataObjectTest_Ploy',
|
'DataObjectTest_Ploy',
|
||||||
'DataObjectTest_Bogey',
|
'DataObjectTest_Bogey',
|
||||||
|
'ManyManyListTest_Product',
|
||||||
|
'ManyManyListTest_Category',
|
||||||
);
|
);
|
||||||
|
|
||||||
public function testDb() {
|
public function testDb() {
|
||||||
|
@ -59,6 +59,28 @@ DataObjectTest_TeamComment:
|
|||||||
Name: Phil
|
Name: Phil
|
||||||
Comment: Phil is a unique guy, and comments on team2
|
Comment: Phil is a unique guy, and comments on team2
|
||||||
Team: =>DataObjectTest_Team.team2
|
Team: =>DataObjectTest_Team.team2
|
||||||
|
ManyManyListTest_Product:
|
||||||
|
producta:
|
||||||
|
Title: 'Product A'
|
||||||
|
productb:
|
||||||
|
Title: 'Product B'
|
||||||
|
RelatedProducts: =>ManyManyListTest_Product.producta
|
||||||
|
ManyManyListTest_Category:
|
||||||
|
categorya:
|
||||||
|
Title: 'Category A'
|
||||||
|
Products: =>ManyManyListTest_Product.producta,=>ManyManyListTest_Product.productb
|
||||||
|
comment1:
|
||||||
|
Name: Joe
|
||||||
|
Comment: This is a team comment by Joe
|
||||||
|
Team: =>DataObjectTest_Team.team1
|
||||||
|
comment2:
|
||||||
|
Name: Bob
|
||||||
|
Comment: This is a team comment by Bob
|
||||||
|
Team: =>DataObjectTest_Team.team1
|
||||||
|
comment3:
|
||||||
|
Name: Phil
|
||||||
|
Comment: Phil is a unique guy, and comments on team2
|
||||||
|
Team: =>DataObjectTest_Team.team2
|
||||||
DataObjectTest_Fan:
|
DataObjectTest_Fan:
|
||||||
fan1:
|
fan1:
|
||||||
Name: Damian
|
Name: Damian
|
||||||
|
@ -11,6 +11,7 @@ class DataQueryTest extends SapphireTest {
|
|||||||
'DataQueryTest_D',
|
'DataQueryTest_D',
|
||||||
'DataQueryTest_E',
|
'DataQueryTest_E',
|
||||||
'DataQueryTest_F',
|
'DataQueryTest_F',
|
||||||
|
'DataQueryTest_G',
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|
||||||
@ -63,11 +64,39 @@ class DataQueryTest extends SapphireTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public function testApplyReplationDeepInheretence() {
|
public function testApplyReplationDeepInheretence() {
|
||||||
|
//test has_one relation
|
||||||
$newDQ = new DataQuery('DataQueryTest_E');
|
$newDQ = new DataQuery('DataQueryTest_E');
|
||||||
//apply a relation to a relation from an ancestor class
|
//apply a relation to a relation from an ancestor class
|
||||||
$newDQ->applyRelation('TestA');
|
$newDQ->applyRelation('TestA');
|
||||||
$this->assertTrue($newDQ->query()->isJoinedTo('DataQueryTest_C'));
|
$this->assertTrue($newDQ->query()->isJoinedTo('DataQueryTest_C'));
|
||||||
$this->assertContains('"DataQueryTest_A"."ID" = "DataQueryTest_C"."TestAID"', $newDQ->sql($params));
|
$this->assertContains('"DataQueryTest_A"."ID" = "DataQueryTest_C"."TestAID"', $newDQ->sql($params));
|
||||||
|
|
||||||
|
//test many_many relation
|
||||||
|
|
||||||
|
//test many_many with separate inheritance
|
||||||
|
$newDQ = new DataQuery('DataQueryTest_C');
|
||||||
|
$baseDBTable = ClassInfo::baseDataClass('DataQueryTest_C');
|
||||||
|
$newDQ->applyRelation('ManyTestAs');
|
||||||
|
//check we are "joined" to the DataObject's table (there is no distinction between FROM or JOIN clauses)
|
||||||
|
$this->assertTrue($newDQ->query()->isJoinedTo($baseDBTable));
|
||||||
|
//check we are explicitly selecting "FROM" the DO's table
|
||||||
|
$this->assertContains("FROM \"$baseDBTable\"", $newDQ->sql());
|
||||||
|
|
||||||
|
//test many_many with shared inheritance
|
||||||
|
$newDQ = new DataQuery('DataQueryTest_E');
|
||||||
|
$baseDBTable = ClassInfo::baseDataClass('DataQueryTest_E');
|
||||||
|
//check we are "joined" to the DataObject's table (there is no distinction between FROM or JOIN clauses)
|
||||||
|
$this->assertTrue($newDQ->query()->isJoinedTo($baseDBTable));
|
||||||
|
//check we are explicitly selecting "FROM" the DO's table
|
||||||
|
$this->assertContains("FROM \"$baseDBTable\"", $newDQ->sql(), 'The FROM clause is missing from the query');
|
||||||
|
$newDQ->applyRelation('ManyTestGs');
|
||||||
|
//confirm we are still joined to the base table
|
||||||
|
$this->assertTrue($newDQ->query()->isJoinedTo($baseDBTable));
|
||||||
|
//double check it is the "FROM" clause
|
||||||
|
$this->assertContains("FROM \"$baseDBTable\"", $newDQ->sql(), 'The FROM clause has been removed from the query');
|
||||||
|
//another (potentially less crude check) for checking "FROM" clause
|
||||||
|
$fromTables = $newDQ->query()->getFrom();
|
||||||
|
$this->assertEquals('"' . $baseDBTable . '"', $fromTables[$baseDBTable]);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testRelationReturn() {
|
public function testRelationReturn() {
|
||||||
@ -310,6 +339,10 @@ class DataQueryTest_E extends DataQueryTest_C implements TestOnly {
|
|||||||
'SortOrder' => 'Int'
|
'SortOrder' => 'Int'
|
||||||
);
|
);
|
||||||
|
|
||||||
|
private static $many_many = array(
|
||||||
|
'ManyTestGs' => 'DataQueryTest_G',
|
||||||
|
);
|
||||||
|
|
||||||
private static $default_sort = '"DataQueryTest_E"."SortOrder" ASC';
|
private static $default_sort = '"DataQueryTest_E"."SortOrder" ASC';
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -321,3 +354,11 @@ class DataQueryTest_F extends DataObject implements TestOnly {
|
|||||||
'MyString' => 'Text'
|
'MyString' => 'Text'
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
class DataQueryTest_G extends DataQueryTest_C implements TestOnly {
|
||||||
|
|
||||||
|
private static $belongs_many_many = array(
|
||||||
|
'ManyTestEs' => 'DataQueryTest_E',
|
||||||
|
);
|
||||||
|
|
||||||
|
}
|
||||||
|
@ -10,6 +10,8 @@ class HasManyListTest extends SapphireTest {
|
|||||||
'DataObjectTest_SubTeam',
|
'DataObjectTest_SubTeam',
|
||||||
'DataObjectTest_Player',
|
'DataObjectTest_Player',
|
||||||
'DataObjectTest_TeamComment',
|
'DataObjectTest_TeamComment',
|
||||||
|
'ManyManyListTest_Product',
|
||||||
|
'ManyManyListTest_Category',
|
||||||
);
|
);
|
||||||
|
|
||||||
public function testRelationshipEmptyOnNewRecords() {
|
public function testRelationshipEmptyOnNewRecords() {
|
||||||
|
@ -15,6 +15,8 @@ class ManyManyListTest extends SapphireTest {
|
|||||||
'DataObjectTest_Company',
|
'DataObjectTest_Company',
|
||||||
'DataObjectTest_TeamComment',
|
'DataObjectTest_TeamComment',
|
||||||
'ManyManyListTest_ExtraFields',
|
'ManyManyListTest_ExtraFields',
|
||||||
|
'ManyManyListTest_Product',
|
||||||
|
'ManyManyListTest_Category',
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|
||||||
@ -267,6 +269,17 @@ class ManyManyListTest extends SapphireTest {
|
|||||||
$this->assertSQLEquals($expected, $list->sql($parameters));
|
$this->assertSQLEquals($expected, $list->sql($parameters));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testFilteringOnPreviouslyJoinedTable() {
|
||||||
|
|
||||||
|
/** @var ManyManyListTest_Category $category */
|
||||||
|
$category = $this->objFromFixture('ManyManyListTest_Category', 'categorya');
|
||||||
|
|
||||||
|
/** @var ManyManyList $productsRelatedToProductB */
|
||||||
|
$productsRelatedToProductB = $category->Products()->filter('RelatedProducts.Title', 'Product B');
|
||||||
|
|
||||||
|
$this->assertEquals(1, $productsRelatedToProductB->count());
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -291,3 +304,33 @@ class ManyManyListTest_ExtraFields extends DataObject implements TestOnly {
|
|||||||
)
|
)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
class ManyManyListTest_Product extends DataObject implements TestOnly {
|
||||||
|
|
||||||
|
private static $db = array(
|
||||||
|
'Title' => 'Varchar'
|
||||||
|
);
|
||||||
|
|
||||||
|
private static $many_many = array(
|
||||||
|
'RelatedProducts' => 'ManyManyListTest_Product'
|
||||||
|
);
|
||||||
|
|
||||||
|
private static $belongs_many_many = array(
|
||||||
|
'RelatedTo' => 'ManyManyListTest_Product',
|
||||||
|
'Categories' => 'ManyManyListTest_Category'
|
||||||
|
);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
class ManyManyListTest_Category extends DataObject implements TestOnly {
|
||||||
|
|
||||||
|
private static $db = array(
|
||||||
|
'Title' => 'Varchar'
|
||||||
|
);
|
||||||
|
|
||||||
|
private static $many_many = array(
|
||||||
|
'Products' => 'ManyManyListTest_Product'
|
||||||
|
);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@ -5,7 +5,7 @@
|
|||||||
* @subpackage tests
|
* @subpackage tests
|
||||||
*/
|
*/
|
||||||
class SS_MapTest extends SapphireTest {
|
class SS_MapTest extends SapphireTest {
|
||||||
|
|
||||||
// Borrow the model from DataObjectTest
|
// Borrow the model from DataObjectTest
|
||||||
protected static $fixture_file = 'DataObjectTest.yml';
|
protected static $fixture_file = 'DataObjectTest.yml';
|
||||||
|
|
||||||
@ -18,9 +18,11 @@ class SS_MapTest extends SapphireTest {
|
|||||||
'DataObjectTest_FieldlessSubTable',
|
'DataObjectTest_FieldlessSubTable',
|
||||||
'DataObjectTest_ValidatedObject',
|
'DataObjectTest_ValidatedObject',
|
||||||
'DataObjectTest_Player',
|
'DataObjectTest_Player',
|
||||||
'DataObjectTest_TeamComment'
|
'DataObjectTest_TeamComment',
|
||||||
|
'ManyManyListTest_Product',
|
||||||
|
'ManyManyListTest_Category',
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|
||||||
public function testValues() {
|
public function testValues() {
|
||||||
$list = DataObjectTest_TeamComment::get()->sort('Name');
|
$list = DataObjectTest_TeamComment::get()->sort('Name');
|
||||||
@ -76,13 +78,13 @@ class SS_MapTest extends SapphireTest {
|
|||||||
. "Bob: This is a team comment by Bob\n"
|
. "Bob: This is a team comment by Bob\n"
|
||||||
. "Phil: Phil is a unique guy, and comments on team2\n", $text);
|
. "Phil: Phil is a unique guy, and comments on team2\n", $text);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testDefaultConfigIsIDAndTitle() {
|
public function testDefaultConfigIsIDAndTitle() {
|
||||||
$list = DataObjectTest_Team::get();
|
$list = DataObjectTest_Team::get();
|
||||||
$map = new SS_Map($list);
|
$map = new SS_Map($list);
|
||||||
$this->assertEquals('Team 1', $map[$this->idFromFixture('DataObjectTest_Team', 'team1')]);
|
$this->assertEquals('Team 1', $map[$this->idFromFixture('DataObjectTest_Team', 'team1')]);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testSetKeyFieldAndValueField() {
|
public function testSetKeyFieldAndValueField() {
|
||||||
$list = DataObjectTest_TeamComment::get();
|
$list = DataObjectTest_TeamComment::get();
|
||||||
$map = new SS_Map($list);
|
$map = new SS_Map($list);
|
||||||
@ -90,7 +92,7 @@ class SS_MapTest extends SapphireTest {
|
|||||||
$map->setValueField('Comment');
|
$map->setValueField('Comment');
|
||||||
$this->assertEquals('This is a team comment by Joe', $map['Joe']);
|
$this->assertEquals('This is a team comment by Joe', $map['Joe']);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testToArray() {
|
public function testToArray() {
|
||||||
$list = DataObjectTest_TeamComment::get();
|
$list = DataObjectTest_TeamComment::get();
|
||||||
$map = new SS_Map($list, 'Name', 'Comment');
|
$map = new SS_Map($list, 'Name', 'Comment');
|
||||||
@ -168,10 +170,10 @@ class SS_MapTest extends SapphireTest {
|
|||||||
"Phil" => "Phil is a unique guy, and comments on team2"), $map->toArray());
|
"Phil" => "Phil is a unique guy, and comments on team2"), $map->toArray());
|
||||||
|
|
||||||
$map->unshift(0, '(Select)');
|
$map->unshift(0, '(Select)');
|
||||||
|
|
||||||
$this->assertEquals('(All)', $map[-1]);
|
$this->assertEquals('(All)', $map[-1]);
|
||||||
$this->assertEquals('(Select)', $map[0]);
|
$this->assertEquals('(Select)', $map[0]);
|
||||||
|
|
||||||
$this->assertEquals(array(
|
$this->assertEquals(array(
|
||||||
0 => "(Select)",
|
0 => "(Select)",
|
||||||
-1 => "(All)",
|
-1 => "(All)",
|
||||||
@ -217,7 +219,7 @@ class SS_MapTest extends SapphireTest {
|
|||||||
1 => "(All)"
|
1 => "(All)"
|
||||||
), $map->toArray());
|
), $map->toArray());
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testCount() {
|
public function testCount() {
|
||||||
$list = DataObjectTest_TeamComment::get();
|
$list = DataObjectTest_TeamComment::get();
|
||||||
$map = new SS_Map($list, 'Name', 'Comment');
|
$map = new SS_Map($list, 'Name', 'Comment');
|
||||||
@ -262,7 +264,7 @@ class SS_MapTest extends SapphireTest {
|
|||||||
$list = DataObjectTest_TeamComment::get()->sort('ID');
|
$list = DataObjectTest_TeamComment::get()->sort('ID');
|
||||||
$map = new SS_Map($list, 'Name', 'Comment');
|
$map = new SS_Map($list, 'Name', 'Comment');
|
||||||
$map->push(1, 'Pushed');
|
$map->push(1, 'Pushed');
|
||||||
|
|
||||||
$text = "";
|
$text = "";
|
||||||
|
|
||||||
foreach($map as $k => $v) {
|
foreach($map as $k => $v) {
|
||||||
@ -285,7 +287,7 @@ class SS_MapTest extends SapphireTest {
|
|||||||
foreach($map as $k => $v) {
|
foreach($map as $k => $v) {
|
||||||
$text .= "$k: $v\n";
|
$text .= "$k: $v\n";
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->assertEquals("1: unshifted\n", $text);
|
$this->assertEquals("1: unshifted\n", $text);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -298,7 +300,7 @@ class SS_MapTest extends SapphireTest {
|
|||||||
foreach($map as $k => $v) {
|
foreach($map as $k => $v) {
|
||||||
$text .= "$k: $v\n";
|
$text .= "$k: $v\n";
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->assertEquals("1: pushed\n", $text);
|
$this->assertEquals("1: pushed\n", $text);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -12,7 +12,9 @@ class PaginatedListTest extends SapphireTest {
|
|||||||
protected $extraDataObjects = array(
|
protected $extraDataObjects = array(
|
||||||
'DataObjectTest_Team',
|
'DataObjectTest_Team',
|
||||||
'DataObjectTest_SubTeam',
|
'DataObjectTest_SubTeam',
|
||||||
'DataObjectTest_Player'
|
'DataObjectTest_Player',
|
||||||
|
'ManyManyListTest_Product',
|
||||||
|
'ManyManyListTest_Category',
|
||||||
);
|
);
|
||||||
|
|
||||||
public function testPageStart() {
|
public function testPageStart() {
|
||||||
|
Loading…
Reference in New Issue
Block a user