Mercurial > p > roundup > code
annotate test/test_db.py @ 1378:5d1fe5d51c12
note on how to fix mysql tests - also indicate which tests are being run
| author | Richard Jones <richard@users.sourceforge.net> |
|---|---|
| date | Tue, 14 Jan 2003 10:52:05 +0000 |
| parents | faf93d3fbf2f |
| children | 083cce7840aa |
| rev | line source |
|---|---|
|
213
d45384bc6420
Added the copyright/license notice to (nearly) all files...
Richard Jones <richard@users.sourceforge.net>
parents:
158
diff
changeset
|
1 # |
|
d45384bc6420
Added the copyright/license notice to (nearly) all files...
Richard Jones <richard@users.sourceforge.net>
parents:
158
diff
changeset
|
2 # Copyright (c) 2001 Bizar Software Pty Ltd (http://www.bizarsoftware.com.au/) |
|
d45384bc6420
Added the copyright/license notice to (nearly) all files...
Richard Jones <richard@users.sourceforge.net>
parents:
158
diff
changeset
|
3 # This module is free software, and you may redistribute it and/or modify |
|
d45384bc6420
Added the copyright/license notice to (nearly) all files...
Richard Jones <richard@users.sourceforge.net>
parents:
158
diff
changeset
|
4 # under the same terms as Python, so long as this copyright message and |
|
d45384bc6420
Added the copyright/license notice to (nearly) all files...
Richard Jones <richard@users.sourceforge.net>
parents:
158
diff
changeset
|
5 # disclaimer are retained in their original form. |
|
d45384bc6420
Added the copyright/license notice to (nearly) all files...
Richard Jones <richard@users.sourceforge.net>
parents:
158
diff
changeset
|
6 # |
| 214 | 7 # IN NO EVENT SHALL BIZAR SOFTWARE PTY LTD BE LIABLE TO ANY PARTY FOR |
|
213
d45384bc6420
Added the copyright/license notice to (nearly) all files...
Richard Jones <richard@users.sourceforge.net>
parents:
158
diff
changeset
|
8 # DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES ARISING |
|
d45384bc6420
Added the copyright/license notice to (nearly) all files...
Richard Jones <richard@users.sourceforge.net>
parents:
158
diff
changeset
|
9 # OUT OF THE USE OF THIS CODE, EVEN IF THE AUTHOR HAS BEEN ADVISED OF THE |
|
d45384bc6420
Added the copyright/license notice to (nearly) all files...
Richard Jones <richard@users.sourceforge.net>
parents:
158
diff
changeset
|
10 # POSSIBILITY OF SUCH DAMAGE. |
|
d45384bc6420
Added the copyright/license notice to (nearly) all files...
Richard Jones <richard@users.sourceforge.net>
parents:
158
diff
changeset
|
11 # |
|
d45384bc6420
Added the copyright/license notice to (nearly) all files...
Richard Jones <richard@users.sourceforge.net>
parents:
158
diff
changeset
|
12 # BIZAR SOFTWARE PTY LTD SPECIFICALLY DISCLAIMS ANY WARRANTIES, INCLUDING, |
|
d45384bc6420
Added the copyright/license notice to (nearly) all files...
Richard Jones <richard@users.sourceforge.net>
parents:
158
diff
changeset
|
13 # BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS |
|
d45384bc6420
Added the copyright/license notice to (nearly) all files...
Richard Jones <richard@users.sourceforge.net>
parents:
158
diff
changeset
|
14 # FOR A PARTICULAR PURPOSE. THE CODE PROVIDED HEREUNDER IS ON AN "AS IS" |
|
d45384bc6420
Added the copyright/license notice to (nearly) all files...
Richard Jones <richard@users.sourceforge.net>
parents:
158
diff
changeset
|
15 # BASIS, AND THERE IS NO OBLIGATION WHATSOEVER TO PROVIDE MAINTENANCE, |
|
d45384bc6420
Added the copyright/license notice to (nearly) all files...
Richard Jones <richard@users.sourceforge.net>
parents:
158
diff
changeset
|
16 # SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS. |
|
d45384bc6420
Added the copyright/license notice to (nearly) all files...
Richard Jones <richard@users.sourceforge.net>
parents:
158
diff
changeset
|
17 # |
|
1378
5d1fe5d51c12
note on how to fix mysql tests - also indicate which tests are being run
Richard Jones <richard@users.sourceforge.net>
parents:
1375
diff
changeset
|
18 # $Id: test_db.py,v 1.67 2003-01-14 10:52:05 richard Exp $ |
|
92
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
19 |
|
860
2df32a73eb45
Implemented a switch to disable journalling for a Class.
Richard Jones <richard@users.sourceforge.net>
parents:
859
diff
changeset
|
20 import unittest, os, shutil, time |
|
92
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
21 |
|
270
a4241ddd22d7
Added the Password property type.
Richard Jones <richard@users.sourceforge.net>
parents:
243
diff
changeset
|
22 from roundup.hyperdb import String, Password, Link, Multilink, Date, \ |
|
886
816b593c755f
added tests for boolean type, and fixes to anydbm backend
Richard Jones <richard@users.sourceforge.net>
parents:
868
diff
changeset
|
23 Interval, DatabaseError, Boolean, Number |
|
676
bc46480e2a2b
Fixed serialisation problem...
Richard Jones <richard@users.sourceforge.net>
parents:
646
diff
changeset
|
24 from roundup import date, password |
|
825
0779ea9f1f18
More indexer work:
Richard Jones <richard@users.sourceforge.net>
parents:
785
diff
changeset
|
25 from roundup.indexer import Indexer |
|
92
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
26 |
|
858
2dd862af72ee
all storage-specific code (ie. backend) is now implemented by the backends
Richard Jones <richard@users.sourceforge.net>
parents:
854
diff
changeset
|
27 def setupSchema(db, create, module): |
|
2dd862af72ee
all storage-specific code (ie. backend) is now implemented by the backends
Richard Jones <richard@users.sourceforge.net>
parents:
854
diff
changeset
|
28 status = module.Class(db, "status", name=String()) |
|
92
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
29 status.setkey("name") |
|
886
816b593c755f
added tests for boolean type, and fixes to anydbm backend
Richard Jones <richard@users.sourceforge.net>
parents:
868
diff
changeset
|
30 user = module.Class(db, "user", username=String(), password=Password(), |
|
905
502a5ae11cc5
Very close now. The cgi and mailgw now use the new security API.
Richard Jones <richard@users.sourceforge.net>
parents:
902
diff
changeset
|
31 assignable=Boolean(), age=Number(), roles=String()) |
|
902
b0d3d3535998
Bugger it. Here's the current shape of the new security implementation.
Richard Jones <richard@users.sourceforge.net>
parents:
891
diff
changeset
|
32 user.setkey("username") |
|
858
2dd862af72ee
all storage-specific code (ie. backend) is now implemented by the backends
Richard Jones <richard@users.sourceforge.net>
parents:
854
diff
changeset
|
33 file = module.FileClass(db, "file", name=String(), type=String(), |
|
1176
bd3b57859c37
On second thought, that last checkin was dumb.
Richard Jones <richard@users.sourceforge.net>
parents:
1174
diff
changeset
|
34 comment=String(indexme="yes"), fooz=Password()) |
|
858
2dd862af72ee
all storage-specific code (ie. backend) is now implemented by the backends
Richard Jones <richard@users.sourceforge.net>
parents:
854
diff
changeset
|
35 issue = module.IssueClass(db, "issue", title=String(indexme="yes"), |
|
825
0779ea9f1f18
More indexer work:
Richard Jones <richard@users.sourceforge.net>
parents:
785
diff
changeset
|
36 status=Link("status"), nosy=Multilink("user"), deadline=Date(), |
|
902
b0d3d3535998
Bugger it. Here's the current shape of the new security implementation.
Richard Jones <richard@users.sourceforge.net>
parents:
891
diff
changeset
|
37 foo=Interval(), files=Multilink("file"), assignedto=Link('user')) |
|
891
974a4b94c5e3
Implemented the destroy() method needed by the session database...
Richard Jones <richard@users.sourceforge.net>
parents:
890
diff
changeset
|
38 session = module.Class(db, 'session', title=String()) |
|
974a4b94c5e3
Implemented the destroy() method needed by the session database...
Richard Jones <richard@users.sourceforge.net>
parents:
890
diff
changeset
|
39 session.disableJournalling() |
|
825
0779ea9f1f18
More indexer work:
Richard Jones <richard@users.sourceforge.net>
parents:
785
diff
changeset
|
40 db.post_init() |
|
92
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
41 if create: |
|
1176
bd3b57859c37
On second thought, that last checkin was dumb.
Richard Jones <richard@users.sourceforge.net>
parents:
1174
diff
changeset
|
42 user.create(username="admin", roles='Admin') |
|
92
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
43 status.create(name="unread") |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
44 status.create(name="in-progress") |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
45 status.create(name="testing") |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
46 status.create(name="resolved") |
|
441
698534628072
Added transaction tests to test_db
Richard Jones <richard@users.sourceforge.net>
parents:
432
diff
changeset
|
47 db.commit() |
|
158
86ebcf734a8e
Added more DB to test_db. Can skip tests where imports fail.
Richard Jones <richard@users.sourceforge.net>
parents:
127
diff
changeset
|
48 |
|
86ebcf734a8e
Added more DB to test_db. Can skip tests where imports fail.
Richard Jones <richard@users.sourceforge.net>
parents:
127
diff
changeset
|
49 class MyTestCase(unittest.TestCase): |
|
86ebcf734a8e
Added more DB to test_db. Can skip tests where imports fail.
Richard Jones <richard@users.sourceforge.net>
parents:
127
diff
changeset
|
50 def tearDown(self): |
|
1126
d77b86cc541b
close the databases before test cleanup
Richard Jones <richard@users.sourceforge.net>
parents:
1096
diff
changeset
|
51 self.db.close() |
|
441
698534628072
Added transaction tests to test_db
Richard Jones <richard@users.sourceforge.net>
parents:
432
diff
changeset
|
52 if os.path.exists('_test_dir'): |
|
158
86ebcf734a8e
Added more DB to test_db. Can skip tests where imports fail.
Richard Jones <richard@users.sourceforge.net>
parents:
127
diff
changeset
|
53 shutil.rmtree('_test_dir') |
|
524
dce4c75bef5a
changed all config accesses...
Richard Jones <richard@users.sourceforge.net>
parents:
461
diff
changeset
|
54 |
|
dce4c75bef5a
changed all config accesses...
Richard Jones <richard@users.sourceforge.net>
parents:
461
diff
changeset
|
55 class config: |
|
dce4c75bef5a
changed all config accesses...
Richard Jones <richard@users.sourceforge.net>
parents:
461
diff
changeset
|
56 DATABASE='_test_dir' |
|
dce4c75bef5a
changed all config accesses...
Richard Jones <richard@users.sourceforge.net>
parents:
461
diff
changeset
|
57 MAILHOST = 'localhost' |
|
dce4c75bef5a
changed all config accesses...
Richard Jones <richard@users.sourceforge.net>
parents:
461
diff
changeset
|
58 MAIL_DOMAIN = 'fill.me.in.' |
|
1096
fa7df238e2d4
More cleaning up of configuration, and the "instance" -> "tracker" renaming.
Richard Jones <richard@users.sourceforge.net>
parents:
1090
diff
changeset
|
59 TRACKER_NAME = 'Roundup issue tracker' |
|
fa7df238e2d4
More cleaning up of configuration, and the "instance" -> "tracker" renaming.
Richard Jones <richard@users.sourceforge.net>
parents:
1090
diff
changeset
|
60 TRACKER_EMAIL = 'issue_tracker@%s'%MAIL_DOMAIN |
|
fa7df238e2d4
More cleaning up of configuration, and the "instance" -> "tracker" renaming.
Richard Jones <richard@users.sourceforge.net>
parents:
1090
diff
changeset
|
61 TRACKER_WEB = 'http://some.useful.url/' |
|
524
dce4c75bef5a
changed all config accesses...
Richard Jones <richard@users.sourceforge.net>
parents:
461
diff
changeset
|
62 ADMIN_EMAIL = 'roundup-admin@%s'%MAIL_DOMAIN |
|
dce4c75bef5a
changed all config accesses...
Richard Jones <richard@users.sourceforge.net>
parents:
461
diff
changeset
|
63 FILTER_POSITION = 'bottom' # one of 'top', 'bottom', 'top and bottom' |
|
dce4c75bef5a
changed all config accesses...
Richard Jones <richard@users.sourceforge.net>
parents:
461
diff
changeset
|
64 ANONYMOUS_ACCESS = 'deny' # either 'deny' or 'allow' |
|
dce4c75bef5a
changed all config accesses...
Richard Jones <richard@users.sourceforge.net>
parents:
461
diff
changeset
|
65 ANONYMOUS_REGISTER = 'deny' # either 'deny' or 'allow' |
|
dce4c75bef5a
changed all config accesses...
Richard Jones <richard@users.sourceforge.net>
parents:
461
diff
changeset
|
66 MESSAGES_TO_AUTHOR = 'no' # either 'yes' or 'no' |
|
dce4c75bef5a
changed all config accesses...
Richard Jones <richard@users.sourceforge.net>
parents:
461
diff
changeset
|
67 EMAIL_SIGNATURE_POSITION = 'bottom' |
|
dce4c75bef5a
changed all config accesses...
Richard Jones <richard@users.sourceforge.net>
parents:
461
diff
changeset
|
68 |
|
441
698534628072
Added transaction tests to test_db
Richard Jones <richard@users.sourceforge.net>
parents:
432
diff
changeset
|
69 class anydbmDBTestCase(MyTestCase): |
|
92
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
70 def setUp(self): |
|
158
86ebcf734a8e
Added more DB to test_db. Can skip tests where imports fail.
Richard Jones <richard@users.sourceforge.net>
parents:
127
diff
changeset
|
71 from roundup.backends import anydbm |
|
92
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
72 # remove previous test, ignore errors |
|
524
dce4c75bef5a
changed all config accesses...
Richard Jones <richard@users.sourceforge.net>
parents:
461
diff
changeset
|
73 if os.path.exists(config.DATABASE): |
|
dce4c75bef5a
changed all config accesses...
Richard Jones <richard@users.sourceforge.net>
parents:
461
diff
changeset
|
74 shutil.rmtree(config.DATABASE) |
|
dce4c75bef5a
changed all config accesses...
Richard Jones <richard@users.sourceforge.net>
parents:
461
diff
changeset
|
75 os.makedirs(config.DATABASE + '/files') |
|
1176
bd3b57859c37
On second thought, that last checkin was dumb.
Richard Jones <richard@users.sourceforge.net>
parents:
1174
diff
changeset
|
76 self.db = anydbm.Database(config, 'admin') |
|
858
2dd862af72ee
all storage-specific code (ie. backend) is now implemented by the backends
Richard Jones <richard@users.sourceforge.net>
parents:
854
diff
changeset
|
77 setupSchema(self.db, 1, anydbm) |
|
1333
80d27b7d6db5
implemented whole-database locking
Richard Jones <richard@users.sourceforge.net>
parents:
1305
diff
changeset
|
78 |
|
80d27b7d6db5
implemented whole-database locking
Richard Jones <richard@users.sourceforge.net>
parents:
1305
diff
changeset
|
79 def testIDGeneration(self): |
|
80d27b7d6db5
implemented whole-database locking
Richard Jones <richard@users.sourceforge.net>
parents:
1305
diff
changeset
|
80 id1 = self.db.issue.create(title="spam", status='1') |
|
80d27b7d6db5
implemented whole-database locking
Richard Jones <richard@users.sourceforge.net>
parents:
1305
diff
changeset
|
81 id2 = self.db.issue.create(title="eggs", status='2') |
|
80d27b7d6db5
implemented whole-database locking
Richard Jones <richard@users.sourceforge.net>
parents:
1305
diff
changeset
|
82 self.assertNotEqual(id1, id2) |
|
92
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
83 |
| 888 | 84 def testStringChange(self): |
|
1264
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
85 for commit in (0,1): |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
86 # test set & retrieve |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
87 nid = self.db.issue.create(title="spam", status='1') |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
88 self.assertEqual(self.db.issue.get(nid, 'title'), 'spam') |
| 1143 | 89 |
|
1264
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
90 # change and make sure we retrieve the correct value |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
91 self.db.issue.set(nid, title='eggs') |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
92 if commit: self.db.commit() |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
93 self.assertEqual(self.db.issue.get(nid, 'title'), 'eggs') |
| 1143 | 94 |
|
1264
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
95 def testStringUnset(self): |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
96 for commit in (0,1): |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
97 nid = self.db.issue.create(title="spam", status='1') |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
98 if commit: self.db.commit() |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
99 self.assertEqual(self.db.issue.get(nid, 'title'), 'spam') |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
100 # make sure we can unset |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
101 self.db.issue.set(nid, title=None) |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
102 if commit: self.db.commit() |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
103 self.assertEqual(self.db.issue.get(nid, "title"), None) |
|
785
491049fb8e31
Cleaned up the hyperdb tests
Richard Jones <richard@users.sourceforge.net>
parents:
726
diff
changeset
|
104 |
| 888 | 105 def testLinkChange(self): |
|
1264
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
106 for commit in (0,1): |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
107 nid = self.db.issue.create(title="spam", status='1') |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
108 if commit: self.db.commit() |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
109 self.assertEqual(self.db.issue.get(nid, "status"), '1') |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
110 self.db.issue.set(nid, status='2') |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
111 if commit: self.db.commit() |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
112 self.assertEqual(self.db.issue.get(nid, "status"), '2') |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
113 |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
114 def testLinkUnset(self): |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
115 for commit in (0,1): |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
116 nid = self.db.issue.create(title="spam", status='1') |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
117 if commit: self.db.commit() |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
118 self.db.issue.set(nid, status=None) |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
119 if commit: self.db.commit() |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
120 self.assertEqual(self.db.issue.get(nid, "status"), None) |
|
785
491049fb8e31
Cleaned up the hyperdb tests
Richard Jones <richard@users.sourceforge.net>
parents:
726
diff
changeset
|
121 |
|
976
8c2036dace08
implemented multilink changes (and a unit test)
Richard Jones <richard@users.sourceforge.net>
parents:
974
diff
changeset
|
122 def testMultilinkChange(self): |
|
1264
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
123 for commit in (0,1): |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
124 u1 = self.db.user.create(username='foo%s'%commit) |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
125 u2 = self.db.user.create(username='bar%s'%commit) |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
126 nid = self.db.issue.create(title="spam", nosy=[u1]) |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
127 if commit: self.db.commit() |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
128 self.assertEqual(self.db.issue.get(nid, "nosy"), [u1]) |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
129 self.db.issue.set(nid, nosy=[]) |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
130 if commit: self.db.commit() |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
131 self.assertEqual(self.db.issue.get(nid, "nosy"), []) |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
132 self.db.issue.set(nid, nosy=[u1,u2]) |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
133 if commit: self.db.commit() |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
134 self.assertEqual(self.db.issue.get(nid, "nosy"), [u1,u2]) |
|
976
8c2036dace08
implemented multilink changes (and a unit test)
Richard Jones <richard@users.sourceforge.net>
parents:
974
diff
changeset
|
135 |
| 888 | 136 def testDateChange(self): |
|
1264
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
137 for commit in (0,1): |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
138 nid = self.db.issue.create(title="spam", status='1') |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
139 a = self.db.issue.get(nid, "deadline") |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
140 if commit: self.db.commit() |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
141 self.db.issue.set(nid, deadline=date.Date()) |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
142 b = self.db.issue.get(nid, "deadline") |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
143 if commit: self.db.commit() |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
144 self.assertNotEqual(a, b) |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
145 self.assertNotEqual(b, date.Date('1970-1-1 00:00:00')) |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
146 |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
147 def testDateUnset(self): |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
148 for commit in (0,1): |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
149 nid = self.db.issue.create(title="spam", status='1') |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
150 self.db.issue.set(nid, deadline=date.Date()) |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
151 if commit: self.db.commit() |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
152 self.assertNotEqual(self.db.issue.get(nid, "deadline"), None) |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
153 self.db.issue.set(nid, deadline=None) |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
154 if commit: self.db.commit() |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
155 self.assertEqual(self.db.issue.get(nid, "deadline"), None) |
|
785
491049fb8e31
Cleaned up the hyperdb tests
Richard Jones <richard@users.sourceforge.net>
parents:
726
diff
changeset
|
156 |
| 888 | 157 def testIntervalChange(self): |
|
1264
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
158 for commit in (0,1): |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
159 nid = self.db.issue.create(title="spam", status='1') |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
160 if commit: self.db.commit() |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
161 a = self.db.issue.get(nid, "foo") |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
162 i = date.Interval('-1d') |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
163 self.db.issue.set(nid, foo=i) |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
164 if commit: self.db.commit() |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
165 self.assertNotEqual(self.db.issue.get(nid, "foo"), a) |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
166 self.assertEqual(i, self.db.issue.get(nid, "foo")) |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
167 j = date.Interval('1y') |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
168 self.db.issue.set(nid, foo=j) |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
169 if commit: self.db.commit() |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
170 self.assertNotEqual(self.db.issue.get(nid, "foo"), i) |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
171 self.assertEqual(j, self.db.issue.get(nid, "foo")) |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
172 |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
173 def testIntervalUnset(self): |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
174 for commit in (0,1): |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
175 nid = self.db.issue.create(title="spam", status='1') |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
176 self.db.issue.set(nid, foo=date.Interval('-1d')) |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
177 if commit: self.db.commit() |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
178 self.assertNotEqual(self.db.issue.get(nid, "foo"), None) |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
179 self.db.issue.set(nid, foo=None) |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
180 if commit: self.db.commit() |
|
9e6743c00b5f
more anal unit tests
Richard Jones <richard@users.sourceforge.net>
parents:
1261
diff
changeset
|
181 self.assertEqual(self.db.issue.get(nid, "foo"), None) |
|
785
491049fb8e31
Cleaned up the hyperdb tests
Richard Jones <richard@users.sourceforge.net>
parents:
726
diff
changeset
|
182 |
|
886
816b593c755f
added tests for boolean type, and fixes to anydbm backend
Richard Jones <richard@users.sourceforge.net>
parents:
868
diff
changeset
|
183 def testBooleanChange(self): |
|
902
b0d3d3535998
Bugger it. Here's the current shape of the new security implementation.
Richard Jones <richard@users.sourceforge.net>
parents:
891
diff
changeset
|
184 userid = self.db.user.create(username='foo', assignable=1) |
|
1168
94620e088e3a
fixes to the rdbms backends
Richard Jones <richard@users.sourceforge.net>
parents:
1165
diff
changeset
|
185 self.assertEqual(1, self.db.user.get(userid, 'assignable')) |
|
902
b0d3d3535998
Bugger it. Here's the current shape of the new security implementation.
Richard Jones <richard@users.sourceforge.net>
parents:
891
diff
changeset
|
186 self.db.user.set(userid, assignable=0) |
|
1168
94620e088e3a
fixes to the rdbms backends
Richard Jones <richard@users.sourceforge.net>
parents:
1165
diff
changeset
|
187 self.assertEqual(self.db.user.get(userid, 'assignable'), 0) |
|
94620e088e3a
fixes to the rdbms backends
Richard Jones <richard@users.sourceforge.net>
parents:
1165
diff
changeset
|
188 self.db.user.set(userid, assignable=None) |
|
927
51519406b73e
web forms may now unset Link values (like assignedto)
Richard Jones <richard@users.sourceforge.net>
parents:
905
diff
changeset
|
189 self.assertEqual(self.db.user.get('1', "assignable"), None) |
|
887
e7169d6e6e45
added tests for number type too
Richard Jones <richard@users.sourceforge.net>
parents:
886
diff
changeset
|
190 |
|
e7169d6e6e45
added tests for number type too
Richard Jones <richard@users.sourceforge.net>
parents:
886
diff
changeset
|
191 def testNumberChange(self): |
|
1176
bd3b57859c37
On second thought, that last checkin was dumb.
Richard Jones <richard@users.sourceforge.net>
parents:
1174
diff
changeset
|
192 nid = self.db.user.create(username='foo', age=1) |
|
bd3b57859c37
On second thought, that last checkin was dumb.
Richard Jones <richard@users.sourceforge.net>
parents:
1174
diff
changeset
|
193 self.assertEqual(1, self.db.user.get(nid, 'age')) |
|
1168
94620e088e3a
fixes to the rdbms backends
Richard Jones <richard@users.sourceforge.net>
parents:
1165
diff
changeset
|
194 self.db.user.set('1', age=3) |
|
94620e088e3a
fixes to the rdbms backends
Richard Jones <richard@users.sourceforge.net>
parents:
1165
diff
changeset
|
195 self.assertNotEqual(self.db.user.get('1', 'age'), 1) |
|
94620e088e3a
fixes to the rdbms backends
Richard Jones <richard@users.sourceforge.net>
parents:
1165
diff
changeset
|
196 self.db.user.set('1', age=1.0) |
|
927
51519406b73e
web forms may now unset Link values (like assignedto)
Richard Jones <richard@users.sourceforge.net>
parents:
905
diff
changeset
|
197 self.db.user.set('1', age=None) |
|
51519406b73e
web forms may now unset Link values (like assignedto)
Richard Jones <richard@users.sourceforge.net>
parents:
905
diff
changeset
|
198 self.assertEqual(self.db.user.get('1', "age"), None) |
|
886
816b593c755f
added tests for boolean type, and fixes to anydbm backend
Richard Jones <richard@users.sourceforge.net>
parents:
868
diff
changeset
|
199 |
|
1174
8e318dfaf479
Verify contents of tracker module when the tracker is opened
Richard Jones <richard@users.sourceforge.net>
parents:
1170
diff
changeset
|
200 def testKeyValue(self): |
|
8e318dfaf479
Verify contents of tracker module when the tracker is opened
Richard Jones <richard@users.sourceforge.net>
parents:
1170
diff
changeset
|
201 newid = self.db.user.create(username="spam") |
|
8e318dfaf479
Verify contents of tracker module when the tracker is opened
Richard Jones <richard@users.sourceforge.net>
parents:
1170
diff
changeset
|
202 self.assertEqual(self.db.user.lookup('spam'), newid) |
|
8e318dfaf479
Verify contents of tracker module when the tracker is opened
Richard Jones <richard@users.sourceforge.net>
parents:
1170
diff
changeset
|
203 self.db.commit() |
|
8e318dfaf479
Verify contents of tracker module when the tracker is opened
Richard Jones <richard@users.sourceforge.net>
parents:
1170
diff
changeset
|
204 self.assertEqual(self.db.user.lookup('spam'), newid) |
|
8e318dfaf479
Verify contents of tracker module when the tracker is opened
Richard Jones <richard@users.sourceforge.net>
parents:
1170
diff
changeset
|
205 self.db.user.retire(newid) |
|
8e318dfaf479
Verify contents of tracker module when the tracker is opened
Richard Jones <richard@users.sourceforge.net>
parents:
1170
diff
changeset
|
206 self.assertRaises(KeyError, self.db.user.lookup, 'spam') |
|
8e318dfaf479
Verify contents of tracker module when the tracker is opened
Richard Jones <richard@users.sourceforge.net>
parents:
1170
diff
changeset
|
207 |
|
1378
5d1fe5d51c12
note on how to fix mysql tests - also indicate which tests are being run
Richard Jones <richard@users.sourceforge.net>
parents:
1375
diff
changeset
|
208 # use the key again now that the old is retired |
|
5d1fe5d51c12
note on how to fix mysql tests - also indicate which tests are being run
Richard Jones <richard@users.sourceforge.net>
parents:
1375
diff
changeset
|
209 newid2 = self.db.user.create(username="spam") |
|
5d1fe5d51c12
note on how to fix mysql tests - also indicate which tests are being run
Richard Jones <richard@users.sourceforge.net>
parents:
1375
diff
changeset
|
210 self.assertNotEqual(newid, newid2) |
|
5d1fe5d51c12
note on how to fix mysql tests - also indicate which tests are being run
Richard Jones <richard@users.sourceforge.net>
parents:
1375
diff
changeset
|
211 |
| 888 | 212 def testNewProperty(self): |
|
785
491049fb8e31
Cleaned up the hyperdb tests
Richard Jones <richard@users.sourceforge.net>
parents:
726
diff
changeset
|
213 self.db.issue.create(title="spam", status='1') |
|
92
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
214 self.db.issue.addprop(fixer=Link("user")) |
| 973 | 215 # force any post-init stuff to happen |
| 216 self.db.post_init() | |
|
92
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
217 props = self.db.issue.getprops() |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
218 keys = props.keys() |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
219 keys.sort() |
|
902
b0d3d3535998
Bugger it. Here's the current shape of the new security implementation.
Richard Jones <richard@users.sourceforge.net>
parents:
891
diff
changeset
|
220 self.assertEqual(keys, ['activity', 'assignedto', 'creation', |
|
b0d3d3535998
Bugger it. Here's the current shape of the new security implementation.
Richard Jones <richard@users.sourceforge.net>
parents:
891
diff
changeset
|
221 'creator', 'deadline', 'files', 'fixer', 'foo', 'id', 'messages', |
|
b0d3d3535998
Bugger it. Here's the current shape of the new security implementation.
Richard Jones <richard@users.sourceforge.net>
parents:
891
diff
changeset
|
222 'nosy', 'status', 'superseder', 'title']) |
|
785
491049fb8e31
Cleaned up the hyperdb tests
Richard Jones <richard@users.sourceforge.net>
parents:
726
diff
changeset
|
223 self.assertEqual(self.db.issue.get('1', "fixer"), None) |
|
543
22e0edf7da6e
lots of date/interval related changes: more relaxed date format for input
Richard Jones <richard@users.sourceforge.net>
parents:
524
diff
changeset
|
224 |
| 888 | 225 def testRetire(self): |
|
785
491049fb8e31
Cleaned up the hyperdb tests
Richard Jones <richard@users.sourceforge.net>
parents:
726
diff
changeset
|
226 self.db.issue.create(title="spam", status='1') |
|
491049fb8e31
Cleaned up the hyperdb tests
Richard Jones <richard@users.sourceforge.net>
parents:
726
diff
changeset
|
227 b = self.db.status.get('1', 'name') |
|
491049fb8e31
Cleaned up the hyperdb tests
Richard Jones <richard@users.sourceforge.net>
parents:
726
diff
changeset
|
228 a = self.db.status.list() |
|
491049fb8e31
Cleaned up the hyperdb tests
Richard Jones <richard@users.sourceforge.net>
parents:
726
diff
changeset
|
229 self.db.status.retire('1') |
|
491049fb8e31
Cleaned up the hyperdb tests
Richard Jones <richard@users.sourceforge.net>
parents:
726
diff
changeset
|
230 # make sure the list is different |
|
491049fb8e31
Cleaned up the hyperdb tests
Richard Jones <richard@users.sourceforge.net>
parents:
726
diff
changeset
|
231 self.assertNotEqual(a, self.db.status.list()) |
|
491049fb8e31
Cleaned up the hyperdb tests
Richard Jones <richard@users.sourceforge.net>
parents:
726
diff
changeset
|
232 # can still access the node if necessary |
|
491049fb8e31
Cleaned up the hyperdb tests
Richard Jones <richard@users.sourceforge.net>
parents:
726
diff
changeset
|
233 self.assertEqual(self.db.status.get('1', 'name'), b) |
|
432
f97415cccb9d
Fixes so the tests use commit and not close
Richard Jones <richard@users.sourceforge.net>
parents:
431
diff
changeset
|
234 self.db.commit() |
|
785
491049fb8e31
Cleaned up the hyperdb tests
Richard Jones <richard@users.sourceforge.net>
parents:
726
diff
changeset
|
235 self.assertEqual(self.db.status.get('1', 'name'), b) |
|
491049fb8e31
Cleaned up the hyperdb tests
Richard Jones <richard@users.sourceforge.net>
parents:
726
diff
changeset
|
236 self.assertNotEqual(a, self.db.status.list()) |
|
92
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
237 |
| 888 | 238 def testSerialisation(self): |
|
1253
fe67477e678f
fixes from changes today
Richard Jones <richard@users.sourceforge.net>
parents:
1244
diff
changeset
|
239 nid = self.db.issue.create(title="spam", status='1', |
|
676
bc46480e2a2b
Fixed serialisation problem...
Richard Jones <richard@users.sourceforge.net>
parents:
646
diff
changeset
|
240 deadline=date.Date(), foo=date.Interval('-1d')) |
|
bc46480e2a2b
Fixed serialisation problem...
Richard Jones <richard@users.sourceforge.net>
parents:
646
diff
changeset
|
241 self.db.commit() |
|
1253
fe67477e678f
fixes from changes today
Richard Jones <richard@users.sourceforge.net>
parents:
1244
diff
changeset
|
242 assert isinstance(self.db.issue.get(nid, 'deadline'), date.Date) |
|
fe67477e678f
fixes from changes today
Richard Jones <richard@users.sourceforge.net>
parents:
1244
diff
changeset
|
243 assert isinstance(self.db.issue.get(nid, 'foo'), date.Interval) |
|
fe67477e678f
fixes from changes today
Richard Jones <richard@users.sourceforge.net>
parents:
1244
diff
changeset
|
244 uid = self.db.user.create(username="fozzy", |
|
676
bc46480e2a2b
Fixed serialisation problem...
Richard Jones <richard@users.sourceforge.net>
parents:
646
diff
changeset
|
245 password=password.Password('t. bear')) |
|
bc46480e2a2b
Fixed serialisation problem...
Richard Jones <richard@users.sourceforge.net>
parents:
646
diff
changeset
|
246 self.db.commit() |
|
1253
fe67477e678f
fixes from changes today
Richard Jones <richard@users.sourceforge.net>
parents:
1244
diff
changeset
|
247 assert isinstance(self.db.user.get(uid, 'password'), password.Password) |
|
676
bc46480e2a2b
Fixed serialisation problem...
Richard Jones <richard@users.sourceforge.net>
parents:
646
diff
changeset
|
248 |
| 888 | 249 def testTransactions(self): |
|
646
07abfe8f0c01
use blobfiles in back_anydbm which is used in back_bsddb.
Engelbert Gruber <grubert@users.sourceforge.net>
parents:
570
diff
changeset
|
250 # remember the number of items we started |
|
441
698534628072
Added transaction tests to test_db
Richard Jones <richard@users.sourceforge.net>
parents:
432
diff
changeset
|
251 num_issues = len(self.db.issue.list()) |
|
646
07abfe8f0c01
use blobfiles in back_anydbm which is used in back_bsddb.
Engelbert Gruber <grubert@users.sourceforge.net>
parents:
570
diff
changeset
|
252 num_files = self.db.numfiles() |
|
441
698534628072
Added transaction tests to test_db
Richard Jones <richard@users.sourceforge.net>
parents:
432
diff
changeset
|
253 self.db.issue.create(title="don't commit me!", status='1') |
|
698534628072
Added transaction tests to test_db
Richard Jones <richard@users.sourceforge.net>
parents:
432
diff
changeset
|
254 self.assertNotEqual(num_issues, len(self.db.issue.list())) |
|
698534628072
Added transaction tests to test_db
Richard Jones <richard@users.sourceforge.net>
parents:
432
diff
changeset
|
255 self.db.rollback() |
|
698534628072
Added transaction tests to test_db
Richard Jones <richard@users.sourceforge.net>
parents:
432
diff
changeset
|
256 self.assertEqual(num_issues, len(self.db.issue.list())) |
|
698534628072
Added transaction tests to test_db
Richard Jones <richard@users.sourceforge.net>
parents:
432
diff
changeset
|
257 self.db.issue.create(title="please commit me!", status='1') |
|
698534628072
Added transaction tests to test_db
Richard Jones <richard@users.sourceforge.net>
parents:
432
diff
changeset
|
258 self.assertNotEqual(num_issues, len(self.db.issue.list())) |
|
698534628072
Added transaction tests to test_db
Richard Jones <richard@users.sourceforge.net>
parents:
432
diff
changeset
|
259 self.db.commit() |
|
698534628072
Added transaction tests to test_db
Richard Jones <richard@users.sourceforge.net>
parents:
432
diff
changeset
|
260 self.assertNotEqual(num_issues, len(self.db.issue.list())) |
|
698534628072
Added transaction tests to test_db
Richard Jones <richard@users.sourceforge.net>
parents:
432
diff
changeset
|
261 self.db.rollback() |
|
698534628072
Added transaction tests to test_db
Richard Jones <richard@users.sourceforge.net>
parents:
432
diff
changeset
|
262 self.assertNotEqual(num_issues, len(self.db.issue.list())) |
|
461
b579418f7ed1
Implemented file store rollback.
Richard Jones <richard@users.sourceforge.net>
parents:
441
diff
changeset
|
263 self.db.file.create(name="test", type="text/plain", content="hi") |
|
b579418f7ed1
Implemented file store rollback.
Richard Jones <richard@users.sourceforge.net>
parents:
441
diff
changeset
|
264 self.db.rollback() |
|
646
07abfe8f0c01
use blobfiles in back_anydbm which is used in back_bsddb.
Engelbert Gruber <grubert@users.sourceforge.net>
parents:
570
diff
changeset
|
265 self.assertEqual(num_files, self.db.numfiles()) |
|
07abfe8f0c01
use blobfiles in back_anydbm which is used in back_bsddb.
Engelbert Gruber <grubert@users.sourceforge.net>
parents:
570
diff
changeset
|
266 for i in range(10): |
|
07abfe8f0c01
use blobfiles in back_anydbm which is used in back_bsddb.
Engelbert Gruber <grubert@users.sourceforge.net>
parents:
570
diff
changeset
|
267 self.db.file.create(name="test", type="text/plain", |
|
07abfe8f0c01
use blobfiles in back_anydbm which is used in back_bsddb.
Engelbert Gruber <grubert@users.sourceforge.net>
parents:
570
diff
changeset
|
268 content="hi %d"%(i)) |
|
07abfe8f0c01
use blobfiles in back_anydbm which is used in back_bsddb.
Engelbert Gruber <grubert@users.sourceforge.net>
parents:
570
diff
changeset
|
269 self.db.commit() |
|
07abfe8f0c01
use blobfiles in back_anydbm which is used in back_bsddb.
Engelbert Gruber <grubert@users.sourceforge.net>
parents:
570
diff
changeset
|
270 num_files2 = self.db.numfiles() |
|
07abfe8f0c01
use blobfiles in back_anydbm which is used in back_bsddb.
Engelbert Gruber <grubert@users.sourceforge.net>
parents:
570
diff
changeset
|
271 self.assertNotEqual(num_files, num_files2) |
|
461
b579418f7ed1
Implemented file store rollback.
Richard Jones <richard@users.sourceforge.net>
parents:
441
diff
changeset
|
272 self.db.file.create(name="test", type="text/plain", content="hi") |
|
b579418f7ed1
Implemented file store rollback.
Richard Jones <richard@users.sourceforge.net>
parents:
441
diff
changeset
|
273 self.db.rollback() |
|
646
07abfe8f0c01
use blobfiles in back_anydbm which is used in back_bsddb.
Engelbert Gruber <grubert@users.sourceforge.net>
parents:
570
diff
changeset
|
274 self.assertNotEqual(num_files, self.db.numfiles()) |
|
07abfe8f0c01
use blobfiles in back_anydbm which is used in back_bsddb.
Engelbert Gruber <grubert@users.sourceforge.net>
parents:
570
diff
changeset
|
275 self.assertEqual(num_files2, self.db.numfiles()) |
|
441
698534628072
Added transaction tests to test_db
Richard Jones <richard@users.sourceforge.net>
parents:
432
diff
changeset
|
276 |
|
891
974a4b94c5e3
Implemented the destroy() method needed by the session database...
Richard Jones <richard@users.sourceforge.net>
parents:
890
diff
changeset
|
277 def testDestroyNoJournalling(self): |
|
974a4b94c5e3
Implemented the destroy() method needed by the session database...
Richard Jones <richard@users.sourceforge.net>
parents:
890
diff
changeset
|
278 self.innerTestDestroy(klass=self.db.session) |
|
974a4b94c5e3
Implemented the destroy() method needed by the session database...
Richard Jones <richard@users.sourceforge.net>
parents:
890
diff
changeset
|
279 |
|
974a4b94c5e3
Implemented the destroy() method needed by the session database...
Richard Jones <richard@users.sourceforge.net>
parents:
890
diff
changeset
|
280 def testDestroyJournalling(self): |
|
974a4b94c5e3
Implemented the destroy() method needed by the session database...
Richard Jones <richard@users.sourceforge.net>
parents:
890
diff
changeset
|
281 self.innerTestDestroy(klass=self.db.issue) |
|
974a4b94c5e3
Implemented the destroy() method needed by the session database...
Richard Jones <richard@users.sourceforge.net>
parents:
890
diff
changeset
|
282 |
|
974a4b94c5e3
Implemented the destroy() method needed by the session database...
Richard Jones <richard@users.sourceforge.net>
parents:
890
diff
changeset
|
283 def innerTestDestroy(self, klass): |
|
974a4b94c5e3
Implemented the destroy() method needed by the session database...
Richard Jones <richard@users.sourceforge.net>
parents:
890
diff
changeset
|
284 newid = klass.create(title='Mr Friendly') |
|
974a4b94c5e3
Implemented the destroy() method needed by the session database...
Richard Jones <richard@users.sourceforge.net>
parents:
890
diff
changeset
|
285 n = len(klass.list()) |
|
974a4b94c5e3
Implemented the destroy() method needed by the session database...
Richard Jones <richard@users.sourceforge.net>
parents:
890
diff
changeset
|
286 self.assertEqual(klass.get(newid, 'title'), 'Mr Friendly') |
|
974a4b94c5e3
Implemented the destroy() method needed by the session database...
Richard Jones <richard@users.sourceforge.net>
parents:
890
diff
changeset
|
287 klass.destroy(newid) |
|
974a4b94c5e3
Implemented the destroy() method needed by the session database...
Richard Jones <richard@users.sourceforge.net>
parents:
890
diff
changeset
|
288 self.assertRaises(IndexError, klass.get, newid, 'title') |
|
974a4b94c5e3
Implemented the destroy() method needed by the session database...
Richard Jones <richard@users.sourceforge.net>
parents:
890
diff
changeset
|
289 self.assertNotEqual(len(klass.list()), n) |
|
974a4b94c5e3
Implemented the destroy() method needed by the session database...
Richard Jones <richard@users.sourceforge.net>
parents:
890
diff
changeset
|
290 if klass.do_journal: |
|
974a4b94c5e3
Implemented the destroy() method needed by the session database...
Richard Jones <richard@users.sourceforge.net>
parents:
890
diff
changeset
|
291 self.assertRaises(IndexError, klass.history, newid) |
|
974a4b94c5e3
Implemented the destroy() method needed by the session database...
Richard Jones <richard@users.sourceforge.net>
parents:
890
diff
changeset
|
292 |
|
974a4b94c5e3
Implemented the destroy() method needed by the session database...
Richard Jones <richard@users.sourceforge.net>
parents:
890
diff
changeset
|
293 # now with a commit |
|
974a4b94c5e3
Implemented the destroy() method needed by the session database...
Richard Jones <richard@users.sourceforge.net>
parents:
890
diff
changeset
|
294 newid = klass.create(title='Mr Friendly') |
|
974a4b94c5e3
Implemented the destroy() method needed by the session database...
Richard Jones <richard@users.sourceforge.net>
parents:
890
diff
changeset
|
295 n = len(klass.list()) |
|
974a4b94c5e3
Implemented the destroy() method needed by the session database...
Richard Jones <richard@users.sourceforge.net>
parents:
890
diff
changeset
|
296 self.assertEqual(klass.get(newid, 'title'), 'Mr Friendly') |
|
974a4b94c5e3
Implemented the destroy() method needed by the session database...
Richard Jones <richard@users.sourceforge.net>
parents:
890
diff
changeset
|
297 self.db.commit() |
|
974a4b94c5e3
Implemented the destroy() method needed by the session database...
Richard Jones <richard@users.sourceforge.net>
parents:
890
diff
changeset
|
298 klass.destroy(newid) |
|
974a4b94c5e3
Implemented the destroy() method needed by the session database...
Richard Jones <richard@users.sourceforge.net>
parents:
890
diff
changeset
|
299 self.assertRaises(IndexError, klass.get, newid, 'title') |
|
974a4b94c5e3
Implemented the destroy() method needed by the session database...
Richard Jones <richard@users.sourceforge.net>
parents:
890
diff
changeset
|
300 self.db.commit() |
|
974a4b94c5e3
Implemented the destroy() method needed by the session database...
Richard Jones <richard@users.sourceforge.net>
parents:
890
diff
changeset
|
301 self.assertRaises(IndexError, klass.get, newid, 'title') |
|
974a4b94c5e3
Implemented the destroy() method needed by the session database...
Richard Jones <richard@users.sourceforge.net>
parents:
890
diff
changeset
|
302 self.assertNotEqual(len(klass.list()), n) |
|
974a4b94c5e3
Implemented the destroy() method needed by the session database...
Richard Jones <richard@users.sourceforge.net>
parents:
890
diff
changeset
|
303 if klass.do_journal: |
|
974a4b94c5e3
Implemented the destroy() method needed by the session database...
Richard Jones <richard@users.sourceforge.net>
parents:
890
diff
changeset
|
304 self.assertRaises(IndexError, klass.history, newid) |
|
974a4b94c5e3
Implemented the destroy() method needed by the session database...
Richard Jones <richard@users.sourceforge.net>
parents:
890
diff
changeset
|
305 |
|
974a4b94c5e3
Implemented the destroy() method needed by the session database...
Richard Jones <richard@users.sourceforge.net>
parents:
890
diff
changeset
|
306 # now with a rollback |
|
974a4b94c5e3
Implemented the destroy() method needed by the session database...
Richard Jones <richard@users.sourceforge.net>
parents:
890
diff
changeset
|
307 newid = klass.create(title='Mr Friendly') |
|
974a4b94c5e3
Implemented the destroy() method needed by the session database...
Richard Jones <richard@users.sourceforge.net>
parents:
890
diff
changeset
|
308 n = len(klass.list()) |
|
974a4b94c5e3
Implemented the destroy() method needed by the session database...
Richard Jones <richard@users.sourceforge.net>
parents:
890
diff
changeset
|
309 self.assertEqual(klass.get(newid, 'title'), 'Mr Friendly') |
|
974a4b94c5e3
Implemented the destroy() method needed by the session database...
Richard Jones <richard@users.sourceforge.net>
parents:
890
diff
changeset
|
310 self.db.commit() |
|
974a4b94c5e3
Implemented the destroy() method needed by the session database...
Richard Jones <richard@users.sourceforge.net>
parents:
890
diff
changeset
|
311 klass.destroy(newid) |
|
974a4b94c5e3
Implemented the destroy() method needed by the session database...
Richard Jones <richard@users.sourceforge.net>
parents:
890
diff
changeset
|
312 self.assertNotEqual(len(klass.list()), n) |
|
974a4b94c5e3
Implemented the destroy() method needed by the session database...
Richard Jones <richard@users.sourceforge.net>
parents:
890
diff
changeset
|
313 self.assertRaises(IndexError, klass.get, newid, 'title') |
|
974a4b94c5e3
Implemented the destroy() method needed by the session database...
Richard Jones <richard@users.sourceforge.net>
parents:
890
diff
changeset
|
314 self.db.rollback() |
|
974a4b94c5e3
Implemented the destroy() method needed by the session database...
Richard Jones <richard@users.sourceforge.net>
parents:
890
diff
changeset
|
315 self.assertEqual(klass.get(newid, 'title'), 'Mr Friendly') |
|
974a4b94c5e3
Implemented the destroy() method needed by the session database...
Richard Jones <richard@users.sourceforge.net>
parents:
890
diff
changeset
|
316 self.assertEqual(len(klass.list()), n) |
|
974a4b94c5e3
Implemented the destroy() method needed by the session database...
Richard Jones <richard@users.sourceforge.net>
parents:
890
diff
changeset
|
317 if klass.do_journal: |
|
974a4b94c5e3
Implemented the destroy() method needed by the session database...
Richard Jones <richard@users.sourceforge.net>
parents:
890
diff
changeset
|
318 self.assertNotEqual(klass.history(newid), []) |
|
974a4b94c5e3
Implemented the destroy() method needed by the session database...
Richard Jones <richard@users.sourceforge.net>
parents:
890
diff
changeset
|
319 |
|
887
e7169d6e6e45
added tests for number type too
Richard Jones <richard@users.sourceforge.net>
parents:
886
diff
changeset
|
320 def testExceptions(self): |
|
92
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
321 # this tests the exceptions that should be raised |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
322 ar = self.assertRaises |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
323 |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
324 # |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
325 # class create |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
326 # |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
327 # string property |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
328 ar(TypeError, self.db.status.create, name=1) |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
329 # invalid property name |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
330 ar(KeyError, self.db.status.create, foo='foo') |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
331 # key name clash |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
332 ar(ValueError, self.db.status.create, name='unread') |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
333 # invalid link index |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
334 ar(IndexError, self.db.issue.create, title='foo', status='bar') |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
335 # invalid link value |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
336 ar(ValueError, self.db.issue.create, title='foo', status=1) |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
337 # invalid multilink type |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
338 ar(TypeError, self.db.issue.create, title='foo', status='1', |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
339 nosy='hello') |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
340 # invalid multilink index type |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
341 ar(ValueError, self.db.issue.create, title='foo', status='1', |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
342 nosy=[1]) |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
343 # invalid multilink index |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
344 ar(IndexError, self.db.issue.create, title='foo', status='1', |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
345 nosy=['10']) |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
346 |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
347 # |
|
862
37fb48c3a136
Did some old TODOs
Richard Jones <richard@users.sourceforge.net>
parents:
860
diff
changeset
|
348 # key property |
|
37fb48c3a136
Did some old TODOs
Richard Jones <richard@users.sourceforge.net>
parents:
860
diff
changeset
|
349 # |
|
37fb48c3a136
Did some old TODOs
Richard Jones <richard@users.sourceforge.net>
parents:
860
diff
changeset
|
350 # key must be a String |
|
1176
bd3b57859c37
On second thought, that last checkin was dumb.
Richard Jones <richard@users.sourceforge.net>
parents:
1174
diff
changeset
|
351 ar(TypeError, self.db.file.setkey, 'fooz') |
|
862
37fb48c3a136
Did some old TODOs
Richard Jones <richard@users.sourceforge.net>
parents:
860
diff
changeset
|
352 # key must exist |
|
1176
bd3b57859c37
On second thought, that last checkin was dumb.
Richard Jones <richard@users.sourceforge.net>
parents:
1174
diff
changeset
|
353 ar(KeyError, self.db.file.setkey, 'fubar') |
|
862
37fb48c3a136
Did some old TODOs
Richard Jones <richard@users.sourceforge.net>
parents:
860
diff
changeset
|
354 |
|
37fb48c3a136
Did some old TODOs
Richard Jones <richard@users.sourceforge.net>
parents:
860
diff
changeset
|
355 # |
|
92
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
356 # class get |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
357 # |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
358 # invalid node id |
|
1178
18bb36e4f62f
Remove some assumptions about what idi numbers will be created.
Gordon B. McMillan <gmcm@users.sourceforge.net>
parents:
1176
diff
changeset
|
359 ar(IndexError, self.db.issue.get, '99', 'title') |
|
92
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
360 # invalid property name |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
361 ar(KeyError, self.db.status.get, '2', 'foo') |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
362 |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
363 # |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
364 # class set |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
365 # |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
366 # invalid node id |
|
1178
18bb36e4f62f
Remove some assumptions about what idi numbers will be created.
Gordon B. McMillan <gmcm@users.sourceforge.net>
parents:
1176
diff
changeset
|
367 ar(IndexError, self.db.issue.set, '99', title='foo') |
|
92
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
368 # invalid property name |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
369 ar(KeyError, self.db.status.set, '1', foo='foo') |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
370 # string property |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
371 ar(TypeError, self.db.status.set, '1', name=1) |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
372 # key name clash |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
373 ar(ValueError, self.db.status.set, '2', name='unread') |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
374 # set up a valid issue for me to work on |
|
1178
18bb36e4f62f
Remove some assumptions about what idi numbers will be created.
Gordon B. McMillan <gmcm@users.sourceforge.net>
parents:
1176
diff
changeset
|
375 id = self.db.issue.create(title="spam", status='1') |
|
92
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
376 # invalid link index |
|
1178
18bb36e4f62f
Remove some assumptions about what idi numbers will be created.
Gordon B. McMillan <gmcm@users.sourceforge.net>
parents:
1176
diff
changeset
|
377 ar(IndexError, self.db.issue.set, id, title='foo', status='bar') |
|
92
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
378 # invalid link value |
|
1178
18bb36e4f62f
Remove some assumptions about what idi numbers will be created.
Gordon B. McMillan <gmcm@users.sourceforge.net>
parents:
1176
diff
changeset
|
379 ar(ValueError, self.db.issue.set, id, title='foo', status=1) |
|
92
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
380 # invalid multilink type |
|
1178
18bb36e4f62f
Remove some assumptions about what idi numbers will be created.
Gordon B. McMillan <gmcm@users.sourceforge.net>
parents:
1176
diff
changeset
|
381 ar(TypeError, self.db.issue.set, id, title='foo', status='1', |
|
92
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
382 nosy='hello') |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
383 # invalid multilink index type |
|
1178
18bb36e4f62f
Remove some assumptions about what idi numbers will be created.
Gordon B. McMillan <gmcm@users.sourceforge.net>
parents:
1176
diff
changeset
|
384 ar(ValueError, self.db.issue.set, id, title='foo', status='1', |
|
92
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
385 nosy=[1]) |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
386 # invalid multilink index |
|
1178
18bb36e4f62f
Remove some assumptions about what idi numbers will be created.
Gordon B. McMillan <gmcm@users.sourceforge.net>
parents:
1176
diff
changeset
|
387 ar(IndexError, self.db.issue.set, id, title='foo', status='1', |
|
92
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
388 nosy=['10']) |
|
887
e7169d6e6e45
added tests for number type too
Richard Jones <richard@users.sourceforge.net>
parents:
886
diff
changeset
|
389 # invalid number value |
|
e7169d6e6e45
added tests for number type too
Richard Jones <richard@users.sourceforge.net>
parents:
886
diff
changeset
|
390 ar(TypeError, self.db.user.create, username='foo', age='a') |
|
e7169d6e6e45
added tests for number type too
Richard Jones <richard@users.sourceforge.net>
parents:
886
diff
changeset
|
391 # invalid boolean value |
|
890
a568596dbea7
Unit tests and a few fixes.
Richard Jones <richard@users.sourceforge.net>
parents:
888
diff
changeset
|
392 ar(TypeError, self.db.user.create, username='foo', assignable='true') |
|
1176
bd3b57859c37
On second thought, that last checkin was dumb.
Richard Jones <richard@users.sourceforge.net>
parents:
1174
diff
changeset
|
393 nid = self.db.user.create(username='foo') |
|
887
e7169d6e6e45
added tests for number type too
Richard Jones <richard@users.sourceforge.net>
parents:
886
diff
changeset
|
394 # invalid number value |
|
1176
bd3b57859c37
On second thought, that last checkin was dumb.
Richard Jones <richard@users.sourceforge.net>
parents:
1174
diff
changeset
|
395 ar(TypeError, self.db.user.set, nid, username='foo', age='a') |
|
887
e7169d6e6e45
added tests for number type too
Richard Jones <richard@users.sourceforge.net>
parents:
886
diff
changeset
|
396 # invalid boolean value |
|
1176
bd3b57859c37
On second thought, that last checkin was dumb.
Richard Jones <richard@users.sourceforge.net>
parents:
1174
diff
changeset
|
397 ar(TypeError, self.db.user.set, nid, username='foo', assignable='true') |
|
92
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
398 |
| 888 | 399 def testJournals(self): |
|
555
5fd94347c6f2
Journal entries for link and multilink properties can now be switched on or off.
Roche Compaan <rochecompaan@users.sourceforge.net>
parents:
543
diff
changeset
|
400 self.db.user.create(username="mary") |
|
5fd94347c6f2
Journal entries for link and multilink properties can now be switched on or off.
Roche Compaan <rochecompaan@users.sourceforge.net>
parents:
543
diff
changeset
|
401 self.db.user.create(username="pete") |
|
5fd94347c6f2
Journal entries for link and multilink properties can now be switched on or off.
Roche Compaan <rochecompaan@users.sourceforge.net>
parents:
543
diff
changeset
|
402 self.db.issue.create(title="spam", status='1') |
|
5fd94347c6f2
Journal entries for link and multilink properties can now be switched on or off.
Roche Compaan <rochecompaan@users.sourceforge.net>
parents:
543
diff
changeset
|
403 self.db.commit() |
|
5fd94347c6f2
Journal entries for link and multilink properties can now be switched on or off.
Roche Compaan <rochecompaan@users.sourceforge.net>
parents:
543
diff
changeset
|
404 |
|
5fd94347c6f2
Journal entries for link and multilink properties can now be switched on or off.
Roche Compaan <rochecompaan@users.sourceforge.net>
parents:
543
diff
changeset
|
405 # journal entry for issue create |
|
5fd94347c6f2
Journal entries for link and multilink properties can now be switched on or off.
Roche Compaan <rochecompaan@users.sourceforge.net>
parents:
543
diff
changeset
|
406 journal = self.db.getjournal('issue', '1') |
|
5fd94347c6f2
Journal entries for link and multilink properties can now be switched on or off.
Roche Compaan <rochecompaan@users.sourceforge.net>
parents:
543
diff
changeset
|
407 self.assertEqual(1, len(journal)) |
|
5fd94347c6f2
Journal entries for link and multilink properties can now be switched on or off.
Roche Compaan <rochecompaan@users.sourceforge.net>
parents:
543
diff
changeset
|
408 (nodeid, date_stamp, journaltag, action, params) = journal[0] |
|
5fd94347c6f2
Journal entries for link and multilink properties can now be switched on or off.
Roche Compaan <rochecompaan@users.sourceforge.net>
parents:
543
diff
changeset
|
409 self.assertEqual(nodeid, '1') |
|
1176
bd3b57859c37
On second thought, that last checkin was dumb.
Richard Jones <richard@users.sourceforge.net>
parents:
1174
diff
changeset
|
410 self.assertEqual(journaltag, self.db.user.lookup('admin')) |
|
555
5fd94347c6f2
Journal entries for link and multilink properties can now be switched on or off.
Roche Compaan <rochecompaan@users.sourceforge.net>
parents:
543
diff
changeset
|
411 self.assertEqual(action, 'create') |
|
5fd94347c6f2
Journal entries for link and multilink properties can now be switched on or off.
Roche Compaan <rochecompaan@users.sourceforge.net>
parents:
543
diff
changeset
|
412 keys = params.keys() |
|
5fd94347c6f2
Journal entries for link and multilink properties can now be switched on or off.
Roche Compaan <rochecompaan@users.sourceforge.net>
parents:
543
diff
changeset
|
413 keys.sort() |
|
1305
d8de80de9fc4
oops, fixed unit tests for journal change
Richard Jones <richard@users.sourceforge.net>
parents:
1264
diff
changeset
|
414 self.assertEqual(keys, []) |
|
555
5fd94347c6f2
Journal entries for link and multilink properties can now be switched on or off.
Roche Compaan <rochecompaan@users.sourceforge.net>
parents:
543
diff
changeset
|
415 |
|
5fd94347c6f2
Journal entries for link and multilink properties can now be switched on or off.
Roche Compaan <rochecompaan@users.sourceforge.net>
parents:
543
diff
changeset
|
416 # journal entry for link |
|
5fd94347c6f2
Journal entries for link and multilink properties can now be switched on or off.
Roche Compaan <rochecompaan@users.sourceforge.net>
parents:
543
diff
changeset
|
417 journal = self.db.getjournal('user', '1') |
|
5fd94347c6f2
Journal entries for link and multilink properties can now be switched on or off.
Roche Compaan <rochecompaan@users.sourceforge.net>
parents:
543
diff
changeset
|
418 self.assertEqual(1, len(journal)) |
| 973 | 419 self.db.issue.set('1', assignedto='1') |
|
555
5fd94347c6f2
Journal entries for link and multilink properties can now be switched on or off.
Roche Compaan <rochecompaan@users.sourceforge.net>
parents:
543
diff
changeset
|
420 self.db.commit() |
|
5fd94347c6f2
Journal entries for link and multilink properties can now be switched on or off.
Roche Compaan <rochecompaan@users.sourceforge.net>
parents:
543
diff
changeset
|
421 journal = self.db.getjournal('user', '1') |
|
5fd94347c6f2
Journal entries for link and multilink properties can now be switched on or off.
Roche Compaan <rochecompaan@users.sourceforge.net>
parents:
543
diff
changeset
|
422 self.assertEqual(2, len(journal)) |
|
5fd94347c6f2
Journal entries for link and multilink properties can now be switched on or off.
Roche Compaan <rochecompaan@users.sourceforge.net>
parents:
543
diff
changeset
|
423 (nodeid, date_stamp, journaltag, action, params) = journal[1] |
|
5fd94347c6f2
Journal entries for link and multilink properties can now be switched on or off.
Roche Compaan <rochecompaan@users.sourceforge.net>
parents:
543
diff
changeset
|
424 self.assertEqual('1', nodeid) |
|
1176
bd3b57859c37
On second thought, that last checkin was dumb.
Richard Jones <richard@users.sourceforge.net>
parents:
1174
diff
changeset
|
425 self.assertEqual('1', journaltag) |
|
555
5fd94347c6f2
Journal entries for link and multilink properties can now be switched on or off.
Roche Compaan <rochecompaan@users.sourceforge.net>
parents:
543
diff
changeset
|
426 self.assertEqual('link', action) |
| 973 | 427 self.assertEqual(('issue', '1', 'assignedto'), params) |
|
555
5fd94347c6f2
Journal entries for link and multilink properties can now be switched on or off.
Roche Compaan <rochecompaan@users.sourceforge.net>
parents:
543
diff
changeset
|
428 |
|
5fd94347c6f2
Journal entries for link and multilink properties can now be switched on or off.
Roche Compaan <rochecompaan@users.sourceforge.net>
parents:
543
diff
changeset
|
429 # journal entry for unlink |
| 973 | 430 self.db.issue.set('1', assignedto='2') |
|
555
5fd94347c6f2
Journal entries for link and multilink properties can now be switched on or off.
Roche Compaan <rochecompaan@users.sourceforge.net>
parents:
543
diff
changeset
|
431 self.db.commit() |
|
5fd94347c6f2
Journal entries for link and multilink properties can now be switched on or off.
Roche Compaan <rochecompaan@users.sourceforge.net>
parents:
543
diff
changeset
|
432 journal = self.db.getjournal('user', '1') |
|
5fd94347c6f2
Journal entries for link and multilink properties can now be switched on or off.
Roche Compaan <rochecompaan@users.sourceforge.net>
parents:
543
diff
changeset
|
433 self.assertEqual(3, len(journal)) |
|
5fd94347c6f2
Journal entries for link and multilink properties can now be switched on or off.
Roche Compaan <rochecompaan@users.sourceforge.net>
parents:
543
diff
changeset
|
434 (nodeid, date_stamp, journaltag, action, params) = journal[2] |
|
5fd94347c6f2
Journal entries for link and multilink properties can now be switched on or off.
Roche Compaan <rochecompaan@users.sourceforge.net>
parents:
543
diff
changeset
|
435 self.assertEqual('1', nodeid) |
|
1176
bd3b57859c37
On second thought, that last checkin was dumb.
Richard Jones <richard@users.sourceforge.net>
parents:
1174
diff
changeset
|
436 self.assertEqual('1', journaltag) |
|
555
5fd94347c6f2
Journal entries for link and multilink properties can now be switched on or off.
Roche Compaan <rochecompaan@users.sourceforge.net>
parents:
543
diff
changeset
|
437 self.assertEqual('unlink', action) |
| 973 | 438 self.assertEqual(('issue', '1', 'assignedto'), params) |
|
555
5fd94347c6f2
Journal entries for link and multilink properties can now be switched on or off.
Roche Compaan <rochecompaan@users.sourceforge.net>
parents:
543
diff
changeset
|
439 |
|
860
2df32a73eb45
Implemented a switch to disable journalling for a Class.
Richard Jones <richard@users.sourceforge.net>
parents:
859
diff
changeset
|
440 # test disabling journalling |
|
2df32a73eb45
Implemented a switch to disable journalling for a Class.
Richard Jones <richard@users.sourceforge.net>
parents:
859
diff
changeset
|
441 # ... get the last entry |
|
2df32a73eb45
Implemented a switch to disable journalling for a Class.
Richard Jones <richard@users.sourceforge.net>
parents:
859
diff
changeset
|
442 time.sleep(1) |
|
2df32a73eb45
Implemented a switch to disable journalling for a Class.
Richard Jones <richard@users.sourceforge.net>
parents:
859
diff
changeset
|
443 entry = self.db.getjournal('issue', '1')[-1] |
|
2df32a73eb45
Implemented a switch to disable journalling for a Class.
Richard Jones <richard@users.sourceforge.net>
parents:
859
diff
changeset
|
444 (x, date_stamp, x, x, x) = entry |
|
2df32a73eb45
Implemented a switch to disable journalling for a Class.
Richard Jones <richard@users.sourceforge.net>
parents:
859
diff
changeset
|
445 self.db.issue.disableJournalling() |
|
2df32a73eb45
Implemented a switch to disable journalling for a Class.
Richard Jones <richard@users.sourceforge.net>
parents:
859
diff
changeset
|
446 self.db.issue.set('1', title='hello world') |
|
2df32a73eb45
Implemented a switch to disable journalling for a Class.
Richard Jones <richard@users.sourceforge.net>
parents:
859
diff
changeset
|
447 self.db.commit() |
|
2df32a73eb45
Implemented a switch to disable journalling for a Class.
Richard Jones <richard@users.sourceforge.net>
parents:
859
diff
changeset
|
448 entry = self.db.getjournal('issue', '1')[-1] |
|
2df32a73eb45
Implemented a switch to disable journalling for a Class.
Richard Jones <richard@users.sourceforge.net>
parents:
859
diff
changeset
|
449 (x, date_stamp2, x, x, x) = entry |
|
2df32a73eb45
Implemented a switch to disable journalling for a Class.
Richard Jones <richard@users.sourceforge.net>
parents:
859
diff
changeset
|
450 # see if the change was journalled when it shouldn't have been |
|
2df32a73eb45
Implemented a switch to disable journalling for a Class.
Richard Jones <richard@users.sourceforge.net>
parents:
859
diff
changeset
|
451 self.assertEqual(date_stamp, date_stamp2) |
|
1183
08a13a84ed43
Some speedups - both of the SQL backends can handle using only one cursor.
Richard Jones <richard@users.sourceforge.net>
parents:
1178
diff
changeset
|
452 time.sleep(1) |
|
860
2df32a73eb45
Implemented a switch to disable journalling for a Class.
Richard Jones <richard@users.sourceforge.net>
parents:
859
diff
changeset
|
453 self.db.issue.enableJournalling() |
|
2df32a73eb45
Implemented a switch to disable journalling for a Class.
Richard Jones <richard@users.sourceforge.net>
parents:
859
diff
changeset
|
454 self.db.issue.set('1', title='hello world 2') |
|
2df32a73eb45
Implemented a switch to disable journalling for a Class.
Richard Jones <richard@users.sourceforge.net>
parents:
859
diff
changeset
|
455 self.db.commit() |
|
2df32a73eb45
Implemented a switch to disable journalling for a Class.
Richard Jones <richard@users.sourceforge.net>
parents:
859
diff
changeset
|
456 entry = self.db.getjournal('issue', '1')[-1] |
|
2df32a73eb45
Implemented a switch to disable journalling for a Class.
Richard Jones <richard@users.sourceforge.net>
parents:
859
diff
changeset
|
457 (x, date_stamp2, x, x, x) = entry |
|
2df32a73eb45
Implemented a switch to disable journalling for a Class.
Richard Jones <richard@users.sourceforge.net>
parents:
859
diff
changeset
|
458 # see if the change was journalled |
|
2df32a73eb45
Implemented a switch to disable journalling for a Class.
Richard Jones <richard@users.sourceforge.net>
parents:
859
diff
changeset
|
459 self.assertNotEqual(date_stamp, date_stamp2) |
|
2df32a73eb45
Implemented a switch to disable journalling for a Class.
Richard Jones <richard@users.sourceforge.net>
parents:
859
diff
changeset
|
460 |
| 888 | 461 def testPack(self): |
|
1178
18bb36e4f62f
Remove some assumptions about what idi numbers will be created.
Gordon B. McMillan <gmcm@users.sourceforge.net>
parents:
1176
diff
changeset
|
462 id = self.db.issue.create(title="spam", status='1') |
|
566
73af3e54c309
We need to keep the last 'set' entry in the journal...
Roche Compaan <rochecompaan@users.sourceforge.net>
parents:
562
diff
changeset
|
463 self.db.commit() |
|
1178
18bb36e4f62f
Remove some assumptions about what idi numbers will be created.
Gordon B. McMillan <gmcm@users.sourceforge.net>
parents:
1176
diff
changeset
|
464 self.db.issue.set(id, status='2') |
|
562
62febbd7ffec
You can now use the roundup-admin tool to pack the database
Roche Compaan <rochecompaan@users.sourceforge.net>
parents:
555
diff
changeset
|
465 self.db.commit() |
| 973 | 466 |
| 467 # sleep for at least a second, then get a date to pack at | |
|
1222
bc3bc3248dd1
added Class.find() unit test, fixed implementations
Richard Jones <richard@users.sourceforge.net>
parents:
1198
diff
changeset
|
468 time.sleep(1) |
| 973 | 469 pack_before = date.Date('.') |
| 470 | |
|
1222
bc3bc3248dd1
added Class.find() unit test, fixed implementations
Richard Jones <richard@users.sourceforge.net>
parents:
1198
diff
changeset
|
471 # wait another second and add one more entry |
|
bc3bc3248dd1
added Class.find() unit test, fixed implementations
Richard Jones <richard@users.sourceforge.net>
parents:
1198
diff
changeset
|
472 time.sleep(1) |
|
1178
18bb36e4f62f
Remove some assumptions about what idi numbers will be created.
Gordon B. McMillan <gmcm@users.sourceforge.net>
parents:
1176
diff
changeset
|
473 self.db.issue.set(id, status='3') |
|
566
73af3e54c309
We need to keep the last 'set' entry in the journal...
Roche Compaan <rochecompaan@users.sourceforge.net>
parents:
562
diff
changeset
|
474 self.db.commit() |
|
1222
bc3bc3248dd1
added Class.find() unit test, fixed implementations
Richard Jones <richard@users.sourceforge.net>
parents:
1198
diff
changeset
|
475 jlen = len(self.db.getjournal('issue', id)) |
| 973 | 476 |
| 477 # pack | |
|
562
62febbd7ffec
You can now use the roundup-admin tool to pack the database
Roche Compaan <rochecompaan@users.sourceforge.net>
parents:
555
diff
changeset
|
478 self.db.pack(pack_before) |
| 973 | 479 |
|
974
84216d63ed9c
ahhh, I understand now
Richard Jones <richard@users.sourceforge.net>
parents:
973
diff
changeset
|
480 # we should have the create and last set entries now |
|
1222
bc3bc3248dd1
added Class.find() unit test, fixed implementations
Richard Jones <richard@users.sourceforge.net>
parents:
1198
diff
changeset
|
481 self.assertEqual(jlen-1, len(self.db.getjournal('issue', id))) |
|
562
62febbd7ffec
You can now use the roundup-admin tool to pack the database
Roche Compaan <rochecompaan@users.sourceforge.net>
parents:
555
diff
changeset
|
482 |
| 888 | 483 def testSearching(self): |
|
825
0779ea9f1f18
More indexer work:
Richard Jones <richard@users.sourceforge.net>
parents:
785
diff
changeset
|
484 self.db.file.create(content='hello', type="text/plain") |
|
0779ea9f1f18
More indexer work:
Richard Jones <richard@users.sourceforge.net>
parents:
785
diff
changeset
|
485 self.db.file.create(content='world', type="text/frozz", |
|
0779ea9f1f18
More indexer work:
Richard Jones <richard@users.sourceforge.net>
parents:
785
diff
changeset
|
486 comment='blah blah') |
|
0779ea9f1f18
More indexer work:
Richard Jones <richard@users.sourceforge.net>
parents:
785
diff
changeset
|
487 self.db.issue.create(files=['1', '2'], title="flebble plop") |
|
0779ea9f1f18
More indexer work:
Richard Jones <richard@users.sourceforge.net>
parents:
785
diff
changeset
|
488 self.db.issue.create(title="flebble frooz") |
|
0779ea9f1f18
More indexer work:
Richard Jones <richard@users.sourceforge.net>
parents:
785
diff
changeset
|
489 self.db.commit() |
|
0779ea9f1f18
More indexer work:
Richard Jones <richard@users.sourceforge.net>
parents:
785
diff
changeset
|
490 self.assertEquals(self.db.indexer.search(['hello'], self.db.issue), |
|
0779ea9f1f18
More indexer work:
Richard Jones <richard@users.sourceforge.net>
parents:
785
diff
changeset
|
491 {'1': {'files': ['1']}}) |
|
0779ea9f1f18
More indexer work:
Richard Jones <richard@users.sourceforge.net>
parents:
785
diff
changeset
|
492 self.assertEquals(self.db.indexer.search(['world'], self.db.issue), {}) |
|
0779ea9f1f18
More indexer work:
Richard Jones <richard@users.sourceforge.net>
parents:
785
diff
changeset
|
493 self.assertEquals(self.db.indexer.search(['frooz'], self.db.issue), |
|
0779ea9f1f18
More indexer work:
Richard Jones <richard@users.sourceforge.net>
parents:
785
diff
changeset
|
494 {'2': {}}) |
|
0779ea9f1f18
More indexer work:
Richard Jones <richard@users.sourceforge.net>
parents:
785
diff
changeset
|
495 self.assertEquals(self.db.indexer.search(['flebble'], self.db.issue), |
|
0779ea9f1f18
More indexer work:
Richard Jones <richard@users.sourceforge.net>
parents:
785
diff
changeset
|
496 {'2': {}, '1': {}}) |
|
826
6d7a45c8464a
Added reindex command to roundup-admin.
Richard Jones <richard@users.sourceforge.net>
parents:
825
diff
changeset
|
497 |
| 888 | 498 def testReindexing(self): |
|
826
6d7a45c8464a
Added reindex command to roundup-admin.
Richard Jones <richard@users.sourceforge.net>
parents:
825
diff
changeset
|
499 self.db.issue.create(title="frooz") |
|
6d7a45c8464a
Added reindex command to roundup-admin.
Richard Jones <richard@users.sourceforge.net>
parents:
825
diff
changeset
|
500 self.db.commit() |
|
6d7a45c8464a
Added reindex command to roundup-admin.
Richard Jones <richard@users.sourceforge.net>
parents:
825
diff
changeset
|
501 self.assertEquals(self.db.indexer.search(['frooz'], self.db.issue), |
|
6d7a45c8464a
Added reindex command to roundup-admin.
Richard Jones <richard@users.sourceforge.net>
parents:
825
diff
changeset
|
502 {'1': {}}) |
|
6d7a45c8464a
Added reindex command to roundup-admin.
Richard Jones <richard@users.sourceforge.net>
parents:
825
diff
changeset
|
503 self.db.issue.set('1', title="dooble") |
|
6d7a45c8464a
Added reindex command to roundup-admin.
Richard Jones <richard@users.sourceforge.net>
parents:
825
diff
changeset
|
504 self.db.commit() |
|
6d7a45c8464a
Added reindex command to roundup-admin.
Richard Jones <richard@users.sourceforge.net>
parents:
825
diff
changeset
|
505 self.assertEquals(self.db.indexer.search(['dooble'], self.db.issue), |
|
6d7a45c8464a
Added reindex command to roundup-admin.
Richard Jones <richard@users.sourceforge.net>
parents:
825
diff
changeset
|
506 {'1': {}}) |
|
6d7a45c8464a
Added reindex command to roundup-admin.
Richard Jones <richard@users.sourceforge.net>
parents:
825
diff
changeset
|
507 self.assertEquals(self.db.indexer.search(['frooz'], self.db.issue), {}) |
|
6d7a45c8464a
Added reindex command to roundup-admin.
Richard Jones <richard@users.sourceforge.net>
parents:
825
diff
changeset
|
508 |
| 888 | 509 def testForcedReindexing(self): |
|
826
6d7a45c8464a
Added reindex command to roundup-admin.
Richard Jones <richard@users.sourceforge.net>
parents:
825
diff
changeset
|
510 self.db.issue.create(title="flebble frooz") |
|
6d7a45c8464a
Added reindex command to roundup-admin.
Richard Jones <richard@users.sourceforge.net>
parents:
825
diff
changeset
|
511 self.db.commit() |
|
6d7a45c8464a
Added reindex command to roundup-admin.
Richard Jones <richard@users.sourceforge.net>
parents:
825
diff
changeset
|
512 self.assertEquals(self.db.indexer.search(['flebble'], self.db.issue), |
|
6d7a45c8464a
Added reindex command to roundup-admin.
Richard Jones <richard@users.sourceforge.net>
parents:
825
diff
changeset
|
513 {'1': {}}) |
|
6d7a45c8464a
Added reindex command to roundup-admin.
Richard Jones <richard@users.sourceforge.net>
parents:
825
diff
changeset
|
514 self.db.indexer.quiet = 1 |
|
6d7a45c8464a
Added reindex command to roundup-admin.
Richard Jones <richard@users.sourceforge.net>
parents:
825
diff
changeset
|
515 self.db.indexer.force_reindex() |
|
6d7a45c8464a
Added reindex command to roundup-admin.
Richard Jones <richard@users.sourceforge.net>
parents:
825
diff
changeset
|
516 self.db.post_init() |
|
6d7a45c8464a
Added reindex command to roundup-admin.
Richard Jones <richard@users.sourceforge.net>
parents:
825
diff
changeset
|
517 self.db.indexer.quiet = 9 |
|
6d7a45c8464a
Added reindex command to roundup-admin.
Richard Jones <richard@users.sourceforge.net>
parents:
825
diff
changeset
|
518 self.assertEquals(self.db.indexer.search(['flebble'], self.db.issue), |
|
6d7a45c8464a
Added reindex command to roundup-admin.
Richard Jones <richard@users.sourceforge.net>
parents:
825
diff
changeset
|
519 {'1': {}}) |
|
92
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
520 |
|
1222
bc3bc3248dd1
added Class.find() unit test, fixed implementations
Richard Jones <richard@users.sourceforge.net>
parents:
1198
diff
changeset
|
521 # |
|
bc3bc3248dd1
added Class.find() unit test, fixed implementations
Richard Jones <richard@users.sourceforge.net>
parents:
1198
diff
changeset
|
522 # searching tests follow |
|
bc3bc3248dd1
added Class.find() unit test, fixed implementations
Richard Jones <richard@users.sourceforge.net>
parents:
1198
diff
changeset
|
523 # |
|
bc3bc3248dd1
added Class.find() unit test, fixed implementations
Richard Jones <richard@users.sourceforge.net>
parents:
1198
diff
changeset
|
524 def testFind(self): |
|
bc3bc3248dd1
added Class.find() unit test, fixed implementations
Richard Jones <richard@users.sourceforge.net>
parents:
1198
diff
changeset
|
525 self.db.user.create(username='test') |
|
bc3bc3248dd1
added Class.find() unit test, fixed implementations
Richard Jones <richard@users.sourceforge.net>
parents:
1198
diff
changeset
|
526 ids = [] |
|
bc3bc3248dd1
added Class.find() unit test, fixed implementations
Richard Jones <richard@users.sourceforge.net>
parents:
1198
diff
changeset
|
527 ids.append(self.db.issue.create(status="1", nosy=['1'])) |
|
bc3bc3248dd1
added Class.find() unit test, fixed implementations
Richard Jones <richard@users.sourceforge.net>
parents:
1198
diff
changeset
|
528 oddid = self.db.issue.create(status="2", nosy=['2']) |
|
bc3bc3248dd1
added Class.find() unit test, fixed implementations
Richard Jones <richard@users.sourceforge.net>
parents:
1198
diff
changeset
|
529 ids.append(self.db.issue.create(status="1", nosy=['1','2'])) |
|
bc3bc3248dd1
added Class.find() unit test, fixed implementations
Richard Jones <richard@users.sourceforge.net>
parents:
1198
diff
changeset
|
530 self.db.issue.create(status="3", nosy=['1']) |
|
bc3bc3248dd1
added Class.find() unit test, fixed implementations
Richard Jones <richard@users.sourceforge.net>
parents:
1198
diff
changeset
|
531 ids.sort() |
|
bc3bc3248dd1
added Class.find() unit test, fixed implementations
Richard Jones <richard@users.sourceforge.net>
parents:
1198
diff
changeset
|
532 |
|
bc3bc3248dd1
added Class.find() unit test, fixed implementations
Richard Jones <richard@users.sourceforge.net>
parents:
1198
diff
changeset
|
533 # should match first and third |
|
bc3bc3248dd1
added Class.find() unit test, fixed implementations
Richard Jones <richard@users.sourceforge.net>
parents:
1198
diff
changeset
|
534 got = self.db.issue.find(status='1') |
|
bc3bc3248dd1
added Class.find() unit test, fixed implementations
Richard Jones <richard@users.sourceforge.net>
parents:
1198
diff
changeset
|
535 got.sort() |
|
bc3bc3248dd1
added Class.find() unit test, fixed implementations
Richard Jones <richard@users.sourceforge.net>
parents:
1198
diff
changeset
|
536 self.assertEqual(got, ids) |
|
bc3bc3248dd1
added Class.find() unit test, fixed implementations
Richard Jones <richard@users.sourceforge.net>
parents:
1198
diff
changeset
|
537 |
|
bc3bc3248dd1
added Class.find() unit test, fixed implementations
Richard Jones <richard@users.sourceforge.net>
parents:
1198
diff
changeset
|
538 # none |
|
bc3bc3248dd1
added Class.find() unit test, fixed implementations
Richard Jones <richard@users.sourceforge.net>
parents:
1198
diff
changeset
|
539 self.assertEqual(self.db.issue.find(status='4'), []) |
|
bc3bc3248dd1
added Class.find() unit test, fixed implementations
Richard Jones <richard@users.sourceforge.net>
parents:
1198
diff
changeset
|
540 |
|
bc3bc3248dd1
added Class.find() unit test, fixed implementations
Richard Jones <richard@users.sourceforge.net>
parents:
1198
diff
changeset
|
541 # should match first three |
|
bc3bc3248dd1
added Class.find() unit test, fixed implementations
Richard Jones <richard@users.sourceforge.net>
parents:
1198
diff
changeset
|
542 got = self.db.issue.find(status='1', nosy='2') |
|
bc3bc3248dd1
added Class.find() unit test, fixed implementations
Richard Jones <richard@users.sourceforge.net>
parents:
1198
diff
changeset
|
543 got.sort() |
|
bc3bc3248dd1
added Class.find() unit test, fixed implementations
Richard Jones <richard@users.sourceforge.net>
parents:
1198
diff
changeset
|
544 ids.append(oddid) |
|
bc3bc3248dd1
added Class.find() unit test, fixed implementations
Richard Jones <richard@users.sourceforge.net>
parents:
1198
diff
changeset
|
545 ids.sort() |
|
bc3bc3248dd1
added Class.find() unit test, fixed implementations
Richard Jones <richard@users.sourceforge.net>
parents:
1198
diff
changeset
|
546 self.assertEqual(got, ids) |
|
bc3bc3248dd1
added Class.find() unit test, fixed implementations
Richard Jones <richard@users.sourceforge.net>
parents:
1198
diff
changeset
|
547 |
|
bc3bc3248dd1
added Class.find() unit test, fixed implementations
Richard Jones <richard@users.sourceforge.net>
parents:
1198
diff
changeset
|
548 # none |
|
bc3bc3248dd1
added Class.find() unit test, fixed implementations
Richard Jones <richard@users.sourceforge.net>
parents:
1198
diff
changeset
|
549 self.assertEqual(self.db.issue.find(status='4', nosy='3'), []) |
|
bc3bc3248dd1
added Class.find() unit test, fixed implementations
Richard Jones <richard@users.sourceforge.net>
parents:
1198
diff
changeset
|
550 |
|
1198
1c5bc0e2ed7d
*** empty log message ***
Richard Jones <richard@users.sourceforge.net>
parents:
1183
diff
changeset
|
551 def testStringFind(self): |
|
1c5bc0e2ed7d
*** empty log message ***
Richard Jones <richard@users.sourceforge.net>
parents:
1183
diff
changeset
|
552 ids = [] |
|
1c5bc0e2ed7d
*** empty log message ***
Richard Jones <richard@users.sourceforge.net>
parents:
1183
diff
changeset
|
553 ids.append(self.db.issue.create(title="spam")) |
|
1c5bc0e2ed7d
*** empty log message ***
Richard Jones <richard@users.sourceforge.net>
parents:
1183
diff
changeset
|
554 self.db.issue.create(title="not spam") |
|
1c5bc0e2ed7d
*** empty log message ***
Richard Jones <richard@users.sourceforge.net>
parents:
1183
diff
changeset
|
555 ids.append(self.db.issue.create(title="spam")) |
|
1c5bc0e2ed7d
*** empty log message ***
Richard Jones <richard@users.sourceforge.net>
parents:
1183
diff
changeset
|
556 ids.sort() |
|
1c5bc0e2ed7d
*** empty log message ***
Richard Jones <richard@users.sourceforge.net>
parents:
1183
diff
changeset
|
557 got = self.db.issue.stringFind(title='spam') |
|
1c5bc0e2ed7d
*** empty log message ***
Richard Jones <richard@users.sourceforge.net>
parents:
1183
diff
changeset
|
558 got.sort() |
|
1c5bc0e2ed7d
*** empty log message ***
Richard Jones <richard@users.sourceforge.net>
parents:
1183
diff
changeset
|
559 self.assertEqual(got, ids) |
|
1c5bc0e2ed7d
*** empty log message ***
Richard Jones <richard@users.sourceforge.net>
parents:
1183
diff
changeset
|
560 self.assertEqual(self.db.issue.stringFind(title='fubar'), []) |
|
1c5bc0e2ed7d
*** empty log message ***
Richard Jones <richard@users.sourceforge.net>
parents:
1183
diff
changeset
|
561 |
|
1170
af104fa52746
Added some words to the installation doc about choosing backends.
Richard Jones <richard@users.sourceforge.net>
parents:
1168
diff
changeset
|
562 def filteringSetup(self): |
|
af104fa52746
Added some words to the installation doc about choosing backends.
Richard Jones <richard@users.sourceforge.net>
parents:
1168
diff
changeset
|
563 for user in ( |
|
af104fa52746
Added some words to the installation doc about choosing backends.
Richard Jones <richard@users.sourceforge.net>
parents:
1168
diff
changeset
|
564 {'username': 'bleep'}, |
|
af104fa52746
Added some words to the installation doc about choosing backends.
Richard Jones <richard@users.sourceforge.net>
parents:
1168
diff
changeset
|
565 {'username': 'blop'}, |
|
af104fa52746
Added some words to the installation doc about choosing backends.
Richard Jones <richard@users.sourceforge.net>
parents:
1168
diff
changeset
|
566 {'username': 'blorp'}): |
|
af104fa52746
Added some words to the installation doc about choosing backends.
Richard Jones <richard@users.sourceforge.net>
parents:
1168
diff
changeset
|
567 self.db.user.create(**user) |
|
af104fa52746
Added some words to the installation doc about choosing backends.
Richard Jones <richard@users.sourceforge.net>
parents:
1168
diff
changeset
|
568 iss = self.db.issue |
|
af104fa52746
Added some words to the installation doc about choosing backends.
Richard Jones <richard@users.sourceforge.net>
parents:
1168
diff
changeset
|
569 for issue in ( |
|
af104fa52746
Added some words to the installation doc about choosing backends.
Richard Jones <richard@users.sourceforge.net>
parents:
1168
diff
changeset
|
570 {'title': 'issue one', 'status': '2'}, |
|
af104fa52746
Added some words to the installation doc about choosing backends.
Richard Jones <richard@users.sourceforge.net>
parents:
1168
diff
changeset
|
571 {'title': 'issue two', 'status': '1'}, |
|
af104fa52746
Added some words to the installation doc about choosing backends.
Richard Jones <richard@users.sourceforge.net>
parents:
1168
diff
changeset
|
572 {'title': 'issue three', 'status': '1', 'nosy': ['1','2']}): |
|
af104fa52746
Added some words to the installation doc about choosing backends.
Richard Jones <richard@users.sourceforge.net>
parents:
1168
diff
changeset
|
573 self.db.issue.create(**issue) |
|
af104fa52746
Added some words to the installation doc about choosing backends.
Richard Jones <richard@users.sourceforge.net>
parents:
1168
diff
changeset
|
574 self.db.commit() |
|
af104fa52746
Added some words to the installation doc about choosing backends.
Richard Jones <richard@users.sourceforge.net>
parents:
1168
diff
changeset
|
575 return self.assertEqual, self.db.issue.filter |
|
af104fa52746
Added some words to the installation doc about choosing backends.
Richard Jones <richard@users.sourceforge.net>
parents:
1168
diff
changeset
|
576 |
|
1365
4884fb0860f9
fixed rdbms searching by ID [SF#666615]
Richard Jones <richard@users.sourceforge.net>
parents:
1361
diff
changeset
|
577 def testFilteringID(self): |
|
4884fb0860f9
fixed rdbms searching by ID [SF#666615]
Richard Jones <richard@users.sourceforge.net>
parents:
1361
diff
changeset
|
578 ae, filt = self.filteringSetup() |
|
4884fb0860f9
fixed rdbms searching by ID [SF#666615]
Richard Jones <richard@users.sourceforge.net>
parents:
1361
diff
changeset
|
579 ae(filt(None, {'id': '1'}, ('+','id'), (None,None)), ['1']) |
|
4884fb0860f9
fixed rdbms searching by ID [SF#666615]
Richard Jones <richard@users.sourceforge.net>
parents:
1361
diff
changeset
|
580 |
|
1170
af104fa52746
Added some words to the installation doc about choosing backends.
Richard Jones <richard@users.sourceforge.net>
parents:
1168
diff
changeset
|
581 def testFilteringString(self): |
|
af104fa52746
Added some words to the installation doc about choosing backends.
Richard Jones <richard@users.sourceforge.net>
parents:
1168
diff
changeset
|
582 ae, filt = self.filteringSetup() |
|
af104fa52746
Added some words to the installation doc about choosing backends.
Richard Jones <richard@users.sourceforge.net>
parents:
1168
diff
changeset
|
583 ae(filt(None, {'title': 'issue one'}, ('+','id'), (None,None)), ['1']) |
|
af104fa52746
Added some words to the installation doc about choosing backends.
Richard Jones <richard@users.sourceforge.net>
parents:
1168
diff
changeset
|
584 ae(filt(None, {'title': 'issue'}, ('+','id'), (None,None)), |
|
af104fa52746
Added some words to the installation doc about choosing backends.
Richard Jones <richard@users.sourceforge.net>
parents:
1168
diff
changeset
|
585 ['1','2','3']) |
|
af104fa52746
Added some words to the installation doc about choosing backends.
Richard Jones <richard@users.sourceforge.net>
parents:
1168
diff
changeset
|
586 |
|
af104fa52746
Added some words to the installation doc about choosing backends.
Richard Jones <richard@users.sourceforge.net>
parents:
1168
diff
changeset
|
587 def testFilteringLink(self): |
|
af104fa52746
Added some words to the installation doc about choosing backends.
Richard Jones <richard@users.sourceforge.net>
parents:
1168
diff
changeset
|
588 ae, filt = self.filteringSetup() |
|
af104fa52746
Added some words to the installation doc about choosing backends.
Richard Jones <richard@users.sourceforge.net>
parents:
1168
diff
changeset
|
589 ae(filt(None, {'status': '1'}, ('+','id'), (None,None)), ['2','3']) |
|
af104fa52746
Added some words to the installation doc about choosing backends.
Richard Jones <richard@users.sourceforge.net>
parents:
1168
diff
changeset
|
590 |
|
af104fa52746
Added some words to the installation doc about choosing backends.
Richard Jones <richard@users.sourceforge.net>
parents:
1168
diff
changeset
|
591 def testFilteringMultilink(self): |
|
af104fa52746
Added some words to the installation doc about choosing backends.
Richard Jones <richard@users.sourceforge.net>
parents:
1168
diff
changeset
|
592 ae, filt = self.filteringSetup() |
|
af104fa52746
Added some words to the installation doc about choosing backends.
Richard Jones <richard@users.sourceforge.net>
parents:
1168
diff
changeset
|
593 ae(filt(None, {'nosy': '2'}, ('+','id'), (None,None)), ['3']) |
|
af104fa52746
Added some words to the installation doc about choosing backends.
Richard Jones <richard@users.sourceforge.net>
parents:
1168
diff
changeset
|
594 |
|
af104fa52746
Added some words to the installation doc about choosing backends.
Richard Jones <richard@users.sourceforge.net>
parents:
1168
diff
changeset
|
595 def testFilteringMany(self): |
|
af104fa52746
Added some words to the installation doc about choosing backends.
Richard Jones <richard@users.sourceforge.net>
parents:
1168
diff
changeset
|
596 ae, filt = self.filteringSetup() |
|
af104fa52746
Added some words to the installation doc about choosing backends.
Richard Jones <richard@users.sourceforge.net>
parents:
1168
diff
changeset
|
597 ae(filt(None, {'nosy': '2', 'status': '1'}, ('+','id'), (None,None)), |
|
af104fa52746
Added some words to the installation doc about choosing backends.
Richard Jones <richard@users.sourceforge.net>
parents:
1168
diff
changeset
|
598 ['3']) |
|
af104fa52746
Added some words to the installation doc about choosing backends.
Richard Jones <richard@users.sourceforge.net>
parents:
1168
diff
changeset
|
599 |
|
1361
b94cc62090be
reminder comments for where we need new tests
Richard Jones <richard@users.sourceforge.net>
parents:
1333
diff
changeset
|
600 # TODO test auditors and reactors |
|
b94cc62090be
reminder comments for where we need new tests
Richard Jones <richard@users.sourceforge.net>
parents:
1333
diff
changeset
|
601 |
|
441
698534628072
Added transaction tests to test_db
Richard Jones <richard@users.sourceforge.net>
parents:
432
diff
changeset
|
602 class anydbmReadOnlyDBTestCase(MyTestCase): |
|
92
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
603 def setUp(self): |
|
158
86ebcf734a8e
Added more DB to test_db. Can skip tests where imports fail.
Richard Jones <richard@users.sourceforge.net>
parents:
127
diff
changeset
|
604 from roundup.backends import anydbm |
|
92
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
605 # remove previous test, ignore errors |
|
524
dce4c75bef5a
changed all config accesses...
Richard Jones <richard@users.sourceforge.net>
parents:
461
diff
changeset
|
606 if os.path.exists(config.DATABASE): |
|
dce4c75bef5a
changed all config accesses...
Richard Jones <richard@users.sourceforge.net>
parents:
461
diff
changeset
|
607 shutil.rmtree(config.DATABASE) |
|
dce4c75bef5a
changed all config accesses...
Richard Jones <richard@users.sourceforge.net>
parents:
461
diff
changeset
|
608 os.makedirs(config.DATABASE + '/files') |
|
1176
bd3b57859c37
On second thought, that last checkin was dumb.
Richard Jones <richard@users.sourceforge.net>
parents:
1174
diff
changeset
|
609 db = anydbm.Database(config, 'admin') |
|
858
2dd862af72ee
all storage-specific code (ie. backend) is now implemented by the backends
Richard Jones <richard@users.sourceforge.net>
parents:
854
diff
changeset
|
610 setupSchema(db, 1, anydbm) |
|
1333
80d27b7d6db5
implemented whole-database locking
Richard Jones <richard@users.sourceforge.net>
parents:
1305
diff
changeset
|
611 db.close() |
|
524
dce4c75bef5a
changed all config accesses...
Richard Jones <richard@users.sourceforge.net>
parents:
461
diff
changeset
|
612 self.db = anydbm.Database(config) |
|
858
2dd862af72ee
all storage-specific code (ie. backend) is now implemented by the backends
Richard Jones <richard@users.sourceforge.net>
parents:
854
diff
changeset
|
613 setupSchema(self.db, 0, anydbm) |
|
92
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
614 |
| 888 | 615 def testExceptions(self): |
|
92
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
616 # this tests the exceptions that should be raised |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
617 ar = self.assertRaises |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
618 |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
619 # this tests the exceptions that should be raised |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
620 ar(DatabaseError, self.db.status.create, name="foo") |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
621 ar(DatabaseError, self.db.status.set, '1', name="foo") |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
622 ar(DatabaseError, self.db.status.retire, '1') |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
623 |
|
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
624 |
|
441
698534628072
Added transaction tests to test_db
Richard Jones <richard@users.sourceforge.net>
parents:
432
diff
changeset
|
625 class bsddbDBTestCase(anydbmDBTestCase): |
|
158
86ebcf734a8e
Added more DB to test_db. Can skip tests where imports fail.
Richard Jones <richard@users.sourceforge.net>
parents:
127
diff
changeset
|
626 def setUp(self): |
|
86ebcf734a8e
Added more DB to test_db. Can skip tests where imports fail.
Richard Jones <richard@users.sourceforge.net>
parents:
127
diff
changeset
|
627 from roundup.backends import bsddb |
|
86ebcf734a8e
Added more DB to test_db. Can skip tests where imports fail.
Richard Jones <richard@users.sourceforge.net>
parents:
127
diff
changeset
|
628 # remove previous test, ignore errors |
|
524
dce4c75bef5a
changed all config accesses...
Richard Jones <richard@users.sourceforge.net>
parents:
461
diff
changeset
|
629 if os.path.exists(config.DATABASE): |
|
dce4c75bef5a
changed all config accesses...
Richard Jones <richard@users.sourceforge.net>
parents:
461
diff
changeset
|
630 shutil.rmtree(config.DATABASE) |
|
dce4c75bef5a
changed all config accesses...
Richard Jones <richard@users.sourceforge.net>
parents:
461
diff
changeset
|
631 os.makedirs(config.DATABASE + '/files') |
|
1176
bd3b57859c37
On second thought, that last checkin was dumb.
Richard Jones <richard@users.sourceforge.net>
parents:
1174
diff
changeset
|
632 self.db = bsddb.Database(config, 'admin') |
|
858
2dd862af72ee
all storage-specific code (ie. backend) is now implemented by the backends
Richard Jones <richard@users.sourceforge.net>
parents:
854
diff
changeset
|
633 setupSchema(self.db, 1, bsddb) |
|
158
86ebcf734a8e
Added more DB to test_db. Can skip tests where imports fail.
Richard Jones <richard@users.sourceforge.net>
parents:
127
diff
changeset
|
634 |
|
441
698534628072
Added transaction tests to test_db
Richard Jones <richard@users.sourceforge.net>
parents:
432
diff
changeset
|
635 class bsddbReadOnlyDBTestCase(anydbmReadOnlyDBTestCase): |
|
158
86ebcf734a8e
Added more DB to test_db. Can skip tests where imports fail.
Richard Jones <richard@users.sourceforge.net>
parents:
127
diff
changeset
|
636 def setUp(self): |
|
86ebcf734a8e
Added more DB to test_db. Can skip tests where imports fail.
Richard Jones <richard@users.sourceforge.net>
parents:
127
diff
changeset
|
637 from roundup.backends import bsddb |
|
86ebcf734a8e
Added more DB to test_db. Can skip tests where imports fail.
Richard Jones <richard@users.sourceforge.net>
parents:
127
diff
changeset
|
638 # remove previous test, ignore errors |
|
524
dce4c75bef5a
changed all config accesses...
Richard Jones <richard@users.sourceforge.net>
parents:
461
diff
changeset
|
639 if os.path.exists(config.DATABASE): |
|
dce4c75bef5a
changed all config accesses...
Richard Jones <richard@users.sourceforge.net>
parents:
461
diff
changeset
|
640 shutil.rmtree(config.DATABASE) |
|
dce4c75bef5a
changed all config accesses...
Richard Jones <richard@users.sourceforge.net>
parents:
461
diff
changeset
|
641 os.makedirs(config.DATABASE + '/files') |
|
1176
bd3b57859c37
On second thought, that last checkin was dumb.
Richard Jones <richard@users.sourceforge.net>
parents:
1174
diff
changeset
|
642 db = bsddb.Database(config, 'admin') |
|
858
2dd862af72ee
all storage-specific code (ie. backend) is now implemented by the backends
Richard Jones <richard@users.sourceforge.net>
parents:
854
diff
changeset
|
643 setupSchema(db, 1, bsddb) |
|
1333
80d27b7d6db5
implemented whole-database locking
Richard Jones <richard@users.sourceforge.net>
parents:
1305
diff
changeset
|
644 db.close() |
|
524
dce4c75bef5a
changed all config accesses...
Richard Jones <richard@users.sourceforge.net>
parents:
461
diff
changeset
|
645 self.db = bsddb.Database(config) |
|
858
2dd862af72ee
all storage-specific code (ie. backend) is now implemented by the backends
Richard Jones <richard@users.sourceforge.net>
parents:
854
diff
changeset
|
646 setupSchema(self.db, 0, bsddb) |
|
158
86ebcf734a8e
Added more DB to test_db. Can skip tests where imports fail.
Richard Jones <richard@users.sourceforge.net>
parents:
127
diff
changeset
|
647 |
|
86ebcf734a8e
Added more DB to test_db. Can skip tests where imports fail.
Richard Jones <richard@users.sourceforge.net>
parents:
127
diff
changeset
|
648 |
|
441
698534628072
Added transaction tests to test_db
Richard Jones <richard@users.sourceforge.net>
parents:
432
diff
changeset
|
649 class bsddb3DBTestCase(anydbmDBTestCase): |
|
158
86ebcf734a8e
Added more DB to test_db. Can skip tests where imports fail.
Richard Jones <richard@users.sourceforge.net>
parents:
127
diff
changeset
|
650 def setUp(self): |
|
86ebcf734a8e
Added more DB to test_db. Can skip tests where imports fail.
Richard Jones <richard@users.sourceforge.net>
parents:
127
diff
changeset
|
651 from roundup.backends import bsddb3 |
|
86ebcf734a8e
Added more DB to test_db. Can skip tests where imports fail.
Richard Jones <richard@users.sourceforge.net>
parents:
127
diff
changeset
|
652 # remove previous test, ignore errors |
|
524
dce4c75bef5a
changed all config accesses...
Richard Jones <richard@users.sourceforge.net>
parents:
461
diff
changeset
|
653 if os.path.exists(config.DATABASE): |
|
dce4c75bef5a
changed all config accesses...
Richard Jones <richard@users.sourceforge.net>
parents:
461
diff
changeset
|
654 shutil.rmtree(config.DATABASE) |
|
dce4c75bef5a
changed all config accesses...
Richard Jones <richard@users.sourceforge.net>
parents:
461
diff
changeset
|
655 os.makedirs(config.DATABASE + '/files') |
|
1176
bd3b57859c37
On second thought, that last checkin was dumb.
Richard Jones <richard@users.sourceforge.net>
parents:
1174
diff
changeset
|
656 self.db = bsddb3.Database(config, 'admin') |
|
858
2dd862af72ee
all storage-specific code (ie. backend) is now implemented by the backends
Richard Jones <richard@users.sourceforge.net>
parents:
854
diff
changeset
|
657 setupSchema(self.db, 1, bsddb3) |
|
158
86ebcf734a8e
Added more DB to test_db. Can skip tests where imports fail.
Richard Jones <richard@users.sourceforge.net>
parents:
127
diff
changeset
|
658 |
|
441
698534628072
Added transaction tests to test_db
Richard Jones <richard@users.sourceforge.net>
parents:
432
diff
changeset
|
659 class bsddb3ReadOnlyDBTestCase(anydbmReadOnlyDBTestCase): |
|
158
86ebcf734a8e
Added more DB to test_db. Can skip tests where imports fail.
Richard Jones <richard@users.sourceforge.net>
parents:
127
diff
changeset
|
660 def setUp(self): |
|
86ebcf734a8e
Added more DB to test_db. Can skip tests where imports fail.
Richard Jones <richard@users.sourceforge.net>
parents:
127
diff
changeset
|
661 from roundup.backends import bsddb3 |
|
86ebcf734a8e
Added more DB to test_db. Can skip tests where imports fail.
Richard Jones <richard@users.sourceforge.net>
parents:
127
diff
changeset
|
662 # remove previous test, ignore errors |
|
524
dce4c75bef5a
changed all config accesses...
Richard Jones <richard@users.sourceforge.net>
parents:
461
diff
changeset
|
663 if os.path.exists(config.DATABASE): |
|
dce4c75bef5a
changed all config accesses...
Richard Jones <richard@users.sourceforge.net>
parents:
461
diff
changeset
|
664 shutil.rmtree(config.DATABASE) |
|
dce4c75bef5a
changed all config accesses...
Richard Jones <richard@users.sourceforge.net>
parents:
461
diff
changeset
|
665 os.makedirs(config.DATABASE + '/files') |
|
1176
bd3b57859c37
On second thought, that last checkin was dumb.
Richard Jones <richard@users.sourceforge.net>
parents:
1174
diff
changeset
|
666 db = bsddb3.Database(config, 'admin') |
|
858
2dd862af72ee
all storage-specific code (ie. backend) is now implemented by the backends
Richard Jones <richard@users.sourceforge.net>
parents:
854
diff
changeset
|
667 setupSchema(db, 1, bsddb3) |
|
1333
80d27b7d6db5
implemented whole-database locking
Richard Jones <richard@users.sourceforge.net>
parents:
1305
diff
changeset
|
668 db.close() |
|
524
dce4c75bef5a
changed all config accesses...
Richard Jones <richard@users.sourceforge.net>
parents:
461
diff
changeset
|
669 self.db = bsddb3.Database(config) |
|
858
2dd862af72ee
all storage-specific code (ie. backend) is now implemented by the backends
Richard Jones <richard@users.sourceforge.net>
parents:
854
diff
changeset
|
670 setupSchema(self.db, 0, bsddb3) |
|
854
3cdfa5d86cec
Added metakit backend to the db tests...
Richard Jones <richard@users.sourceforge.net>
parents:
826
diff
changeset
|
671 |
|
3cdfa5d86cec
Added metakit backend to the db tests...
Richard Jones <richard@users.sourceforge.net>
parents:
826
diff
changeset
|
672 |
| 973 | 673 class gadflyDBTestCase(anydbmDBTestCase): |
| 674 ''' Gadfly doesn't support multiple connections to the one local | |
| 675 database | |
| 676 ''' | |
| 677 def setUp(self): | |
| 678 from roundup.backends import gadfly | |
| 679 # remove previous test, ignore errors | |
| 680 if os.path.exists(config.DATABASE): | |
| 681 shutil.rmtree(config.DATABASE) | |
| 682 config.GADFLY_DATABASE = ('test', config.DATABASE) | |
| 683 os.makedirs(config.DATABASE + '/files') | |
|
1176
bd3b57859c37
On second thought, that last checkin was dumb.
Richard Jones <richard@users.sourceforge.net>
parents:
1174
diff
changeset
|
684 self.db = gadfly.Database(config, 'admin') |
| 973 | 685 setupSchema(self.db, 1, gadfly) |
| 686 | |
|
1222
bc3bc3248dd1
added Class.find() unit test, fixed implementations
Richard Jones <richard@users.sourceforge.net>
parents:
1198
diff
changeset
|
687 def testFilteringString(self): |
|
bc3bc3248dd1
added Class.find() unit test, fixed implementations
Richard Jones <richard@users.sourceforge.net>
parents:
1198
diff
changeset
|
688 ae, filt = self.filteringSetup() |
|
bc3bc3248dd1
added Class.find() unit test, fixed implementations
Richard Jones <richard@users.sourceforge.net>
parents:
1198
diff
changeset
|
689 ae(filt(None, {'title': 'issue one'}, ('+','id'), (None,None)), ['1']) |
|
bc3bc3248dd1
added Class.find() unit test, fixed implementations
Richard Jones <richard@users.sourceforge.net>
parents:
1198
diff
changeset
|
690 # XXX gadfly can't do substring LIKE searches |
|
bc3bc3248dd1
added Class.find() unit test, fixed implementations
Richard Jones <richard@users.sourceforge.net>
parents:
1198
diff
changeset
|
691 #ae(filt(None, {'title': 'issue'}, ('+','id'), (None,None)), |
|
bc3bc3248dd1
added Class.find() unit test, fixed implementations
Richard Jones <richard@users.sourceforge.net>
parents:
1198
diff
changeset
|
692 # ['1','2','3']) |
|
bc3bc3248dd1
added Class.find() unit test, fixed implementations
Richard Jones <richard@users.sourceforge.net>
parents:
1198
diff
changeset
|
693 |
| 973 | 694 class gadflyReadOnlyDBTestCase(anydbmReadOnlyDBTestCase): |
| 695 def setUp(self): | |
| 696 from roundup.backends import gadfly | |
| 697 # remove previous test, ignore errors | |
| 698 if os.path.exists(config.DATABASE): | |
| 699 shutil.rmtree(config.DATABASE) | |
| 700 config.GADFLY_DATABASE = ('test', config.DATABASE) | |
| 701 os.makedirs(config.DATABASE + '/files') | |
|
1176
bd3b57859c37
On second thought, that last checkin was dumb.
Richard Jones <richard@users.sourceforge.net>
parents:
1174
diff
changeset
|
702 db = gadfly.Database(config, 'admin') |
| 973 | 703 setupSchema(db, 1, gadfly) |
|
1333
80d27b7d6db5
implemented whole-database locking
Richard Jones <richard@users.sourceforge.net>
parents:
1305
diff
changeset
|
704 db.close() |
| 973 | 705 self.db = gadfly.Database(config) |
| 706 setupSchema(self.db, 0, gadfly) | |
| 707 | |
| 708 | |
|
1378
5d1fe5d51c12
note on how to fix mysql tests - also indicate which tests are being run
Richard Jones <richard@users.sourceforge.net>
parents:
1375
diff
changeset
|
709 # XXX to fix the mysql tests... |
|
5d1fe5d51c12
note on how to fix mysql tests - also indicate which tests are being run
Richard Jones <richard@users.sourceforge.net>
parents:
1375
diff
changeset
|
710 # From: Andrey Lebedev <andrey@micro.lt> |
|
5d1fe5d51c12
note on how to fix mysql tests - also indicate which tests are being run
Richard Jones <richard@users.sourceforge.net>
parents:
1375
diff
changeset
|
711 # I believe we can DROP DATABASE <dbname> and then CREATE DATABASE |
|
5d1fe5d51c12
note on how to fix mysql tests - also indicate which tests are being run
Richard Jones <richard@users.sourceforge.net>
parents:
1375
diff
changeset
|
712 # <dbname>.. it's an easiest way. This will work if db user has all |
|
5d1fe5d51c12
note on how to fix mysql tests - also indicate which tests are being run
Richard Jones <richard@users.sourceforge.net>
parents:
1375
diff
changeset
|
713 # privileges on database. |
|
5d1fe5d51c12
note on how to fix mysql tests - also indicate which tests are being run
Richard Jones <richard@users.sourceforge.net>
parents:
1375
diff
changeset
|
714 # Another way - to perform "SHOW TABLES" SQL and then perform DROP TABLE |
|
5d1fe5d51c12
note on how to fix mysql tests - also indicate which tests are being run
Richard Jones <richard@users.sourceforge.net>
parents:
1375
diff
changeset
|
715 # <tblname> on each table... |
|
1365
4884fb0860f9
fixed rdbms searching by ID [SF#666615]
Richard Jones <richard@users.sourceforge.net>
parents:
1361
diff
changeset
|
716 class mysqlDBTestCase(anydbmDBTestCase): |
|
4884fb0860f9
fixed rdbms searching by ID [SF#666615]
Richard Jones <richard@users.sourceforge.net>
parents:
1361
diff
changeset
|
717 def setUp(self): |
|
4884fb0860f9
fixed rdbms searching by ID [SF#666615]
Richard Jones <richard@users.sourceforge.net>
parents:
1361
diff
changeset
|
718 from roundup.backends import mysql |
|
4884fb0860f9
fixed rdbms searching by ID [SF#666615]
Richard Jones <richard@users.sourceforge.net>
parents:
1361
diff
changeset
|
719 # remove previous test, ignore errors |
|
4884fb0860f9
fixed rdbms searching by ID [SF#666615]
Richard Jones <richard@users.sourceforge.net>
parents:
1361
diff
changeset
|
720 if os.path.exists(config.DATABASE): |
|
4884fb0860f9
fixed rdbms searching by ID [SF#666615]
Richard Jones <richard@users.sourceforge.net>
parents:
1361
diff
changeset
|
721 shutil.rmtree(config.DATABASE) |
|
1375
faf93d3fbf2f
added mysql backend
Richard Jones <richard@users.sourceforge.net>
parents:
1365
diff
changeset
|
722 config.MYSQL_DATABASE = ('localhost', 'rounduptest', 'rounduptest', |
|
faf93d3fbf2f
added mysql backend
Richard Jones <richard@users.sourceforge.net>
parents:
1365
diff
changeset
|
723 'rounduptest') |
|
1365
4884fb0860f9
fixed rdbms searching by ID [SF#666615]
Richard Jones <richard@users.sourceforge.net>
parents:
1361
diff
changeset
|
724 os.makedirs(config.DATABASE + '/files') |
|
4884fb0860f9
fixed rdbms searching by ID [SF#666615]
Richard Jones <richard@users.sourceforge.net>
parents:
1361
diff
changeset
|
725 self.db = mysql.Database(config, 'admin') |
|
4884fb0860f9
fixed rdbms searching by ID [SF#666615]
Richard Jones <richard@users.sourceforge.net>
parents:
1361
diff
changeset
|
726 setupSchema(self.db, 1, mysql) |
|
4884fb0860f9
fixed rdbms searching by ID [SF#666615]
Richard Jones <richard@users.sourceforge.net>
parents:
1361
diff
changeset
|
727 |
|
4884fb0860f9
fixed rdbms searching by ID [SF#666615]
Richard Jones <richard@users.sourceforge.net>
parents:
1361
diff
changeset
|
728 class mysqlReadOnlyDBTestCase(anydbmReadOnlyDBTestCase): |
|
4884fb0860f9
fixed rdbms searching by ID [SF#666615]
Richard Jones <richard@users.sourceforge.net>
parents:
1361
diff
changeset
|
729 def setUp(self): |
|
4884fb0860f9
fixed rdbms searching by ID [SF#666615]
Richard Jones <richard@users.sourceforge.net>
parents:
1361
diff
changeset
|
730 from roundup.backends import mysql |
|
4884fb0860f9
fixed rdbms searching by ID [SF#666615]
Richard Jones <richard@users.sourceforge.net>
parents:
1361
diff
changeset
|
731 # remove previous test, ignore errors |
|
4884fb0860f9
fixed rdbms searching by ID [SF#666615]
Richard Jones <richard@users.sourceforge.net>
parents:
1361
diff
changeset
|
732 if os.path.exists(config.DATABASE): |
|
4884fb0860f9
fixed rdbms searching by ID [SF#666615]
Richard Jones <richard@users.sourceforge.net>
parents:
1361
diff
changeset
|
733 shutil.rmtree(config.DATABASE) |
|
1375
faf93d3fbf2f
added mysql backend
Richard Jones <richard@users.sourceforge.net>
parents:
1365
diff
changeset
|
734 config.MYSQL_DATABASE = ('localhost', 'rounduptest', 'rounduptest', |
|
faf93d3fbf2f
added mysql backend
Richard Jones <richard@users.sourceforge.net>
parents:
1365
diff
changeset
|
735 'rounduptest') |
|
1365
4884fb0860f9
fixed rdbms searching by ID [SF#666615]
Richard Jones <richard@users.sourceforge.net>
parents:
1361
diff
changeset
|
736 os.makedirs(config.DATABASE + '/files') |
|
4884fb0860f9
fixed rdbms searching by ID [SF#666615]
Richard Jones <richard@users.sourceforge.net>
parents:
1361
diff
changeset
|
737 db = mysql.Database(config, 'admin') |
|
4884fb0860f9
fixed rdbms searching by ID [SF#666615]
Richard Jones <richard@users.sourceforge.net>
parents:
1361
diff
changeset
|
738 setupSchema(db, 1, mysql) |
|
4884fb0860f9
fixed rdbms searching by ID [SF#666615]
Richard Jones <richard@users.sourceforge.net>
parents:
1361
diff
changeset
|
739 db.close() |
|
4884fb0860f9
fixed rdbms searching by ID [SF#666615]
Richard Jones <richard@users.sourceforge.net>
parents:
1361
diff
changeset
|
740 self.db = sqlite.Database(config) |
|
4884fb0860f9
fixed rdbms searching by ID [SF#666615]
Richard Jones <richard@users.sourceforge.net>
parents:
1361
diff
changeset
|
741 setupSchema(self.db, 0, mysql) |
|
4884fb0860f9
fixed rdbms searching by ID [SF#666615]
Richard Jones <richard@users.sourceforge.net>
parents:
1361
diff
changeset
|
742 |
|
4884fb0860f9
fixed rdbms searching by ID [SF#666615]
Richard Jones <richard@users.sourceforge.net>
parents:
1361
diff
changeset
|
743 |
|
1165
14467c765167
sqlite backend!
Richard Jones <richard@users.sourceforge.net>
parents:
1156
diff
changeset
|
744 class sqliteDBTestCase(anydbmDBTestCase): |
|
14467c765167
sqlite backend!
Richard Jones <richard@users.sourceforge.net>
parents:
1156
diff
changeset
|
745 def setUp(self): |
|
14467c765167
sqlite backend!
Richard Jones <richard@users.sourceforge.net>
parents:
1156
diff
changeset
|
746 from roundup.backends import sqlite |
|
14467c765167
sqlite backend!
Richard Jones <richard@users.sourceforge.net>
parents:
1156
diff
changeset
|
747 # remove previous test, ignore errors |
|
14467c765167
sqlite backend!
Richard Jones <richard@users.sourceforge.net>
parents:
1156
diff
changeset
|
748 if os.path.exists(config.DATABASE): |
|
14467c765167
sqlite backend!
Richard Jones <richard@users.sourceforge.net>
parents:
1156
diff
changeset
|
749 shutil.rmtree(config.DATABASE) |
|
14467c765167
sqlite backend!
Richard Jones <richard@users.sourceforge.net>
parents:
1156
diff
changeset
|
750 os.makedirs(config.DATABASE + '/files') |
|
1176
bd3b57859c37
On second thought, that last checkin was dumb.
Richard Jones <richard@users.sourceforge.net>
parents:
1174
diff
changeset
|
751 self.db = sqlite.Database(config, 'admin') |
|
1165
14467c765167
sqlite backend!
Richard Jones <richard@users.sourceforge.net>
parents:
1156
diff
changeset
|
752 setupSchema(self.db, 1, sqlite) |
|
14467c765167
sqlite backend!
Richard Jones <richard@users.sourceforge.net>
parents:
1156
diff
changeset
|
753 |
|
14467c765167
sqlite backend!
Richard Jones <richard@users.sourceforge.net>
parents:
1156
diff
changeset
|
754 class sqliteReadOnlyDBTestCase(anydbmReadOnlyDBTestCase): |
|
14467c765167
sqlite backend!
Richard Jones <richard@users.sourceforge.net>
parents:
1156
diff
changeset
|
755 def setUp(self): |
|
14467c765167
sqlite backend!
Richard Jones <richard@users.sourceforge.net>
parents:
1156
diff
changeset
|
756 from roundup.backends import sqlite |
|
14467c765167
sqlite backend!
Richard Jones <richard@users.sourceforge.net>
parents:
1156
diff
changeset
|
757 # remove previous test, ignore errors |
|
14467c765167
sqlite backend!
Richard Jones <richard@users.sourceforge.net>
parents:
1156
diff
changeset
|
758 if os.path.exists(config.DATABASE): |
|
14467c765167
sqlite backend!
Richard Jones <richard@users.sourceforge.net>
parents:
1156
diff
changeset
|
759 shutil.rmtree(config.DATABASE) |
|
14467c765167
sqlite backend!
Richard Jones <richard@users.sourceforge.net>
parents:
1156
diff
changeset
|
760 os.makedirs(config.DATABASE + '/files') |
|
1176
bd3b57859c37
On second thought, that last checkin was dumb.
Richard Jones <richard@users.sourceforge.net>
parents:
1174
diff
changeset
|
761 db = sqlite.Database(config, 'admin') |
|
1165
14467c765167
sqlite backend!
Richard Jones <richard@users.sourceforge.net>
parents:
1156
diff
changeset
|
762 setupSchema(db, 1, sqlite) |
|
1333
80d27b7d6db5
implemented whole-database locking
Richard Jones <richard@users.sourceforge.net>
parents:
1305
diff
changeset
|
763 db.close() |
|
1165
14467c765167
sqlite backend!
Richard Jones <richard@users.sourceforge.net>
parents:
1156
diff
changeset
|
764 self.db = sqlite.Database(config) |
|
14467c765167
sqlite backend!
Richard Jones <richard@users.sourceforge.net>
parents:
1156
diff
changeset
|
765 setupSchema(self.db, 0, sqlite) |
|
14467c765167
sqlite backend!
Richard Jones <richard@users.sourceforge.net>
parents:
1156
diff
changeset
|
766 |
|
14467c765167
sqlite backend!
Richard Jones <richard@users.sourceforge.net>
parents:
1156
diff
changeset
|
767 |
|
854
3cdfa5d86cec
Added metakit backend to the db tests...
Richard Jones <richard@users.sourceforge.net>
parents:
826
diff
changeset
|
768 class metakitDBTestCase(anydbmDBTestCase): |
|
3cdfa5d86cec
Added metakit backend to the db tests...
Richard Jones <richard@users.sourceforge.net>
parents:
826
diff
changeset
|
769 def setUp(self): |
|
3cdfa5d86cec
Added metakit backend to the db tests...
Richard Jones <richard@users.sourceforge.net>
parents:
826
diff
changeset
|
770 from roundup.backends import metakit |
|
3cdfa5d86cec
Added metakit backend to the db tests...
Richard Jones <richard@users.sourceforge.net>
parents:
826
diff
changeset
|
771 import weakref |
|
3cdfa5d86cec
Added metakit backend to the db tests...
Richard Jones <richard@users.sourceforge.net>
parents:
826
diff
changeset
|
772 metakit._instances = weakref.WeakValueDictionary() |
|
3cdfa5d86cec
Added metakit backend to the db tests...
Richard Jones <richard@users.sourceforge.net>
parents:
826
diff
changeset
|
773 # remove previous test, ignore errors |
|
3cdfa5d86cec
Added metakit backend to the db tests...
Richard Jones <richard@users.sourceforge.net>
parents:
826
diff
changeset
|
774 if os.path.exists(config.DATABASE): |
|
3cdfa5d86cec
Added metakit backend to the db tests...
Richard Jones <richard@users.sourceforge.net>
parents:
826
diff
changeset
|
775 shutil.rmtree(config.DATABASE) |
|
3cdfa5d86cec
Added metakit backend to the db tests...
Richard Jones <richard@users.sourceforge.net>
parents:
826
diff
changeset
|
776 os.makedirs(config.DATABASE + '/files') |
|
1176
bd3b57859c37
On second thought, that last checkin was dumb.
Richard Jones <richard@users.sourceforge.net>
parents:
1174
diff
changeset
|
777 self.db = metakit.Database(config, 'admin') |
|
858
2dd862af72ee
all storage-specific code (ie. backend) is now implemented by the backends
Richard Jones <richard@users.sourceforge.net>
parents:
854
diff
changeset
|
778 setupSchema(self.db, 1, metakit) |
| 1143 | 779 |
| 888 | 780 def testTransactions(self): |
|
854
3cdfa5d86cec
Added metakit backend to the db tests...
Richard Jones <richard@users.sourceforge.net>
parents:
826
diff
changeset
|
781 # remember the number of items we started |
|
3cdfa5d86cec
Added metakit backend to the db tests...
Richard Jones <richard@users.sourceforge.net>
parents:
826
diff
changeset
|
782 num_issues = len(self.db.issue.list()) |
|
3cdfa5d86cec
Added metakit backend to the db tests...
Richard Jones <richard@users.sourceforge.net>
parents:
826
diff
changeset
|
783 self.db.issue.create(title="don't commit me!", status='1') |
|
3cdfa5d86cec
Added metakit backend to the db tests...
Richard Jones <richard@users.sourceforge.net>
parents:
826
diff
changeset
|
784 self.assertNotEqual(num_issues, len(self.db.issue.list())) |
|
3cdfa5d86cec
Added metakit backend to the db tests...
Richard Jones <richard@users.sourceforge.net>
parents:
826
diff
changeset
|
785 self.db.rollback() |
|
3cdfa5d86cec
Added metakit backend to the db tests...
Richard Jones <richard@users.sourceforge.net>
parents:
826
diff
changeset
|
786 self.assertEqual(num_issues, len(self.db.issue.list())) |
|
3cdfa5d86cec
Added metakit backend to the db tests...
Richard Jones <richard@users.sourceforge.net>
parents:
826
diff
changeset
|
787 self.db.issue.create(title="please commit me!", status='1') |
|
3cdfa5d86cec
Added metakit backend to the db tests...
Richard Jones <richard@users.sourceforge.net>
parents:
826
diff
changeset
|
788 self.assertNotEqual(num_issues, len(self.db.issue.list())) |
|
3cdfa5d86cec
Added metakit backend to the db tests...
Richard Jones <richard@users.sourceforge.net>
parents:
826
diff
changeset
|
789 self.db.commit() |
|
3cdfa5d86cec
Added metakit backend to the db tests...
Richard Jones <richard@users.sourceforge.net>
parents:
826
diff
changeset
|
790 self.assertNotEqual(num_issues, len(self.db.issue.list())) |
|
3cdfa5d86cec
Added metakit backend to the db tests...
Richard Jones <richard@users.sourceforge.net>
parents:
826
diff
changeset
|
791 self.db.rollback() |
|
3cdfa5d86cec
Added metakit backend to the db tests...
Richard Jones <richard@users.sourceforge.net>
parents:
826
diff
changeset
|
792 self.assertNotEqual(num_issues, len(self.db.issue.list())) |
|
3cdfa5d86cec
Added metakit backend to the db tests...
Richard Jones <richard@users.sourceforge.net>
parents:
826
diff
changeset
|
793 self.db.file.create(name="test", type="text/plain", content="hi") |
|
3cdfa5d86cec
Added metakit backend to the db tests...
Richard Jones <richard@users.sourceforge.net>
parents:
826
diff
changeset
|
794 self.db.rollback() |
|
1243
3a028d2f7830
Fix (re)indexing & find in back_metakit.
Gordon B. McMillan <gmcm@users.sourceforge.net>
parents:
1222
diff
changeset
|
795 num_files = len(self.db.file.list()) |
|
854
3cdfa5d86cec
Added metakit backend to the db tests...
Richard Jones <richard@users.sourceforge.net>
parents:
826
diff
changeset
|
796 for i in range(10): |
|
3cdfa5d86cec
Added metakit backend to the db tests...
Richard Jones <richard@users.sourceforge.net>
parents:
826
diff
changeset
|
797 self.db.file.create(name="test", type="text/plain", |
|
3cdfa5d86cec
Added metakit backend to the db tests...
Richard Jones <richard@users.sourceforge.net>
parents:
826
diff
changeset
|
798 content="hi %d"%(i)) |
|
3cdfa5d86cec
Added metakit backend to the db tests...
Richard Jones <richard@users.sourceforge.net>
parents:
826
diff
changeset
|
799 self.db.commit() |
|
3cdfa5d86cec
Added metakit backend to the db tests...
Richard Jones <richard@users.sourceforge.net>
parents:
826
diff
changeset
|
800 # TODO: would be good to be able to ensure the file is not on disk after |
|
3cdfa5d86cec
Added metakit backend to the db tests...
Richard Jones <richard@users.sourceforge.net>
parents:
826
diff
changeset
|
801 # a rollback... |
|
1243
3a028d2f7830
Fix (re)indexing & find in back_metakit.
Gordon B. McMillan <gmcm@users.sourceforge.net>
parents:
1222
diff
changeset
|
802 num_files2 = len(self.db.file.list()) |
|
854
3cdfa5d86cec
Added metakit backend to the db tests...
Richard Jones <richard@users.sourceforge.net>
parents:
826
diff
changeset
|
803 self.assertNotEqual(num_files, num_files2) |
|
3cdfa5d86cec
Added metakit backend to the db tests...
Richard Jones <richard@users.sourceforge.net>
parents:
826
diff
changeset
|
804 self.db.file.create(name="test", type="text/plain", content="hi") |
|
1243
3a028d2f7830
Fix (re)indexing & find in back_metakit.
Gordon B. McMillan <gmcm@users.sourceforge.net>
parents:
1222
diff
changeset
|
805 num_rfiles = len(os.listdir(self.db.config.DATABASE + '/files/file/0')) |
|
854
3cdfa5d86cec
Added metakit backend to the db tests...
Richard Jones <richard@users.sourceforge.net>
parents:
826
diff
changeset
|
806 self.db.rollback() |
|
1243
3a028d2f7830
Fix (re)indexing & find in back_metakit.
Gordon B. McMillan <gmcm@users.sourceforge.net>
parents:
1222
diff
changeset
|
807 num_rfiles2 = len(os.listdir(self.db.config.DATABASE + '/files/file/0')) |
|
3a028d2f7830
Fix (re)indexing & find in back_metakit.
Gordon B. McMillan <gmcm@users.sourceforge.net>
parents:
1222
diff
changeset
|
808 self.assertEqual(num_files2, len(self.db.file.list())) |
|
3a028d2f7830
Fix (re)indexing & find in back_metakit.
Gordon B. McMillan <gmcm@users.sourceforge.net>
parents:
1222
diff
changeset
|
809 self.assertEqual(num_rfiles2, num_rfiles-1) |
|
854
3cdfa5d86cec
Added metakit backend to the db tests...
Richard Jones <richard@users.sourceforge.net>
parents:
826
diff
changeset
|
810 |
|
3cdfa5d86cec
Added metakit backend to the db tests...
Richard Jones <richard@users.sourceforge.net>
parents:
826
diff
changeset
|
811 class metakitReadOnlyDBTestCase(anydbmReadOnlyDBTestCase): |
|
3cdfa5d86cec
Added metakit backend to the db tests...
Richard Jones <richard@users.sourceforge.net>
parents:
826
diff
changeset
|
812 def setUp(self): |
|
3cdfa5d86cec
Added metakit backend to the db tests...
Richard Jones <richard@users.sourceforge.net>
parents:
826
diff
changeset
|
813 from roundup.backends import metakit |
|
3cdfa5d86cec
Added metakit backend to the db tests...
Richard Jones <richard@users.sourceforge.net>
parents:
826
diff
changeset
|
814 import weakref |
|
3cdfa5d86cec
Added metakit backend to the db tests...
Richard Jones <richard@users.sourceforge.net>
parents:
826
diff
changeset
|
815 metakit._instances = weakref.WeakValueDictionary() |
|
3cdfa5d86cec
Added metakit backend to the db tests...
Richard Jones <richard@users.sourceforge.net>
parents:
826
diff
changeset
|
816 # remove previous test, ignore errors |
|
3cdfa5d86cec
Added metakit backend to the db tests...
Richard Jones <richard@users.sourceforge.net>
parents:
826
diff
changeset
|
817 if os.path.exists(config.DATABASE): |
|
3cdfa5d86cec
Added metakit backend to the db tests...
Richard Jones <richard@users.sourceforge.net>
parents:
826
diff
changeset
|
818 shutil.rmtree(config.DATABASE) |
|
3cdfa5d86cec
Added metakit backend to the db tests...
Richard Jones <richard@users.sourceforge.net>
parents:
826
diff
changeset
|
819 os.makedirs(config.DATABASE + '/files') |
|
1176
bd3b57859c37
On second thought, that last checkin was dumb.
Richard Jones <richard@users.sourceforge.net>
parents:
1174
diff
changeset
|
820 db = metakit.Database(config, 'admin') |
|
858
2dd862af72ee
all storage-specific code (ie. backend) is now implemented by the backends
Richard Jones <richard@users.sourceforge.net>
parents:
854
diff
changeset
|
821 setupSchema(db, 1, metakit) |
|
1333
80d27b7d6db5
implemented whole-database locking
Richard Jones <richard@users.sourceforge.net>
parents:
1305
diff
changeset
|
822 db.close() |
|
854
3cdfa5d86cec
Added metakit backend to the db tests...
Richard Jones <richard@users.sourceforge.net>
parents:
826
diff
changeset
|
823 self.db = metakit.Database(config) |
|
858
2dd862af72ee
all storage-specific code (ie. backend) is now implemented by the backends
Richard Jones <richard@users.sourceforge.net>
parents:
854
diff
changeset
|
824 setupSchema(self.db, 0, metakit) |
|
158
86ebcf734a8e
Added more DB to test_db. Can skip tests where imports fail.
Richard Jones <richard@users.sourceforge.net>
parents:
127
diff
changeset
|
825 |
|
92
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
826 def suite(): |
|
676
bc46480e2a2b
Fixed serialisation problem...
Richard Jones <richard@users.sourceforge.net>
parents:
646
diff
changeset
|
827 l = [ |
|
bc46480e2a2b
Fixed serialisation problem...
Richard Jones <richard@users.sourceforge.net>
parents:
646
diff
changeset
|
828 unittest.makeSuite(anydbmDBTestCase, 'test'), |
|
441
698534628072
Added transaction tests to test_db
Richard Jones <richard@users.sourceforge.net>
parents:
432
diff
changeset
|
829 unittest.makeSuite(anydbmReadOnlyDBTestCase, 'test') |
|
698534628072
Added transaction tests to test_db
Richard Jones <richard@users.sourceforge.net>
parents:
432
diff
changeset
|
830 ] |
|
1198
1c5bc0e2ed7d
*** empty log message ***
Richard Jones <richard@users.sourceforge.net>
parents:
1183
diff
changeset
|
831 # return unittest.TestSuite(l) |
|
1170
af104fa52746
Added some words to the installation doc about choosing backends.
Richard Jones <richard@users.sourceforge.net>
parents:
1168
diff
changeset
|
832 |
|
1198
1c5bc0e2ed7d
*** empty log message ***
Richard Jones <richard@users.sourceforge.net>
parents:
1183
diff
changeset
|
833 from roundup import backends |
|
1378
5d1fe5d51c12
note on how to fix mysql tests - also indicate which tests are being run
Richard Jones <richard@users.sourceforge.net>
parents:
1375
diff
changeset
|
834 p = [] |
|
5d1fe5d51c12
note on how to fix mysql tests - also indicate which tests are being run
Richard Jones <richard@users.sourceforge.net>
parents:
1375
diff
changeset
|
835 # if hasattr(backends, 'mysql'): |
|
5d1fe5d51c12
note on how to fix mysql tests - also indicate which tests are being run
Richard Jones <richard@users.sourceforge.net>
parents:
1375
diff
changeset
|
836 # p.append('mysql') |
|
5d1fe5d51c12
note on how to fix mysql tests - also indicate which tests are being run
Richard Jones <richard@users.sourceforge.net>
parents:
1375
diff
changeset
|
837 # l.append(unittest.makeSuite(mysqlDBTestCase, 'test')) |
|
5d1fe5d51c12
note on how to fix mysql tests - also indicate which tests are being run
Richard Jones <richard@users.sourceforge.net>
parents:
1375
diff
changeset
|
838 # l.append(unittest.makeSuite(mysqlReadOnlyDBTestCase, 'test')) |
|
1365
4884fb0860f9
fixed rdbms searching by ID [SF#666615]
Richard Jones <richard@users.sourceforge.net>
parents:
1361
diff
changeset
|
839 # return unittest.TestSuite(l) |
|
4884fb0860f9
fixed rdbms searching by ID [SF#666615]
Richard Jones <richard@users.sourceforge.net>
parents:
1361
diff
changeset
|
840 |
|
1198
1c5bc0e2ed7d
*** empty log message ***
Richard Jones <richard@users.sourceforge.net>
parents:
1183
diff
changeset
|
841 if hasattr(backends, 'gadfly'): |
|
1378
5d1fe5d51c12
note on how to fix mysql tests - also indicate which tests are being run
Richard Jones <richard@users.sourceforge.net>
parents:
1375
diff
changeset
|
842 p.append('gadfly') |
|
1176
bd3b57859c37
On second thought, that last checkin was dumb.
Richard Jones <richard@users.sourceforge.net>
parents:
1174
diff
changeset
|
843 l.append(unittest.makeSuite(gadflyDBTestCase, 'test')) |
|
bd3b57859c37
On second thought, that last checkin was dumb.
Richard Jones <richard@users.sourceforge.net>
parents:
1174
diff
changeset
|
844 l.append(unittest.makeSuite(gadflyReadOnlyDBTestCase, 'test')) |
|
bd3b57859c37
On second thought, that last checkin was dumb.
Richard Jones <richard@users.sourceforge.net>
parents:
1174
diff
changeset
|
845 |
|
1198
1c5bc0e2ed7d
*** empty log message ***
Richard Jones <richard@users.sourceforge.net>
parents:
1183
diff
changeset
|
846 if hasattr(backends, 'sqlite'): |
|
1378
5d1fe5d51c12
note on how to fix mysql tests - also indicate which tests are being run
Richard Jones <richard@users.sourceforge.net>
parents:
1375
diff
changeset
|
847 p.append('sqlite') |
|
1170
af104fa52746
Added some words to the installation doc about choosing backends.
Richard Jones <richard@users.sourceforge.net>
parents:
1168
diff
changeset
|
848 l.append(unittest.makeSuite(sqliteDBTestCase, 'test')) |
|
af104fa52746
Added some words to the installation doc about choosing backends.
Richard Jones <richard@users.sourceforge.net>
parents:
1168
diff
changeset
|
849 l.append(unittest.makeSuite(sqliteReadOnlyDBTestCase, 'test')) |
|
92
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
850 |
|
1198
1c5bc0e2ed7d
*** empty log message ***
Richard Jones <richard@users.sourceforge.net>
parents:
1183
diff
changeset
|
851 if hasattr(backends, 'bsddb'): |
|
1378
5d1fe5d51c12
note on how to fix mysql tests - also indicate which tests are being run
Richard Jones <richard@users.sourceforge.net>
parents:
1375
diff
changeset
|
852 p.append('bsddb') |
|
158
86ebcf734a8e
Added more DB to test_db. Can skip tests where imports fail.
Richard Jones <richard@users.sourceforge.net>
parents:
127
diff
changeset
|
853 l.append(unittest.makeSuite(bsddbDBTestCase, 'test')) |
|
86ebcf734a8e
Added more DB to test_db. Can skip tests where imports fail.
Richard Jones <richard@users.sourceforge.net>
parents:
127
diff
changeset
|
854 l.append(unittest.makeSuite(bsddbReadOnlyDBTestCase, 'test')) |
|
86ebcf734a8e
Added more DB to test_db. Can skip tests where imports fail.
Richard Jones <richard@users.sourceforge.net>
parents:
127
diff
changeset
|
855 |
|
1198
1c5bc0e2ed7d
*** empty log message ***
Richard Jones <richard@users.sourceforge.net>
parents:
1183
diff
changeset
|
856 if hasattr(backends, 'bsddb3'): |
|
1378
5d1fe5d51c12
note on how to fix mysql tests - also indicate which tests are being run
Richard Jones <richard@users.sourceforge.net>
parents:
1375
diff
changeset
|
857 p.append('bsddb3') |
|
726
e3d742c75ac3
Well whadya know, bsddb3 works again.
Richard Jones <richard@users.sourceforge.net>
parents:
690
diff
changeset
|
858 l.append(unittest.makeSuite(bsddb3DBTestCase, 'test')) |
|
e3d742c75ac3
Well whadya know, bsddb3 works again.
Richard Jones <richard@users.sourceforge.net>
parents:
690
diff
changeset
|
859 l.append(unittest.makeSuite(bsddb3ReadOnlyDBTestCase, 'test')) |
|
158
86ebcf734a8e
Added more DB to test_db. Can skip tests where imports fail.
Richard Jones <richard@users.sourceforge.net>
parents:
127
diff
changeset
|
860 |
|
1198
1c5bc0e2ed7d
*** empty log message ***
Richard Jones <richard@users.sourceforge.net>
parents:
1183
diff
changeset
|
861 if hasattr(backends, 'metakit'): |
|
1378
5d1fe5d51c12
note on how to fix mysql tests - also indicate which tests are being run
Richard Jones <richard@users.sourceforge.net>
parents:
1375
diff
changeset
|
862 p.append('metakit') |
|
854
3cdfa5d86cec
Added metakit backend to the db tests...
Richard Jones <richard@users.sourceforge.net>
parents:
826
diff
changeset
|
863 l.append(unittest.makeSuite(metakitDBTestCase, 'test')) |
|
3cdfa5d86cec
Added metakit backend to the db tests...
Richard Jones <richard@users.sourceforge.net>
parents:
826
diff
changeset
|
864 l.append(unittest.makeSuite(metakitReadOnlyDBTestCase, 'test')) |
|
3cdfa5d86cec
Added metakit backend to the db tests...
Richard Jones <richard@users.sourceforge.net>
parents:
826
diff
changeset
|
865 |
|
1378
5d1fe5d51c12
note on how to fix mysql tests - also indicate which tests are being run
Richard Jones <richard@users.sourceforge.net>
parents:
1375
diff
changeset
|
866 print 'running %s backend tests'%(', '.join(p)) |
|
158
86ebcf734a8e
Added more DB to test_db. Can skip tests where imports fail.
Richard Jones <richard@users.sourceforge.net>
parents:
127
diff
changeset
|
867 return unittest.TestSuite(l) |
|
92
fa44da8d9df2
moving tests -> test
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
868 |
|
127
0791d13baea7
Added vim command to all source so that we don't get no steenkin' tabs :)
Richard Jones <richard@users.sourceforge.net>
parents:
121
diff
changeset
|
869 # vim: set filetype=python ts=4 sw=4 et si |
