2010-04-12 05:04:34 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
/*
|
2012-05-19 12:55:49 +12:00
|
|
|
* A hierarchy of data types, to...
|
|
|
|
*
|
|
|
|
* @deprecated. This is testing`
|
|
|
|
* {@link DataObject::Aggregate()} and {@link DataObject::RelationshipAggregate()}
|
|
|
|
* which are deprecated. Aggregates are handled directly by DataList instead.
|
|
|
|
* This test should be removed or merged into DataListTest once those functions are
|
|
|
|
* removed from DataObject.
|
2010-04-12 05:04:34 +00:00
|
|
|
*/
|
|
|
|
class AggregateTest_Foo extends DataObject implements TestOnly {
|
2013-03-21 19:48:54 +01:00
|
|
|
private static $db = array(
|
2010-04-12 05:04:34 +00:00
|
|
|
"Foo" => "Int"
|
|
|
|
);
|
|
|
|
|
2013-03-21 19:48:54 +01:00
|
|
|
private static $has_one = array('Bar' => 'AggregateTest_Bar');
|
|
|
|
private static $belongs_many_many = array('Bazi' => 'AggregateTest_Baz');
|
2010-04-12 05:04:34 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
class AggregateTest_Fab extends AggregateTest_Foo {
|
2013-03-21 19:48:54 +01:00
|
|
|
private static $db = array(
|
2010-04-12 05:04:34 +00:00
|
|
|
"Fab" => "Int"
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
class AggregateTest_Fac extends AggregateTest_Fab {
|
2013-03-21 19:48:54 +01:00
|
|
|
private static $db = array(
|
2010-04-12 05:04:34 +00:00
|
|
|
"Fac" => "Int"
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
class AggregateTest_Bar extends DataObject implements TestOnly {
|
2013-03-21 19:48:54 +01:00
|
|
|
private static $db = array(
|
2010-04-12 05:04:34 +00:00
|
|
|
"Bar" => "Int"
|
|
|
|
);
|
|
|
|
|
2013-03-21 19:48:54 +01:00
|
|
|
private static $has_many = array(
|
2010-04-12 05:04:34 +00:00
|
|
|
"Foos" => "AggregateTest_Foo"
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
class AggregateTest_Baz extends DataObject implements TestOnly {
|
2013-03-21 19:48:54 +01:00
|
|
|
private static $db = array(
|
2010-04-12 05:04:34 +00:00
|
|
|
"Baz" => "Int"
|
|
|
|
);
|
|
|
|
|
2013-03-21 19:48:54 +01:00
|
|
|
private static $many_many = array(
|
2010-04-12 05:04:34 +00:00
|
|
|
"Foos" => "AggregateTest_Foo"
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
class AggregateTest extends SapphireTest {
|
2013-03-21 19:48:54 +01:00
|
|
|
protected static $fixture_file = 'AggregateTest.yml';
|
2010-04-12 05:04:34 +00:00
|
|
|
|
|
|
|
protected $extraDataObjects = array(
|
|
|
|
'AggregateTest_Foo',
|
|
|
|
'AggregateTest_Fab',
|
|
|
|
'AggregateTest_Fac',
|
|
|
|
'AggregateTest_Bar',
|
|
|
|
'AggregateTest_Baz'
|
|
|
|
);
|
|
|
|
|
2011-10-29 17:04:45 +13:00
|
|
|
protected $originalDeprecation;
|
|
|
|
|
2012-09-19 12:07:39 +02:00
|
|
|
public function setUp() {
|
2011-10-29 17:04:45 +13:00
|
|
|
parent::setUp();
|
|
|
|
// This test tests code that was deprecated after 2.4
|
|
|
|
$this->originalDeprecation = Deprecation::dump_settings();
|
|
|
|
Deprecation::notification_version('2.4');
|
|
|
|
}
|
|
|
|
|
2012-09-19 12:07:39 +02:00
|
|
|
public function tearDown() {
|
2011-10-29 17:04:45 +13:00
|
|
|
parent::tearDown();
|
|
|
|
Deprecation::restore_settings($this->originalDeprecation);
|
|
|
|
}
|
|
|
|
|
2010-04-12 05:04:34 +00:00
|
|
|
/**
|
|
|
|
* Test basic aggregation on a passed type
|
|
|
|
*/
|
2012-09-19 12:07:39 +02:00
|
|
|
public function testTypeSpecifiedAggregate() {
|
2012-03-27 17:04:11 +13:00
|
|
|
$foo = $this->objFromFixture('AggregateTest_Foo', 'foo1');
|
|
|
|
|
2010-04-12 05:04:34 +00:00
|
|
|
// Template style access
|
2012-03-27 17:04:11 +13:00
|
|
|
$this->assertEquals($foo->Aggregate('AggregateTest_Foo')->XML_val('Max', array('Foo')), 9);
|
|
|
|
$this->assertEquals($foo->Aggregate('AggregateTest_Fab')->XML_val('Max', array('Fab')), 3);
|
2010-04-12 05:04:34 +00:00
|
|
|
|
|
|
|
// PHP style access
|
2012-03-27 17:04:11 +13:00
|
|
|
$this->assertEquals($foo->Aggregate('AggregateTest_Foo')->Max('Foo'), 9);
|
|
|
|
$this->assertEquals($foo->Aggregate('AggregateTest_Fab')->Max('Fab'), 3);
|
2010-04-12 05:04:34 +00:00
|
|
|
}
|
|
|
|
/* */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Test basic aggregation on a given dataobject
|
|
|
|
* @return unknown_type
|
|
|
|
*/
|
2012-09-19 12:07:39 +02:00
|
|
|
public function testAutoTypeAggregate() {
|
2010-04-12 05:04:34 +00:00
|
|
|
$foo = $this->objFromFixture('AggregateTest_Foo', 'foo1');
|
|
|
|
$fab = $this->objFromFixture('AggregateTest_Fab', 'fab1');
|
2012-03-27 17:04:11 +13:00
|
|
|
|
2010-04-12 05:04:34 +00:00
|
|
|
// Template style access
|
|
|
|
$this->assertEquals($foo->Aggregate()->XML_val('Max', array('Foo')), 9);
|
|
|
|
$this->assertEquals($fab->Aggregate()->XML_val('Max', array('Fab')), 3);
|
|
|
|
|
|
|
|
// PHP style access
|
|
|
|
$this->assertEquals($foo->Aggregate()->Max('Foo'), 9);
|
|
|
|
$this->assertEquals($fab->Aggregate()->Max('Fab'), 3);
|
|
|
|
}
|
|
|
|
/* */
|
|
|
|
|
2010-04-12 21:10:21 +00:00
|
|
|
/**
|
|
|
|
* Test base-level field access - was failing due to use of custom_database_fields, not just database_fields
|
|
|
|
* @return unknown_type
|
|
|
|
*/
|
2012-09-19 12:07:39 +02:00
|
|
|
public function testBaseFieldAggregate() {
|
2012-03-27 17:04:11 +13:00
|
|
|
$foo = $this->objFromFixture('AggregateTest_Foo', 'foo1');
|
|
|
|
|
2010-04-12 21:10:21 +00:00
|
|
|
$this->assertEquals(
|
2012-03-27 17:04:11 +13:00
|
|
|
$this->formatDate($foo->Aggregate('AggregateTest_Foo')->Max('LastEdited')),
|
2011-10-29 17:27:03 +13:00
|
|
|
$this->formatDate(DataObject::get_one('AggregateTest_Foo', '', '', '"LastEdited" DESC')->LastEdited)
|
2010-04-12 21:10:21 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
$this->assertEquals(
|
2012-03-27 17:04:11 +13:00
|
|
|
$this->formatDate($foo->Aggregate('AggregateTest_Foo')->Max('Created')),
|
2011-10-29 17:27:03 +13:00
|
|
|
$this->formatDate(DataObject::get_one('AggregateTest_Foo', '', '', '"Created" DESC')->Created)
|
2010-04-12 21:10:21 +00:00
|
|
|
);
|
|
|
|
}
|
|
|
|
/* */
|
|
|
|
|
2010-04-12 05:04:34 +00:00
|
|
|
/**
|
|
|
|
* Test aggregation takes place on the passed type & it's children only
|
|
|
|
*/
|
2012-09-19 12:07:39 +02:00
|
|
|
public function testChildAggregate() {
|
2012-03-27 17:04:11 +13:00
|
|
|
$foo = $this->objFromFixture('AggregateTest_Foo', 'foo1');
|
|
|
|
|
2010-04-12 05:04:34 +00:00
|
|
|
// For base classes, aggregate is calculcated on it and all children classes
|
2012-03-27 17:04:11 +13:00
|
|
|
$this->assertEquals($foo->Aggregate('AggregateTest_Foo')->Max('Foo'), 9);
|
2010-04-12 05:04:34 +00:00
|
|
|
|
|
|
|
// For subclasses, aggregate is calculated for that subclass and it's children only
|
2012-03-27 17:04:11 +13:00
|
|
|
$this->assertEquals($foo->Aggregate('AggregateTest_Fab')->Max('Foo'), 9);
|
|
|
|
$this->assertEquals($foo->Aggregate('AggregateTest_Fac')->Max('Foo'), 6);
|
2010-04-12 05:04:34 +00:00
|
|
|
|
|
|
|
}
|
|
|
|
/* */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Test aggregates are cached properly
|
|
|
|
*/
|
2012-09-19 12:07:39 +02:00
|
|
|
public function testCache() {
|
2012-11-23 14:55:19 +01:00
|
|
|
$this->markTestIncomplete();
|
2010-04-12 05:04:34 +00:00
|
|
|
}
|
|
|
|
/* */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Test cache is correctly flushed on write
|
|
|
|
*/
|
2012-09-19 12:07:39 +02:00
|
|
|
public function testCacheFlushing() {
|
2012-03-27 17:04:11 +13:00
|
|
|
$foo = $this->objFromFixture('AggregateTest_Foo', 'foo1');
|
|
|
|
$fab = $this->objFromFixture('AggregateTest_Fab', 'fab1');
|
|
|
|
|
2010-04-12 05:04:34 +00:00
|
|
|
// For base classes, aggregate is calculcated on it and all children classes
|
2012-03-27 17:04:11 +13:00
|
|
|
$this->assertEquals($fab->Aggregate('AggregateTest_Foo')->Max('Foo'), 9);
|
2010-04-12 05:04:34 +00:00
|
|
|
|
|
|
|
// For subclasses, aggregate is calculated for that subclass and it's children only
|
2012-03-27 17:04:11 +13:00
|
|
|
$this->assertEquals($fab->Aggregate('AggregateTest_Fab')->Max('Foo'), 9);
|
|
|
|
$this->assertEquals($fab->Aggregate('AggregateTest_Fac')->Max('Foo'), 6);
|
|
|
|
|
2010-04-12 05:04:34 +00:00
|
|
|
$foo->Foo = 12;
|
|
|
|
$foo->write();
|
|
|
|
|
|
|
|
// For base classes, aggregate is calculcated on it and all children classes
|
2012-03-27 17:04:11 +13:00
|
|
|
$this->assertEquals($fab->Aggregate('AggregateTest_Foo')->Max('Foo'), 12);
|
2010-04-12 05:04:34 +00:00
|
|
|
|
|
|
|
// For subclasses, aggregate is calculated for that subclass and it's children only
|
2012-03-27 17:04:11 +13:00
|
|
|
$this->assertEquals($fab->Aggregate('AggregateTest_Fab')->Max('Foo'), 9);
|
|
|
|
$this->assertEquals($fab->Aggregate('AggregateTest_Fac')->Max('Foo'), 6);
|
2010-04-12 05:04:34 +00:00
|
|
|
|
|
|
|
$fab->Foo = 15;
|
|
|
|
$fab->write();
|
|
|
|
|
|
|
|
// For base classes, aggregate is calculcated on it and all children classes
|
2012-03-27 17:04:11 +13:00
|
|
|
$this->assertEquals($fab->Aggregate('AggregateTest_Foo')->Max('Foo'), 15);
|
2010-04-12 05:04:34 +00:00
|
|
|
|
|
|
|
// For subclasses, aggregate is calculated for that subclass and it's children only
|
2012-03-27 17:04:11 +13:00
|
|
|
$this->assertEquals($fab->Aggregate('AggregateTest_Fab')->Max('Foo'), 15);
|
|
|
|
$this->assertEquals($fab->Aggregate('AggregateTest_Fac')->Max('Foo'), 6);
|
2010-04-12 05:04:34 +00:00
|
|
|
}
|
|
|
|
/* */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Test basic relationship aggregation
|
|
|
|
*/
|
2012-09-19 12:07:39 +02:00
|
|
|
public function testRelationshipAggregate() {
|
2010-04-12 05:04:34 +00:00
|
|
|
$bar1 = $this->objFromFixture('AggregateTest_Bar', 'bar1');
|
|
|
|
$this->assertEquals($bar1->RelationshipAggregate('Foos')->Max('Foo'), 8);
|
|
|
|
|
|
|
|
$baz1 = $this->objFromFixture('AggregateTest_Baz', 'baz1');
|
|
|
|
$this->assertEquals($baz1->RelationshipAggregate('Foos')->Max('Foo'), 8);
|
|
|
|
}
|
|
|
|
/* */
|
|
|
|
|
2010-10-13 04:01:20 +00:00
|
|
|
/**
|
|
|
|
* Copied from DataObject::__construct(), special case for MSSQLDatabase.
|
|
|
|
*
|
|
|
|
* @param String
|
|
|
|
* @return String
|
|
|
|
*/
|
|
|
|
protected function formatDate($dateStr) {
|
|
|
|
$dateStr = preg_replace('/:[0-9][0-9][0-9]([ap]m)$/i', ' \\1', $dateStr);
|
|
|
|
return date('Y-m-d H:i:s', strtotime($dateStr));
|
|
|
|
}
|
2010-04-12 05:04:34 +00:00
|
|
|
}
|