Convert test_dict_autz into pytest style
This commit is contained in:
parent
e29666cea9
commit
8f527777f3
|
@ -50,10 +50,13 @@ def create_server(loop, unused_port):
|
||||||
|
|
||||||
@asyncio.coroutine
|
@asyncio.coroutine
|
||||||
def finish():
|
def finish():
|
||||||
yield from handler.finish_connections()
|
if handler is not None:
|
||||||
yield from app.finish()
|
yield from handler.finish_connections()
|
||||||
srv.close()
|
if app is not None:
|
||||||
yield from srv.wait_closed()
|
yield from app.finish()
|
||||||
|
if srv is not None:
|
||||||
|
srv.close()
|
||||||
|
yield from srv.wait_closed()
|
||||||
|
|
||||||
loop.run_until_complete(finish())
|
loop.run_until_complete(finish())
|
||||||
|
|
||||||
|
@ -105,7 +108,8 @@ def create_app_and_client(create_server, loop):
|
||||||
return app, client
|
return app, client
|
||||||
|
|
||||||
yield maker
|
yield maker
|
||||||
client.close()
|
if client is not None:
|
||||||
|
client.close()
|
||||||
|
|
||||||
|
|
||||||
@pytest.mark.tryfirst
|
@pytest.mark.tryfirst
|
||||||
|
|
|
@ -1,12 +1,11 @@
|
||||||
import asyncio
|
import asyncio
|
||||||
import socket
|
import pytest
|
||||||
import unittest
|
|
||||||
|
|
||||||
import aiohttp
|
|
||||||
from aiohttp import web
|
from aiohttp import web
|
||||||
from aiohttp_security import (remember, setup,
|
from aiohttp_security import (remember,
|
||||||
authorized_userid, permits,
|
authorized_userid, permits,
|
||||||
AbstractAuthorizationPolicy)
|
AbstractAuthorizationPolicy)
|
||||||
|
from aiohttp_security import setup as _setup
|
||||||
from aiohttp_security.cookies_identity import CookiesIdentityPolicy
|
from aiohttp_security.cookies_identity import CookiesIdentityPolicy
|
||||||
|
|
||||||
|
|
||||||
|
@ -27,133 +26,94 @@ class Autz(AbstractAuthorizationPolicy):
|
||||||
return None
|
return None
|
||||||
|
|
||||||
|
|
||||||
class TestCookiesIdentity(unittest.TestCase):
|
@pytest.mark.run_loop
|
||||||
|
def test_authorized_userid(create_app_and_client):
|
||||||
def setUp(self):
|
|
||||||
self.loop = asyncio.new_event_loop()
|
|
||||||
asyncio.set_event_loop(None)
|
|
||||||
self.client = aiohttp.ClientSession(loop=self.loop)
|
|
||||||
|
|
||||||
def tearDown(self):
|
|
||||||
self.client.close()
|
|
||||||
self.loop.run_until_complete(self.handler.finish_connections())
|
|
||||||
self.srv.close()
|
|
||||||
self.loop.run_until_complete(self.srv.wait_closed())
|
|
||||||
self.loop.close()
|
|
||||||
|
|
||||||
def find_unused_port(self):
|
|
||||||
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
|
|
||||||
s.bind(('127.0.0.1', 0))
|
|
||||||
port = s.getsockname()[1]
|
|
||||||
s.close()
|
|
||||||
return port
|
|
||||||
|
|
||||||
@asyncio.coroutine
|
@asyncio.coroutine
|
||||||
def create_server(self):
|
def login(request):
|
||||||
app = web.Application(loop=self.loop)
|
response = web.HTTPFound(location='/')
|
||||||
setup(app, CookiesIdentityPolicy(), Autz())
|
yield from remember(request, response, 'UserID')
|
||||||
|
return response
|
||||||
|
|
||||||
port = self.find_unused_port()
|
@asyncio.coroutine
|
||||||
self.handler = app.make_handler(
|
def check(request):
|
||||||
debug=False, keep_alive_on=False)
|
userid = yield from authorized_userid(request)
|
||||||
srv = yield from self.loop.create_server(
|
assert 'Andrew' == userid
|
||||||
self.handler, '127.0.0.1', port)
|
return web.Response(text=userid)
|
||||||
url = "http://127.0.0.1:{}".format(port)
|
|
||||||
self.srv = srv
|
|
||||||
return app, srv, url
|
|
||||||
|
|
||||||
def test_authorized_userid(self):
|
app, client = yield from create_app_and_client()
|
||||||
|
_setup(app, CookiesIdentityPolicy(), Autz())
|
||||||
|
app.router.add_route('GET', '/', check)
|
||||||
|
app.router.add_route('POST', '/login', login)
|
||||||
|
|
||||||
@asyncio.coroutine
|
resp = yield from client.post('/login')
|
||||||
def login(request):
|
assert 200 == resp.status
|
||||||
response = web.HTTPFound(location='/')
|
txt = yield from resp.text()
|
||||||
yield from remember(request, response, 'UserID')
|
assert 'Andrew' == txt
|
||||||
return response
|
yield from resp.release()
|
||||||
|
|
||||||
@asyncio.coroutine
|
|
||||||
def check(request):
|
|
||||||
userid = yield from authorized_userid(request)
|
|
||||||
self.assertEqual('Andrew', userid)
|
|
||||||
return web.Response(text=userid)
|
|
||||||
|
|
||||||
@asyncio.coroutine
|
@pytest.mark.run_loop
|
||||||
def go():
|
def test_authorized_userid_not_authorized(create_app_and_client):
|
||||||
app, srv, url = yield from self.create_server()
|
|
||||||
app.router.add_route('GET', '/', check)
|
|
||||||
app.router.add_route('POST', '/login', login)
|
|
||||||
resp = yield from self.client.post(url+'/login')
|
|
||||||
self.assertEqual(200, resp.status)
|
|
||||||
txt = yield from resp.text()
|
|
||||||
self.assertEqual('Andrew', txt)
|
|
||||||
yield from resp.release()
|
|
||||||
|
|
||||||
self.loop.run_until_complete(go())
|
@asyncio.coroutine
|
||||||
|
def check(request):
|
||||||
|
userid = yield from authorized_userid(request)
|
||||||
|
assert userid is None
|
||||||
|
return web.Response()
|
||||||
|
|
||||||
def test_authorized_userid_not_authorized(self):
|
app, client = yield from create_app_and_client()
|
||||||
|
_setup(app, CookiesIdentityPolicy(), Autz())
|
||||||
|
app.router.add_route('GET', '/', check)
|
||||||
|
resp = yield from client.get('/')
|
||||||
|
assert 200 == resp.status
|
||||||
|
yield from resp.release()
|
||||||
|
|
||||||
@asyncio.coroutine
|
|
||||||
def check(request):
|
|
||||||
userid = yield from authorized_userid(request)
|
|
||||||
self.assertIsNone(userid)
|
|
||||||
return web.Response()
|
|
||||||
|
|
||||||
@asyncio.coroutine
|
@pytest.mark.run_loop
|
||||||
def go():
|
def test_permits(create_app_and_client):
|
||||||
app, srv, url = yield from self.create_server()
|
|
||||||
app.router.add_route('GET', '/', check)
|
|
||||||
resp = yield from self.client.get(url+'/')
|
|
||||||
self.assertEqual(200, resp.status)
|
|
||||||
yield from resp.release()
|
|
||||||
|
|
||||||
self.loop.run_until_complete(go())
|
@asyncio.coroutine
|
||||||
|
def login(request):
|
||||||
|
response = web.HTTPFound(location='/')
|
||||||
|
yield from remember(request, response, 'UserID')
|
||||||
|
return response
|
||||||
|
|
||||||
def test_permits(self):
|
@asyncio.coroutine
|
||||||
|
def check(request):
|
||||||
|
ret = yield from permits(request, 'read')
|
||||||
|
assert ret
|
||||||
|
ret = yield from permits(request, 'write')
|
||||||
|
assert ret
|
||||||
|
ret = yield from permits(request, 'unknown')
|
||||||
|
assert not ret
|
||||||
|
return web.Response()
|
||||||
|
|
||||||
@asyncio.coroutine
|
app, client = yield from create_app_and_client()
|
||||||
def login(request):
|
_setup(app, CookiesIdentityPolicy(), Autz())
|
||||||
response = web.HTTPFound(location='/')
|
app.router.add_route('GET', '/', check)
|
||||||
yield from remember(request, response, 'UserID')
|
app.router.add_route('POST', '/login', login)
|
||||||
return response
|
resp = yield from client.post('/login')
|
||||||
|
assert 200 == resp.status
|
||||||
|
yield from resp.release()
|
||||||
|
|
||||||
@asyncio.coroutine
|
|
||||||
def check(request):
|
|
||||||
ret = yield from permits(request, 'read')
|
|
||||||
self.assertTrue(ret)
|
|
||||||
ret = yield from permits(request, 'write')
|
|
||||||
self.assertTrue(ret)
|
|
||||||
ret = yield from permits(request, 'unknown')
|
|
||||||
self.assertFalse(ret)
|
|
||||||
return web.Response()
|
|
||||||
|
|
||||||
@asyncio.coroutine
|
@pytest.mark.run_loop
|
||||||
def go():
|
def test_permits_unauthorized(create_app_and_client):
|
||||||
app, srv, url = yield from self.create_server()
|
|
||||||
app.router.add_route('GET', '/', check)
|
|
||||||
app.router.add_route('POST', '/login', login)
|
|
||||||
resp = yield from self.client.post(url+'/login')
|
|
||||||
self.assertEqual(200, resp.status)
|
|
||||||
yield from resp.release()
|
|
||||||
|
|
||||||
self.loop.run_until_complete(go())
|
@asyncio.coroutine
|
||||||
|
def check(request):
|
||||||
|
ret = yield from permits(request, 'read')
|
||||||
|
assert not ret
|
||||||
|
ret = yield from permits(request, 'write')
|
||||||
|
assert not ret
|
||||||
|
ret = yield from permits(request, 'unknown')
|
||||||
|
assert not ret
|
||||||
|
return web.Response()
|
||||||
|
|
||||||
def test_permits_unauthorized(self):
|
app, client = yield from create_app_and_client()
|
||||||
|
_setup(app, CookiesIdentityPolicy(), Autz())
|
||||||
@asyncio.coroutine
|
app.router.add_route('GET', '/', check)
|
||||||
def check(request):
|
resp = yield from client.get('/')
|
||||||
ret = yield from permits(request, 'read')
|
assert 200 == resp.status
|
||||||
self.assertFalse(ret)
|
yield from resp.release()
|
||||||
ret = yield from permits(request, 'write')
|
|
||||||
self.assertFalse(ret)
|
|
||||||
ret = yield from permits(request, 'unknown')
|
|
||||||
self.assertFalse(ret)
|
|
||||||
return web.Response()
|
|
||||||
|
|
||||||
@asyncio.coroutine
|
|
||||||
def go():
|
|
||||||
app, srv, url = yield from self.create_server()
|
|
||||||
app.router.add_route('GET', '/', check)
|
|
||||||
resp = yield from self.client.get(url+'/')
|
|
||||||
self.assertEqual(200, resp.status)
|
|
||||||
yield from resp.release()
|
|
||||||
|
|
||||||
self.loop.run_until_complete(go())
|
|
||||||
|
|
Loading…
Reference in New Issue