1#!/usr/bin/python2 2 3import unittest 4import common 5from autotest_lib.client.common_lib.test_utils import mock 6from autotest_lib.database import migrate, db_utils 7 8class UtilsTest(unittest.TestCase): 9 10 EXISTS_QUERY_BASE = ('SELECT table_name FROM information_schema.%s ' 11 'WHERE table_schema = %%s') 12 DB_NAME = 'test_db' 13 14 15 def setUp(self): 16 self.god = mock.mock_god() 17 self.manager = self.god.create_mock_class(migrate.MigrationManager, 18 'manager') 19 20 self.god.stub_function(self.manager, 'execute') 21 self.god.stub_function(self.manager, 'get_db_name') 22 23 24 def tearDown(self): 25 self.god.unstub_all() 26 27 28 def test_check_exists(self): 29 views = ('view1', 'view2') 30 def _call_check_exists(): 31 db_utils.check_exists(self.manager, views, db_utils.VIEW_TYPE) 32 33 self._setup_exists_expects(views, 'VIEWS') 34 _call_check_exists() 35 self.god.check_playback() 36 37 self._setup_exists_expects(('view1',), 'VIEWS') 38 self.assertRaises(Exception, _call_check_exists) 39 self.god.check_playback() 40 41 42 def test_drop_views(self): 43 views = ('view1', 'view2') 44 self._setup_exists_expects(views, 'VIEWS') 45 46 for view in views: 47 self.manager.execute.expect_call('DROP VIEW `%s`' % view) 48 49 db_utils.drop_views(self.manager, views) 50 self.god.check_playback() 51 52 53 def test_rename(self): 54 mapping = { 55 'table1' : 'new_table1', 56 'table2' : 'new_table2', 57 } 58 self._setup_exists_expects((name for name, _ in mapping.iteritems()), 59 'TABLES') 60 61 for name, new_name in mapping.iteritems(): 62 self.manager.execute.expect_call( 63 'RENAME TABLE `%s` TO `%s`' % (name, new_name)) 64 65 db_utils.rename(self.manager, mapping) 66 self.god.check_playback() 67 68 69 def _setup_exists_expects(self, names, table): 70 self.manager.get_db_name.expect_call().and_return(self.DB_NAME) 71 self.manager.execute.expect_call( 72 self.EXISTS_QUERY_BASE % table, self.DB_NAME).and_return( 73 self._create_exists_query_result(names)) 74 75 76 def _create_exists_query_result(self, names): 77 return ((name, None) for name in names) 78 79 80if __name__ == '__main__': 81 unittest.main() 82