X-Git-Url: https://code.wpia.club/?a=blobdiff_plain;f=tests%2Ftest_motion.py;h=0bee29420e123a31029dcc6922b3d1c9103a71d7;hb=a2361dff44b3bf95ad7f367484b6bc805b22819d;hp=1bc65858461318e377cf8660479502895cf80cff;hpb=66a7e727089249cd3eeea99c2aead5fb6a9550ce;p=motion.git
diff --git a/tests/test_motion.py b/tests/test_motion.py
index 1bc6585..0bee294 100644
--- a/tests/test_motion.py
+++ b/tests/test_motion.py
@@ -9,7 +9,8 @@ app.config.update(
DEBUGUSER = {},
GROUP_PREFIX = {'127.0.0.1:5000': {'group1': 'g1', 'group2': 'g2'}},
DURATION = {'127.0.0.1:5000':[3, 7, 14]},
- SERVER_NAME = '127.0.0.1:5000'
+ SERVER_NAME = '127.0.0.1:5000',
+ MAX_PROXY=2
)
app.config['TESTING'] = True
@@ -26,9 +27,9 @@ class BasicTest(TestCase):
self.db_clear()
# functions to manipulate motions
- def createVote(self, user, motion, vote):
+ def createVote(self, user, motion, vote, voter):
return self.app.post(
- '/motion/' + motion +'/vote',
+ '/motion/' + motion + '/vote/' + str(voter),
environ_base={'USER_ROLES': user},
data=dict(vote=vote)
)
@@ -54,6 +55,20 @@ class BasicTest(TestCase):
environ_base={'USER_ROLES': user}
)
+ def addProxy(self, user, voter, proxy):
+ return self.app.post(
+ '/proxy/add',
+ environ_base={'USER_ROLES': user},
+ data=dict(voter=voter, proxy=proxy)
+ )
+
+ def revokeProxy(self, user, id):
+ return self.app.post(
+ '/proxy/revoke',
+ environ_base={'USER_ROLES': user},
+ data=dict(id=id)
+ )
+
def buildResultText(self, motiontext, yes, no, abstain):
return '
'+motiontext+'
\n \nYes '+str(yes)+'
'\
+ '\nNo '+str(no)+'
'\
@@ -78,6 +93,8 @@ class GeneralTests(BasicTest):
self.init_test()
global user
user = 'testuser/'
+ global userid
+ userid = 4
self.db_sampledata()
def tearDown(self):
@@ -126,6 +143,8 @@ class GeneralTests(BasicTest):
+ '\nNo 1
'\
+ '\nAbstain 0
\n
\n \n\n'
self.assertIn(str.encode(testtext), result.data)
+ testtext= 'Proxy management'
+ self.assertNotIn(str.encode(testtext), result.data)
# start with second motion
result = self.app.get('/', environ_base={'USER_ROLES': user}, query_string=dict(start=2))
@@ -144,7 +163,7 @@ class GeneralTests(BasicTest):
def test_vote(self):
motion='g1.20200402.004'
- response = self.createVote(user, motion, 'yes')
+ response = self.createVote(user, motion, 'yes', userid)
self.assertEqual(response.status_code, 403)
self.assertIn(str.encode('Forbidden'), response.data)
@@ -169,13 +188,34 @@ class GeneralTests(BasicTest):
self.assertEqual(result.status_code, 404)
self.assertIn(str.encode('Error, Not found'), result.data)
+ def test_no_proxy(self):
+ result = self.app.get('proxy', environ_base={'USER_ROLES': user}, follow_redirects=True)
+ self.assertEqual(result.status_code, 403)
+ self.assertIn(str.encode('Forbidden'), result.data)
+
+ def test_no_proxy_add(self):
+ result = self.app.post('proxy/add', environ_base={'USER_ROLES': user}, follow_redirects=True)
+ self.assertEqual(result.status_code, 403)
+ self.assertIn(str.encode('Forbidden'), result.data)
+
+ def test_no_proxy_revoke(self):
+ result = self.app.post('proxy/revoke', environ_base={'USER_ROLES': user}, follow_redirects=True)
+ self.assertEqual(result.status_code, 403)
+ self.assertIn(str.encode('Forbidden'), result.data)
+ def test_no_proxy_revokeAll(self):
+ result = self.app.post('proxy/revokeall', environ_base={'USER_ROLES': user}, follow_redirects=True)
+ self.assertEqual(result.status_code, 403)
+ self.assertIn(str.encode('Forbidden'), result.data)
+
class VoterTests(BasicTest):
def setUp(self):
self.init_test()
global user
user='testuser/vote:*'
+ global userid
+ userid = 4
self.db_sampledata()
def tearDown(self):
@@ -191,7 +231,7 @@ class VoterTests(BasicTest):
def test_vote_yes(self):
motion='g1.20200402.004'
- response = self.createVote(user, motion, 'yes')
+ response = self.createVote(user, motion, 'yes', userid)
self.assertEqual(response.status_code, 302)
result = self.app.get('/', environ_base={'USER_ROLES': user})
resulttext=self.buildResultText('A fourth motion', 1, 0, 0)
@@ -205,7 +245,7 @@ class VoterTests(BasicTest):
def test_vote_no(self):
motion='g1.20200402.004'
- response = self.createVote(user, motion, 'no')
+ response = self.createVote(user, motion, 'no', userid)
self.assertEqual(response.status_code, 302)
result = self.app.get('/', environ_base={'USER_ROLES': user})
resulttext=self.buildResultText('A fourth motion', 0, 1, 0)
@@ -220,7 +260,7 @@ class VoterTests(BasicTest):
def test_vote_abstain(self):
motion='g1.20200402.004'
- response = self.createVote(user, motion, 'abstain')
+ response = self.createVote(user, motion, 'abstain', userid)
self.assertEqual(response.status_code, 302)
result = self.app.get('/', environ_base={'USER_ROLES': user})
resulttext=self.buildResultText('A fourth motion', 0, 0, 1)
@@ -235,17 +275,17 @@ class VoterTests(BasicTest):
def test_vote_change(self):
motion='g1.20200402.004'
- response = self.createVote(user, motion, 'yes')
+ response = self.createVote(user, motion, 'yes', userid)
self.assertEqual(response.status_code, 302)
result = self.app.get('/', environ_base={'USER_ROLES': user})
resulttext=self.buildResultText('A fourth motion', 1, 0, 0)
self.assertIn(str.encode(resulttext), result.data)
- response = self.createVote(user, motion, 'no')
+ response = self.createVote(user, motion, 'no', userid)
self.assertEqual(response.status_code, 302)
result = self.app.get('/', environ_base={'USER_ROLES': user})
resulttext=self.buildResultText('A fourth motion', 0, 1, 0)
self.assertIn(str.encode(resulttext), result.data)
- response = self.createVote(user, motion, 'abstain')
+ response = self.createVote(user, motion, 'abstain', userid)
self.assertEqual(response.status_code, 302)
result = self.app.get('/', environ_base={'USER_ROLES': user})
resulttext=self.buildResultText('A fourth motion', 0, 0, 1)
@@ -253,41 +293,41 @@ class VoterTests(BasicTest):
def test_vote_group(self):
motion='g1.20200402.004'
- response = self.createVote(user, motion, 'yes')
+ response = self.createVote(user, motion, 'yes', userid)
self.assertEqual(response.status_code, 302)
motion='g1.20200402.004'
user1='testuser/vote:group1'
- response = self.createVote(user1, motion, 'yes')
+ response = self.createVote(user1, motion, 'yes', userid)
self.assertEqual(response.status_code, 302)
motion='g1.20200402.004'
user1='testuser/vote:group1 vote:group2'
- response = self.createVote(user1, motion, 'yes')
+ response = self.createVote(user1, motion, 'yes', userid)
self.assertEqual(response.status_code, 302)
def test_vote_wrong_group(self):
motion='g1.20200402.004'
user1='testuser/vote:group2'
- response = self.createVote(user1, motion, 'yes')
+ response = self.createVote(user1, motion, 'yes', userid)
self.assertEqual(response.status_code, 403)
self.assertIn(str.encode('Forbidden'), response.data)
def test_vote_closed(self):
motion='g1.20200402.002'
- response = self.createVote(user, motion, 'abstain')
+ response = self.createVote(user, motion, 'abstain', userid)
self.assertEqual(response.status_code, 403)
self.assertIn(str.encode('Error, out of time'), response.data)
def test_vote_canceled(self):
motion='g1.20200402.003'
- response = self.createVote(user, motion, 'abstain')
+ response = self.createVote(user, motion, 'abstain', userid)
self.assertEqual(response.status_code, 403)
self.assertIn(str.encode('Error, motion was canceled'), response.data)
def test_vote_not_given(self):
motion='g1.30190402.001'
- response = self.createVote(user, motion, 'abstain')
+ response = self.createVote(user, motion, 'abstain', userid)
self.assertEqual(response.status_code, 404)
self.assertIn(str.encode('Error, Not found'), response.data)
@@ -517,6 +557,313 @@ class AuditMotionTests(BasicTest):
+ '\n User C: no
\n \n\nBack'
self.assertIn(str.encode(testtext), result.data)
+class ProxyManagementTests(BasicTest):
+
+ def setUp(self):
+ self.init_test()
+ global user
+ user='testuser/proxyadmin:*'
+ self.db_sampledata()
+
+ def tearDown(self):
+ pass
+
+ def test_see_proxy(self):
+ result = self.app.get('proxy', environ_base={'USER_ROLES': user}, follow_redirects=True)
+ testtext= 'div class="container">\n'
+ self.assertIn(str.encode(testtext), result.data)
+ # proxy vote with change
+ testtext= '\n'
+ self.assertIn(str.encode(testtext), result.data)
+
+ # User B view
+ result = self.app.get('/motion/' + motion, environ_base={'USER_ROLES': proxyuser}, follow_redirects=True)
+ # own vote without change
+ testtext= 'My vote
\nGiven by testuser\n'\
+ + ''
+ self.assertIn(str.encode(testtext), result.data)
+
+ # change vote
+ response = self.createVote(user, motion, 'no', proxyid)
+ self.assertEqual(response.status_code, 302)
+
+ result = self.app.get('/motion/' + motion, environ_base={'USER_ROLES': user}, follow_redirects=True)
+ testtext= '\n'
+ self.assertIn(str.encode(testtext), result.data)
+
+ def test_proxy_vote_no_proxy(self):
+ voter='testuser'
+ proxy='User B'
+ # wrong proxy id
+ proxyid=3
+
+ response = self.addProxy(user, proxy, voter)
+ self.assertEqual(response.status_code, 302)
+
+ motion='g1.20200402.004'
+ response = self.createVote(user, motion, 'yes', proxyid)
+ self.assertEqual(response.status_code, 400)
+ self.assertIn(str.encode('Error, proxy not found'), response.data)
+
+ # non existing id
+ proxyid=10000
+
+ motion='g1.20200402.004'
+ response = self.createVote(user, motion, 'yes', proxyid)
+ self.assertEqual(response.status_code, 400)
+ self.assertIn(str.encode('Error, proxy not found'), response.data)
+
+ def test_proxy_vote_no_voter(self):
+ voter='User A'
+ proxy='User B'
+ proxyid=2
+
+ response = self.addProxy(user, proxy, voter)
+ self.assertEqual(response.status_code, 302)
+
+ user1='testuser1/'
+ motion='g1.20200402.004'
+ response = self.createVote(user1, motion, 'yes', proxyid)
+ self.assertEqual(response.status_code, 403)
+ self.assertIn(str.encode('Forbidden'), response.data)
+
+
if __name__ == "__main__":
unittest.main()