1
# Author: Paul Kippes <kippesp@gmail.com>
4
import sqlite3 as sqlite
6
class DumpTests(unittest.TestCase):
8
self.cx = sqlite.connect(":memory:")
9
self.cu = self.cx.cursor()
14
def CheckTableDump(self):
16
"CREATE TABLE t1(id integer primary key, s1 text, " \
17
"t1_i1 integer not null, i2 integer, unique (s1), " \
18
"constraint t1_idx1 unique (i2));"
20
"INSERT INTO \"t1\" VALUES(1,'foo',10,20);"
22
"INSERT INTO \"t1\" VALUES(2,'foo2',30,30);"
24
"CREATE TABLE t2(id integer, t2_i1 integer, " \
25
"t2_i2 integer, primary key (id)," \
26
"foreign key(t2_i1) references t1(t1_i1));"
28
"CREATE TRIGGER trigger_1 update of t1_i1 on t1 " \
30
"update t2 set t2_i1 = new.t1_i1 where t2_i1 = old.t1_i1; " \
33
"CREATE VIEW v1 as select * from t1 left join t2 " \
36
[self.cu.execute(s) for s in expected_sqls]
37
i = self.cx.iterdump()
38
actual_sqls = [s for s in i]
39
expected_sqls = ['BEGIN TRANSACTION;'] + expected_sqls + \
41
[self.assertEqual(expected_sqls[i], actual_sqls[i])
42
for i in xrange(len(expected_sqls))]
45
return unittest.TestSuite(unittest.makeSuite(DumpTests, "Check"))
48
runner = unittest.TextTestRunner()
51
if __name__ == "__main__":