-
Notifications
You must be signed in to change notification settings - Fork 0
/
test_validation_blacklist.py
65 lines (51 loc) · 2.54 KB
/
test_validation_blacklist.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
import copy
import unittest
from nanohttp import json, context
from microhttp_restful.validation import validate_form
from microhttp_restful.controllers import RestController, RootController
from microhttp_restful.tests.helpers import WebAppTestCase
from microhttp_restful.tests.helpers import authorize
class ValidationBlackListController(RestController):
@json
@authorize
@validate_form(blacklist=['blacklistParamForAll'],
client={'blacklist': ['blacklistParamForClient']},
admin={'blacklist': ['blacklistParamForAdmin']})
def post(self):
result = copy.deepcopy(context.form)
result.update(context.query)
return result
class Root(RootController):
validation = ValidationBlackListController()
class ValidationBlackListTestCase(WebAppTestCase):
@classmethod
def setUpClass(cls):
super().setUpClass()
cls.application.__root__ = Root()
def test_x(self):
# Test `blacklist`
# role -> All
self.wsgi_app.post('/validation', params={'customParam': 'param'})
self.wsgi_app.post('/validation')
self.wsgi_app.post('/validation', params={'customParam': 'param'})
self.wsgi_app.post('/validation', params={'blacklistParamForAll': 'param'}, status=400)
self.wsgi_app.post('/validation', params={'blacklistParamForClient': 'param'})
self.wsgi_app.post('/validation', params={'blacklistParamForAdmin': 'param'})
# -----------------------------
# role -> Client
self.wsgi_app.extra_environ['fake_roles'] = 'client'
self.wsgi_app.post('/validation')
self.wsgi_app.post('/validation', params={'customParam': 'param'})
self.wsgi_app.post('/validation', params={'blacklistParamForAll': 'param'}, status=400)
self.wsgi_app.post('/validation', params={'blacklistParamForClient': 'param'}, status=400)
self.wsgi_app.post('/validation', params={'blacklistParamForAdmin': 'param'})
# -----------------------------
# role -> Admin
self.wsgi_app.extra_environ['fake_roles'] = 'admin'
self.wsgi_app.post('/validation')
self.wsgi_app.post('/validation', params={'customParam': 'param'})
self.wsgi_app.post('/validation', params={'blacklistParamForAll': 'param'}, status=400)
self.wsgi_app.post('/validation', params={'blacklistParamForClient': 'param'})
self.wsgi_app.post('/validation', params={'blacklistParamForAdmin': 'param'}, status=400)
if __name__ == '__main__': # pragma: no cover
unittest.main()