2010-10-13 04:06:50 +00:00
|
|
|
<?php
|
|
|
|
/**
|
2012-04-12 18:02:46 +12:00
|
|
|
* @package framework
|
2010-10-13 04:06:50 +00:00
|
|
|
* @subpackage testing
|
|
|
|
*/
|
|
|
|
|
|
|
|
class MySQLDatabaseTest extends SapphireTest {
|
|
|
|
protected $extraDataObjects = array(
|
|
|
|
'MySQLDatabaseTest_DO',
|
|
|
|
);
|
|
|
|
|
|
|
|
function setUp() {
|
|
|
|
if(DB::getConn() instanceof MySQLDatabase) {
|
|
|
|
MySQLDatabaseTest_DO::$db = array(
|
|
|
|
'MultiEnum1' => 'MultiEnum("A, B, C, D","")',
|
|
|
|
'MultiEnum2' => 'MultiEnum("A, B, C, D","A")',
|
|
|
|
'MultiEnum3' => 'MultiEnum("A, B, C, D","A, B")',
|
|
|
|
);
|
|
|
|
}
|
2012-08-21 19:05:21 +12:00
|
|
|
$this->markTestSkipped('This test requires the Config API to be immutable');
|
2010-10-13 04:06:50 +00:00
|
|
|
parent::setUp();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Check that once a schema has been generated, then it doesn't need any more updating
|
|
|
|
*/
|
|
|
|
function testFieldsDontRerequestChanges() {
|
|
|
|
// These are MySQL specific :-S
|
|
|
|
if(DB::getConn() instanceof MySQLDatabase) {
|
|
|
|
$db = DB::getConn();
|
|
|
|
DB::quiet();
|
|
|
|
|
|
|
|
// Verify that it doesn't need to be recreated
|
|
|
|
$db->beginSchemaUpdate();
|
|
|
|
$obj = new MySQLDatabaseTest_DO();
|
|
|
|
$obj->requireTable();
|
2012-05-10 14:11:33 +12:00
|
|
|
$needsUpdating = $db->doesSchemaNeedUpdating();
|
2010-10-13 04:06:50 +00:00
|
|
|
$db->cancelSchemaUpdate();
|
2012-05-10 14:11:33 +12:00
|
|
|
|
|
|
|
$this->assertFalse($needsUpdating);
|
2010-10-13 04:06:50 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
class MySQLDatabaseTest_DO extends DataObject implements TestOnly {
|
|
|
|
static $db = array();
|
|
|
|
|
2012-03-24 16:04:52 +13:00
|
|
|
}
|