mirror of
				https://github.com/phpbb/phpbb.git
				synced 2025-10-26 13:16:14 +01:00 
			
		
		
		
	Merge branch 'develop-olympus' into develop
* develop-olympus: [ticket/10346] Add drop_tables to perform_schema_changes and add tests
This commit is contained in:
		| @@ -649,6 +649,23 @@ class phpbb_db_tools | ||||
| 			$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? | ||||
| 		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))) | ||||
| 		); | ||||
|  | ||||
| 		$this->assertTrue($this->tools->sql_table_exists('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', | ||||
| 				), | ||||
| 			), | ||||
| 		)); | ||||
| 	} | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user