dump.py revision a98be45f18156e33a1a6bad0480a8d2dbb857798
1# Author: Paul Kippes <kippesp@gmail.com>
2
3import unittest
4import sqlite3 as sqlite
5
6class DumpTests(unittest.TestCase):
7    def setUp(self):
8        self.cx = sqlite.connect(":memory:")
9        self.cu = self.cx.cursor()
10
11    def tearDown(self):
12        self.cx.close()
13
14    def CheckTableDump(self):
15        expected_sqls = [
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));"
19                ,
20                "INSERT INTO \"t1\" VALUES(1,'foo',10,20);"
21                ,
22                "INSERT INTO \"t1\" VALUES(2,'foo2',30,30);"
23                ,
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));"
27                ,
28                "CREATE TRIGGER trigger_1 update of t1_i1 on t1 " \
29                "begin " \
30                "update t2 set t2_i1 = new.t1_i1 where t2_i1 = old.t1_i1; " \
31                "end;"
32                ,
33                "CREATE VIEW v1 as select * from t1 left join t2 " \
34                "using (id);"
35                ]
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 + \
40            ['COMMIT;']
41        [self.assertEqual(expected_sqls[i], actual_sqls[i])
42            for i in xrange(len(expected_sqls))]
43
44def suite():
45    return unittest.TestSuite(unittest.makeSuite(DumpTests, "Check"))
46
47def test():
48    runner = unittest.TextTestRunner()
49    runner.run(suite())
50
51if __name__ == "__main__":
52    test()
53