mirror of
https://github.com/phpbb/phpbb.git
synced 2025-06-08 04:18:52 +00:00
[ticket/10346] Add drop_tables to perform_schema_changes and add tests
PHPBB3-10346
This commit is contained in:
parent
0d41385344
commit
0f2e45800e
2 changed files with 77 additions and 0 deletions
|
@ -649,6 +649,23 @@ class phpbb_db_tools
|
||||||
$sqlite = true;
|
$sqlite = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Drop tables?
|
||||||
|
if (!empty($schema_changes['drop_tables']))
|
||||||
|
{
|
||||||
|
foreach ($schema_changes['drop_tables'] as $table)
|
||||||
|
{
|
||||||
|
// only drop table if it exists
|
||||||
|
if ($this->sql_table_exists($table))
|
||||||
|
{
|
||||||
|
$result = $this->sql_table_drop($table);
|
||||||
|
if ($this->return_statements)
|
||||||
|
{
|
||||||
|
$statements = array_merge($statements, $result);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Add tables?
|
// Add tables?
|
||||||
if (!empty($schema_changes['add_tables']))
|
if (!empty($schema_changes['add_tables']))
|
||||||
{
|
{
|
||||||
|
|
|
@ -271,6 +271,66 @@ class phpbb_dbal_db_tools_test extends phpbb_database_test_case
|
||||||
'foo' => array('UINT', 42)))
|
'foo' => array('UINT', 42)))
|
||||||
);
|
);
|
||||||
|
|
||||||
|
$this->assertTrue($this->tools->sql_table_exists('prefix_test_table'));
|
||||||
|
|
||||||
$this->tools->sql_table_drop('prefix_test_table');
|
$this->tools->sql_table_drop('prefix_test_table');
|
||||||
|
|
||||||
|
$this->assertFalse($this->tools->sql_table_exists('prefix_test_table'));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function test_peform_schema_changes_drop_tables()
|
||||||
|
{
|
||||||
|
$db_tools = $this->getMock('phpbb_db_tools', array(
|
||||||
|
'sql_table_exists',
|
||||||
|
'sql_table_drop',
|
||||||
|
), array(&$this->db));
|
||||||
|
|
||||||
|
// pretend all tables exist
|
||||||
|
$db_tools->expects($this->any())->method('sql_table_exists')
|
||||||
|
->will($this->returnValue(true));
|
||||||
|
|
||||||
|
// drop tables
|
||||||
|
$db_tools->expects($this->exactly(2))->method('sql_table_drop');
|
||||||
|
$db_tools->expects($this->at(1))->method('sql_table_drop')
|
||||||
|
->with($this->equalTo('dropped_table_1'));
|
||||||
|
$db_tools->expects($this->at(3))->method('sql_table_drop')
|
||||||
|
->with($this->equalTo('dropped_table_2'));
|
||||||
|
|
||||||
|
$db_tools->perform_schema_changes(array(
|
||||||
|
'drop_tables' => array(
|
||||||
|
'dropped_table_1',
|
||||||
|
'dropped_table_2',
|
||||||
|
),
|
||||||
|
));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function test_peform_schema_changes_drop_columns()
|
||||||
|
{
|
||||||
|
$db_tools = $this->getMock('phpbb_db_tools', array(
|
||||||
|
'sql_column_exists',
|
||||||
|
'sql_column_remove',
|
||||||
|
), array(&$this->db));
|
||||||
|
|
||||||
|
// pretend all columns exist
|
||||||
|
$db_tools->expects($this->any())->method('sql_column_exists')
|
||||||
|
->will($this->returnValue(true));
|
||||||
|
$db_tools->expects($this->any())->method('sql_column_exists')
|
||||||
|
->will($this->returnValue(true));
|
||||||
|
|
||||||
|
// drop columns
|
||||||
|
$db_tools->expects($this->exactly(2))->method('sql_column_remove');
|
||||||
|
$db_tools->expects($this->at(1))->method('sql_column_remove')
|
||||||
|
->with($this->equalTo('existing_table'), $this->equalTo('dropped_column_1'));
|
||||||
|
$db_tools->expects($this->at(3))->method('sql_column_remove')
|
||||||
|
->with($this->equalTo('existing_table'), $this->equalTo('dropped_column_2'));
|
||||||
|
|
||||||
|
$db_tools->perform_schema_changes(array(
|
||||||
|
'drop_columns' => array(
|
||||||
|
'existing_table' => array(
|
||||||
|
'dropped_column_1',
|
||||||
|
'dropped_column_2',
|
||||||
|
),
|
||||||
|
),
|
||||||
|
));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue