Пример #1
0
 def testAllColumns(self, mock_query):
     db_result = ResultSet()
     db_result.rows = [('col_1', 'type'), ('col_2', 'type2')]
     mock_query.return_value = db_result
     new_engine = MssqlEngine(instance=self.ins1)
     dbs = new_engine.get_all_columns_by_tb('some_db', 'some_tb')
     self.assertEqual(dbs.rows, ['col_1', 'col_2'])
Пример #2
0
 def testAllDb(self, mock_query):
     db_result = ResultSet()
     db_result.rows = [('db_1', ), ('db_2', )]
     mock_query.return_value = db_result
     new_engine = MssqlEngine(instance=self.ins1)
     dbs = new_engine.get_all_databases()
     self.assertEqual(dbs.rows, ['db_1', 'db_2'])
Пример #3
0
 def testAllTables(self, mock_query):
     table_result = ResultSet()
     table_result.rows = [('tb_1', 'some_des'), ('tb_2', 'some_des')]
     mock_query.return_value = table_result
     new_engine = MssqlEngine(instance=self.ins1)
     tables = new_engine.get_all_tables('some_db')
     mock_query.assert_called_once_with(db_name='some_db', sql=ANY)
     self.assertEqual(tables, ['tb_1', 'tb_2'])
Пример #4
0
 def testQueryCheck(self):
     new_engine = MssqlEngine(instance=self.ins1)
     # 只抽查一个函数
     banned_sql = 'select concat(phone,1) from user_table'
     check_result = new_engine.query_check(db_name='some_db', sql=banned_sql)
     self.assertTrue(check_result.get('bad_query'))
     banned_sql = 'select phone from user_table where phone=concat(phone,1)'
     check_result = new_engine.query_check(db_name='some_db', sql=banned_sql)
     self.assertTrue(check_result.get('bad_query'))
Пример #5
0
 def testQuery(self, connect):
     cur = Mock()
     connect.return_value.cursor = cur
     cur.return_value.execute = Mock()
     cur.return_value.fetchmany.return_value = (('v1', 'v2'),)
     cur.return_value.description = (('k1', 'some_other_des'), ('k2', 'some_other_des'))
     new_engine = MssqlEngine(instance=self.ins1)
     query_result = new_engine.query(sql='some_str', limit_num=100)
     cur.return_value.execute.assert_called()
     cur.return_value.fetchmany.assert_called_once_with(100)
     connect.return_value.close.assert_called_once()
     self.assertIsInstance(query_result, ResultSet)
Пример #6
0
 def setUpClass(cls):
     cls.ins1 = Instance(instance_name='some_ins',
                         type='slave',
                         db_type='mssql',
                         host='some_host',
                         port=1366,
                         user='******',
                         password='******')
     cls.ins1.save()
     cls.engine = MssqlEngine(instance=cls.ins1)
Пример #7
0
 def testGetConnection(self, connect):
     new_engine = MssqlEngine(instance=self.ins1)
     new_engine.get_connection()
     connect.assert_called_once()
Пример #8
0
 def test_filter_sql(self):
     new_engine = MssqlEngine(instance=self.ins1)
     # 只抽查一个函数
     banned_sql = 'select user from user_table'
     check_result = new_engine.filter_sql(sql=banned_sql, limit_num=10)
     self.assertEqual(check_result, "select top 10 user from user_table")
Пример #9
0
 def testDescribe(self, mock_query):
     new_engine = MssqlEngine(instance=self.ins1)
     new_engine.describe_table('some_db', 'some_db')
     mock_query.assert_called_once()