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