annotate test/test_actions.py @ 2485:6e8ecdb19e6a maint-0.7

fix anydbm so search for None Link value works... ...also tweak query edit so its a little more useful
author Richard Jones <richard@users.sourceforge.net>
date Mon, 21 Jun 2004 05:42:45 +0000
parents a15f91a10e45
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
2482
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
1 from __future__ import nested_scopes
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
2
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
3 import unittest
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
4 from cgi import FieldStorage, MiniFieldStorage
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
5
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
6 from roundup import hyperdb
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
7 from roundup.date import Date, Interval
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
8 from roundup.cgi.actions import *
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
9 from roundup.cgi.exceptions import Redirect, Unauthorised, SeriousError
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
10
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
11 class MockNull:
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
12 def __init__(self, **kwargs):
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
13 for key, value in kwargs.items():
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
14 self.__dict__[key] = value
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
15
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
16 def __call__(self, *args, **kwargs): return MockNull()
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
17 def __getattr__(self, name):
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
18 # This allows assignments which assume all intermediate steps are Null
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
19 # objects if they don't exist yet.
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
20 #
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
21 # For example (with just 'client' defined):
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
22 #
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
23 # client.db.config.TRACKER_WEB = 'BASE/'
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
24 self.__dict__[name] = MockNull()
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
25 return getattr(self, name)
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
26
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
27 def __getitem__(self, key): return self
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
28 def __nonzero__(self): return 0
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
29 def __str__(self): return ''
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
30 def __repr__(self): return '<MockNull 0x%x>'%id(self)
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
31
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
32 def true(*args, **kwargs):
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
33 return 1
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
34
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
35 class ActionTestCase(unittest.TestCase):
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
36 def setUp(self):
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
37 self.form = FieldStorage()
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
38 self.client = MockNull()
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
39 self.client.form = self.form
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
40
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
41 class ShowActionTestCase(ActionTestCase):
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
42 def assertRaisesMessage(self, exception, callable, message, *args,
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
43 **kwargs):
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
44 """An extension of assertRaises, which also checks the exception
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
45 message. We need this because we rely on exception messages when
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
46 redirecting.
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
47 """
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
48 try:
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
49 callable(*args, **kwargs)
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
50 except exception, msg:
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
51 self.assertEqual(str(msg), message)
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
52 else:
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
53 if hasattr(excClass,'__name__'):
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
54 excName = excClass.__name__
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
55 else:
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
56 excName = str(excClass)
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
57 raise self.failureException, excName
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
58
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
59 def testShowAction(self):
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
60 self.client.base = 'BASE/'
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
61
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
62 action = ShowAction(self.client)
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
63 self.assertRaises(ValueError, action.handle)
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
64
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
65 self.form.value.append(MiniFieldStorage('@type', 'issue'))
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
66 self.assertRaises(SeriousError, action.handle)
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
67
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
68 self.form.value.append(MiniFieldStorage('@number', '1'))
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
69 self.assertRaisesMessage(Redirect, action.handle, 'BASE/issue1')
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
70
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
71 def testShowActionNoType(self):
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
72 action = ShowAction(self.client)
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
73 self.assertRaises(ValueError, action.handle)
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
74 self.form.value.append(MiniFieldStorage('@number', '1'))
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
75 self.assertRaisesMessage(ValueError, action.handle,
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
76 'No type specified')
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
77
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
78 class RetireActionTestCase(ActionTestCase):
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
79 def testRetireAction(self):
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
80 self.client.db.security.hasPermission = true
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
81 self.client.ok_message = []
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
82 RetireAction(self.client).handle()
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
83 self.assert_(len(self.client.ok_message) == 1)
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
84
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
85 def testNoPermission(self):
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
86 self.assertRaises(Unauthorised, RetireAction(self.client).execute)
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
87
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
88 def testDontRetireAdminOrAnonymous(self):
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
89 self.client.db.security.hasPermission=true
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
90 # look up the user class
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
91 self.client.classname = 'user'
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
92 # but always look up admin, regardless of nodeid
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
93 self.client.db.user.get = lambda a,b: 'admin'
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
94 self.assertRaises(ValueError, RetireAction(self.client).handle)
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
95 # .. or anonymous
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
96 self.client.db.user.get = lambda a,b: 'anonymous'
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
97 self.assertRaises(ValueError, RetireAction(self.client).handle)
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
98
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
99 class SearchActionTestCase(ActionTestCase):
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
100 def setUp(self):
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
101 ActionTestCase.setUp(self)
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
102 self.action = SearchAction(self.client)
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
103
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
104 class StandardSearchActionTestCase(SearchActionTestCase):
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
105 def testNoPermission(self):
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
106 self.assertRaises(Unauthorised, self.action.execute)
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
107
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
108 def testQueryName(self):
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
109 self.assertEqual(self.action.getQueryName(), '')
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
110
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
111 self.form.value.append(MiniFieldStorage('@queryname', 'foo'))
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
112 self.assertEqual(self.action.getQueryName(), 'foo')
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
113
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
114 class FakeFilterVarsTestCase(SearchActionTestCase):
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
115 def setUp(self):
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
116 SearchActionTestCase.setUp(self)
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
117 self.client.db.classes.getprops = lambda: {'foo': hyperdb.Multilink('foo')}
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
118
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
119 def assertFilterEquals(self, expected):
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
120 self.action.fakeFilterVars()
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
121 self.assertEqual(self.form.getvalue('@filter'), expected)
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
122
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
123 def testEmptyMultilink(self):
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
124 self.form.value.append(MiniFieldStorage('foo', ''))
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
125 self.form.value.append(MiniFieldStorage('foo', ''))
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
126
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
127 self.assertFilterEquals(None)
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
128
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
129 def testNonEmptyMultilink(self):
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
130 self.form.value.append(MiniFieldStorage('foo', ''))
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
131 self.form.value.append(MiniFieldStorage('foo', '1'))
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
132
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
133 self.assertFilterEquals('foo')
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
134
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
135 def testEmptyKey(self):
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
136 self.form.value.append(MiniFieldStorage('foo', ''))
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
137 self.assertFilterEquals(None)
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
138
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
139 def testStandardKey(self):
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
140 self.form.value.append(MiniFieldStorage('foo', '1'))
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
141 self.assertFilterEquals('foo')
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
142
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
143 def testStringKey(self):
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
144 self.client.db.classes.getprops = lambda: {'foo': hyperdb.String()}
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
145 self.form.value.append(MiniFieldStorage('foo', 'hello'))
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
146 self.assertFilterEquals('foo')
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
147
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
148 def testTokenizedStringKey(self):
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
149 self.client.db.classes.getprops = lambda: {'foo': hyperdb.String()}
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
150 self.form.value.append(MiniFieldStorage('foo', 'hello world'))
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
151
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
152 self.assertFilterEquals('foo')
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
153
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
154 # The single value gets replaced with the tokenized list.
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
155 self.assertEqual([x.value for x in self.form['foo']], ['hello', 'world'])
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
156
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
157 class CollisionDetectionTestCase(ActionTestCase):
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
158 def setUp(self):
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
159 ActionTestCase.setUp(self)
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
160 self.action = EditItemAction(self.client)
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
161 self.now = Date('.')
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
162 # round off for testing
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
163 self.now.second = int(self.now.second)
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
164
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
165 def testLastUserActivity(self):
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
166 self.assertEqual(self.action.lastUserActivity(), None)
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
167
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
168 self.client.form.value.append(MiniFieldStorage('@lastactivity', str(self.now)))
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
169 self.assertEqual(self.action.lastUserActivity(), self.now)
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
170
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
171 def testLastNodeActivity(self):
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
172 self.action.classname = 'issue'
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
173 self.action.nodeid = '1'
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
174
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
175 def get(nodeid, propname):
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
176 self.assertEqual(nodeid, '1')
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
177 self.assertEqual(propname, 'activity')
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
178 return self.now
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
179 self.client.db.issue.get = get
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
180
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
181 self.assertEqual(self.action.lastNodeActivity(), self.now)
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
182
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
183 def testCollision(self):
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
184 self.failUnless(self.action.detectCollision(self.now, self.now + Interval("1d")))
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
185 self.failIf(self.action.detectCollision(self.now, self.now - Interval("1d")))
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
186 self.failIf(self.action.detectCollision(None, self.now))
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
187
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
188 def test_suite():
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
189 suite = unittest.TestSuite()
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
190 suite.addTest(unittest.makeSuite(RetireActionTestCase))
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
191 suite.addTest(unittest.makeSuite(StandardSearchActionTestCase))
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
192 suite.addTest(unittest.makeSuite(FakeFilterVarsTestCase))
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
193 suite.addTest(unittest.makeSuite(ShowActionTestCase))
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
194 suite.addTest(unittest.makeSuite(CollisionDetectionTestCase))
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
195 return suite
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
196
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
197 if __name__ == '__main__':
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
198 runner = unittest.TextTestRunner()
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
199 unittest.main(testRunner=runner)
a15f91a10e45 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents: 2186
diff changeset
200

Roundup Issue Tracker: http://roundup-tracker.org/