| author | Sandro Knauß <knauss@netzguerilla.net> |
| Sun, 26 Feb 2012 19:46:26 +0100 | |
| branch | devel |
| changeset 191 | 1816e97881ce |
| parent 190 | 71221fd1f7c1 |
| child 192 | 6c708c334f37 |
| permissions | -rw-r--r-- |
| 190 | 1 |
from twisted.internet.defer import inlineCallbacks |
2 |
from datetime import datetime |
|
|
191
1816e97881ce
test viewinterface.sms added
Sandro Knauß <knauss@netzguerilla.net>
parents:
190
diff
changeset
|
3 |
from Queue import deque |
| 190 | 4 |
|
5 |
from iro.model.schema import User, Offer, Userright, Job, Message |
|
6 |
from iro.controller.viewinterface import Interface |
|
|
191
1816e97881ce
test viewinterface.sms added
Sandro Knauß <knauss@netzguerilla.net>
parents:
190
diff
changeset
|
7 |
from iro.controller.pool import taskPool |
|
1816e97881ce
test viewinterface.sms added
Sandro Knauß <knauss@netzguerilla.net>
parents:
190
diff
changeset
|
8 |
|
| 190 | 9 |
from iro.model.pool import data |
|
191
1816e97881ce
test viewinterface.sms added
Sandro Knauß <knauss@netzguerilla.net>
parents:
190
diff
changeset
|
10 |
from iro.model.offer import offers |
|
1816e97881ce
test viewinterface.sms added
Sandro Knauß <knauss@netzguerilla.net>
parents:
190
diff
changeset
|
11 |
from iro.model.job import exJobs |
| 190 | 12 |
|
13 |
import iro.error as IroError |
|
14 |
||
15 |
from .dbtestcase import DBTestCase |
|
16 |
||
17 |
class DummyPool(): |
|
18 |
def run(self, f,*a,**k): |
|
19 |
return f(*a,**k) |
|
20 |
||
21 |
class ViewInterfaceTest(DBTestCase): |
|
22 |
"""tests for the xmlrpc interface""" |
|
23 |
def setUp(self): |
|
24 |
DBTestCase.setUp(self) |
|
25 |
self.pool = data.pool |
|
26 |
data.pool = DummyPool() |
|
27 |
||
28 |
def tearDown(self): |
|
|
191
1816e97881ce
test viewinterface.sms added
Sandro Knauß <knauss@netzguerilla.net>
parents:
190
diff
changeset
|
29 |
exJobs.clear() |
|
1816e97881ce
test viewinterface.sms added
Sandro Knauß <knauss@netzguerilla.net>
parents:
190
diff
changeset
|
30 |
offers.clear() |
|
1816e97881ce
test viewinterface.sms added
Sandro Knauß <knauss@netzguerilla.net>
parents:
190
diff
changeset
|
31 |
taskPool.pool.q.queue = deque() |
| 190 | 32 |
data.pool = self.pool |
33 |
self.pool = None |
|
34 |
DBTestCase.tearDown(self) |
|
35 |
||
36 |
@inlineCallbacks |
|
37 |
def testStatus(self): |
|
38 |
''' test the status function''' |
|
39 |
with self.session() as session: |
|
40 |
u = User(name='test',apikey='abcdef123456789') |
|
41 |
session.add(User(name='test',apikey='abcdef123456789')) |
|
42 |
st = yield Interface().status('abcdef123456789') |
|
43 |
self.assertEqual(st, {}) |
|
44 |
||
45 |
with self.session() as session: |
|
46 |
u = session.merge(u) |
|
47 |
j = Job(info='info', status="started") |
|
48 |
j.user=u |
|
49 |
session.add(j) |
|
50 |
session.commit() |
|
51 |
jid=j.id |
|
52 |
status = {str(jid):{"status":"started"}} |
|
53 |
st = yield Interface().status('abcdef123456789',jid) |
|
54 |
self.assertEqual(st, status) |
|
55 |
st = yield Interface().status('abcdef123456789') |
|
56 |
self.assertEqual(st, status) |
|
57 |
st = yield Interface().status('abcdef123456789', '', 'false') |
|
58 |
self.assertEqual(st, status) |
|
59 |
st = yield Interface().status('abcdef123456789', '', 0) |
|
60 |
self.assertEqual(st, status) |
|
61 |
||
62 |
#JobNotFound |
|
63 |
d = Interface().status('abcdef123456789',jid+1) |
|
64 |
self.assertFailure(d, IroError.JobNotFound) |
|
65 |
yield d |
|
66 |
||
67 |
#self.assertEqual(self.__rpc2().status('abcdef123456789','abcde', True), ["<User('test','abcdef123456789')>",'abcde', True]) |
|
68 |
#self.assertEqual(self.__rpc2().status('abcdef123456789', '', 'true'), ["<User('test','abcdef123456789')>", '', True]) |
|
69 |
#self.assertEqual(self.__rpc2().status('abcdef123456789', '', 1), ["<User('test','abcdef123456789')>", '', True]) |
|
70 |
||
71 |
def testNoSuchUser(self): |
|
72 |
'''a unknown user should raise a UserNotNound Exception |
|
73 |
bewcause xmlrpc only has a Fault exception this Exception has to be deliverd through a xmlrpclib.Fault Exception''' |
|
74 |
d = Interface().status('abcdef123456789') |
|
75 |
self.assertFailure(d, IroError.UserNotFound) |
|
76 |
return d |
|
77 |
||
78 |
||
79 |
def testValidationFault(self): |
|
80 |
'''a validate Exception should be translated to a xmlrpclib.Fault.''' |
|
81 |
d = Interface().status('xxx') |
|
82 |
self.assertFailure(d, IroError.ValidateException) |
|
83 |
||
84 |
@inlineCallbacks |
|
85 |
def testRoutes(self): |
|
86 |
'''test the route function''' |
|
87 |
with self.session() as session: |
|
88 |
u=User(name='test',apikey='abcdef123456789') |
|
89 |
o=Offer(name="sipgate_basic", provider="sipgate", route="basic", typ="sms") |
|
90 |
u.rights.append(Userright(o)) |
|
91 |
session.add(u) |
|
92 |
r = yield Interface().routes('abcdef123456789','sms') |
|
93 |
self.assertEqual(r, ['sipgate_basic']) |
|
94 |
||
95 |
d = Interface().routes('abcdef123456789','fax') |
|
96 |
self.assertFailure(d,IroError.ValidateException) |
|
97 |
yield d |
|
98 |
||
99 |
with self.session() as session: |
|
100 |
o=Offer(name="sipgate_plus", provider="sipgate", route="plus", typ="sms") |
|
101 |
u = session.query(User).filter_by(name="test").first() |
|
102 |
u.rights.append(Userright(o)) |
|
103 |
o=Offer(name="faxde", provider="faxde", route="", typ="fax") |
|
104 |
session.add(o) |
|
105 |
session.commit() |
|
106 |
||
107 |
r = yield Interface().routes('abcdef123456789','sms') |
|
108 |
self.assertEqual(r, ['sipgate_basic','sipgate_plus']) |
|
109 |
r = yield Interface().routes('abcdef123456789','fax') |
|
110 |
self.assertEqual(r, []) |
|
111 |
||
112 |
||
113 |
with self.session() as session: |
|
114 |
u = session.query(User).filter_by(name="test").first() |
|
115 |
u.rights.append(Userright(o)) |
|
116 |
||
117 |
r = yield Interface().routes('abcdef123456789','sms') |
|
118 |
self.assertEqual(r, ['sipgate_basic','sipgate_plus']) |
|
119 |
r = yield Interface().routes('abcdef123456789','fax') |
|
120 |
self.assertEqual(r, ['faxde']) |
|
121 |
||
122 |
@inlineCallbacks |
|
123 |
def testDefaultRoutes(self): |
|
124 |
'''test the defaultRoute function''' |
|
125 |
with self.session() as session: |
|
126 |
u=User(name='test',apikey='abcdef123456789') |
|
127 |
o=Offer(name="sipgate_basic", provider="sipgate", route="basic", typ="sms") |
|
128 |
u.rights.append(Userright(o,True)) |
|
129 |
o=Offer(name="sipgate_plus", provider="sipgate", route="plus", typ="sms") |
|
130 |
u.rights.append(Userright(o)) |
|
131 |
session.add(u) |
|
132 |
r = yield Interface().defaultRoute('abcdef123456789','sms') |
|
133 |
self.assertEqual(r, ['sipgate_basic']) |
|
134 |
||
135 |
@inlineCallbacks |
|
136 |
def testTelnumbers(self): |
|
137 |
'''test the telefon validator''' |
|
138 |
r = yield Interface().telnumber(["0123/456(78)","+4912346785433","00123435456-658"]) |
|
139 |
self.assertEqual(r, True) |
|
140 |
||
141 |
invalid=['xa','+1','1-23',';:+0','0123'] |
|
142 |
||
143 |
d = Interface().telnumber(['01234']+invalid) |
|
144 |
def x(failure): |
|
145 |
self.assertEqual(failure.getErrorMessage(),"701:No valid telnumber: '%s'"%invalid[0]) |
|
146 |
failure.raiseException() |
|
147 |
d.addErrback(x) |
|
148 |
self.assertFailure(d, IroError.InvalidTel) |
|
149 |
yield d |
|
150 |
||
151 |
@inlineCallbacks |
|
152 |
def testVaildEmail(self): |
|
153 |
'''test vaild email adresses (got from wikipedia)''' |
|
154 |
validmails=["niceandsimple@example.com"] |
|
155 |
r = yield Interface().email(validmails) |
|
156 |
self.assertEqual(r,True) |
|
157 |
||
158 |
def testInvaildEmail(self): |
|
159 |
'''test invaild email adresses (got from wikipedia)''' |
|
160 |
invalid=["Abc.example.com",] |
|
161 |
d = Interface().email(invalid) |
|
162 |
self.assertFailure(d, IroError.InvalidMail) |
|
163 |
return d |
|
164 |
||
165 |
@inlineCallbacks |
|
166 |
def testBill(self): |
|
167 |
'''test bill function''' |
|
168 |
apikey='abcdef123456789' |
|
169 |
with self.session() as session: |
|
170 |
u=User(name='test',apikey=apikey) |
|
171 |
session.add(u) |
|
172 |
||
173 |
r = yield Interface().bill(apikey) |
|
174 |
self.assertEqual(r,{'total':{'price':0.0,'anz':0}}) |
|
175 |
||
176 |
with self.session() as session: |
|
177 |
u = session.merge(u) |
|
178 |
o = Offer(name='sipgate_basic',provider="sipgate",route="basic",typ="sms") |
|
179 |
u.rights.append(Userright(o)) |
|
180 |
j = Job(info='i',status='sended') |
|
181 |
j.messages.append(Message(recipient='0123456789', isBilled=False, date=datetime.now() , price=0.4, offer=o)) |
|
182 |
u.jobs.append(j) |
|
183 |
||
184 |
j = Job(info='a',status='sended') |
|
185 |
j.messages.append(Message(recipient='0123456789', isBilled=False, date=datetime.now(), price=0.4, offer=o)) |
|
186 |
u.jobs.append(j) |
|
187 |
||
188 |
ret=yield Interface().bill(apikey) |
|
189 |
self.assertEqual(ret['total'],{'price':0.8,'anz':2}) |
|
190 |
self.assertEqual(ret['sipgate_basic'], |
|
191 |
{'price':0.8,'anz':2, |
|
192 |
'info':{'i':{'price':0.4,'anz':1}, |
|
193 |
'a':{'price':0.4,'anz':1}, |
|
194 |
} |
|
195 |
}) |
|
196 |
||
|
191
1816e97881ce
test viewinterface.sms added
Sandro Knauß <knauss@netzguerilla.net>
parents:
190
diff
changeset
|
197 |
@inlineCallbacks |
|
1816e97881ce
test viewinterface.sms added
Sandro Knauß <knauss@netzguerilla.net>
parents:
190
diff
changeset
|
198 |
def testSMS(self): |
|
1816e97881ce
test viewinterface.sms added
Sandro Knauß <knauss@netzguerilla.net>
parents:
190
diff
changeset
|
199 |
with self.session() as session: |
|
1816e97881ce
test viewinterface.sms added
Sandro Knauß <knauss@netzguerilla.net>
parents:
190
diff
changeset
|
200 |
u = User(name='test',apikey='abcdef123456789') |
|
1816e97881ce
test viewinterface.sms added
Sandro Knauß <knauss@netzguerilla.net>
parents:
190
diff
changeset
|
201 |
o = Offer(name='sipgate_basic',provider="sipgate",route="basic",typ="sms") |
|
1816e97881ce
test viewinterface.sms added
Sandro Knauß <knauss@netzguerilla.net>
parents:
190
diff
changeset
|
202 |
u.rights.append(Userright(o)) |
|
1816e97881ce
test viewinterface.sms added
Sandro Knauß <knauss@netzguerilla.net>
parents:
190
diff
changeset
|
203 |
session.add(u) |
|
1816e97881ce
test viewinterface.sms added
Sandro Knauß <knauss@netzguerilla.net>
parents:
190
diff
changeset
|
204 |
|
|
1816e97881ce
test viewinterface.sms added
Sandro Knauß <knauss@netzguerilla.net>
parents:
190
diff
changeset
|
205 |
jobid = yield Interface().sms('abcdef123456789','message',['0123325456'],['basic']) |
|
1816e97881ce
test viewinterface.sms added
Sandro Knauß <knauss@netzguerilla.net>
parents:
190
diff
changeset
|
206 |
|
|
1816e97881ce
test viewinterface.sms added
Sandro Knauß <knauss@netzguerilla.net>
parents:
190
diff
changeset
|
207 |
with self.session() as session: |
|
1816e97881ce
test viewinterface.sms added
Sandro Knauß <knauss@netzguerilla.net>
parents:
190
diff
changeset
|
208 |
u = session.merge(u) |
|
1816e97881ce
test viewinterface.sms added
Sandro Knauß <knauss@netzguerilla.net>
parents:
190
diff
changeset
|
209 |
u.job(jobid) |
|
1816e97881ce
test viewinterface.sms added
Sandro Knauß <knauss@netzguerilla.net>
parents:
190
diff
changeset
|
210 |
|
|
1816e97881ce
test viewinterface.sms added
Sandro Knauß <knauss@netzguerilla.net>
parents:
190
diff
changeset
|
211 |
self.assertEqual(taskPool.pool.q.qsize(),1) |
| 190 | 212 |
|
213 |
||
|
191
1816e97881ce
test viewinterface.sms added
Sandro Knauß <knauss@netzguerilla.net>
parents:
190
diff
changeset
|
214 |
def testMail(self): |
|
1816e97881ce
test viewinterface.sms added
Sandro Knauß <knauss@netzguerilla.net>
parents:
190
diff
changeset
|
215 |
pass |
|
1816e97881ce
test viewinterface.sms added
Sandro Knauß <knauss@netzguerilla.net>
parents:
190
diff
changeset
|
216 |
testMail.todo = "To implement" |
| 190 | 217 |
|
|
191
1816e97881ce
test viewinterface.sms added
Sandro Knauß <knauss@netzguerilla.net>
parents:
190
diff
changeset
|
218 |
def testFax(self): |
|
1816e97881ce
test viewinterface.sms added
Sandro Knauß <knauss@netzguerilla.net>
parents:
190
diff
changeset
|
219 |
pass |
|
1816e97881ce
test viewinterface.sms added
Sandro Knauß <knauss@netzguerilla.net>
parents:
190
diff
changeset
|
220 |
testFax.todo = "To implement" |