canaille-globuzma/tests/oidc/test_code_admin.py

94 lines
2.8 KiB
Python
Raw Normal View History

from canaille.oidc.models import AuthorizationCode
from werkzeug.security import gen_salt
2020-08-26 14:27:08 +00:00
def test_no_logged_no_access(testclient):
2020-08-26 15:23:53 +00:00
testclient.get("/admin/authorization", status=403)
2020-08-26 14:27:08 +00:00
def test_no_admin_no_access(testclient, logged_user):
2020-08-26 15:23:53 +00:00
testclient.get("/admin/authorization", status=403)
2020-08-26 14:27:08 +00:00
def test_authorizaton_list(testclient, authorization, logged_admin):
2020-08-26 15:23:53 +00:00
res = testclient.get("/admin/authorization")
res.mustcontain(authorization.authorization_code_id)
2020-08-26 14:27:08 +00:00
def test_authorization_list_pagination(testclient, logged_admin, client):
res = testclient.get("/admin/authorization")
res.mustcontain("0 items")
authorizations = []
for _ in range(26):
code = AuthorizationCode(
authorization_code_id=gen_salt(48), client=client, subject=client
)
code.save()
authorizations.append(code)
res = testclient.get("/admin/authorization")
res.mustcontain("26 items")
authorization_code_id = res.pyquery(
".codes tbody tr:nth-of-type(1) td:nth-of-type(1) a"
).text()
assert authorization_code_id
2023-03-09 19:46:04 +00:00
form = res.forms["next"]
form["page"] = 2
res = form.submit()
assert authorization_code_id not in res.pyquery(
".codes tbody tr td:nth-of-type(1) a"
).text().split(" ")
for authorization in authorizations:
authorization.delete()
res = testclient.get("/admin/authorization")
res.mustcontain("0 items")
def test_authorization_list_bad_pages(testclient, logged_admin):
res = testclient.get("/admin/authorization")
2023-03-09 19:46:04 +00:00
form = res.forms["next"]
testclient.post(
"/admin/authorization",
2023-03-28 18:30:29 +00:00
{"csrf_token": form["csrf_token"].value, "page": "2"},
status=404,
)
res = testclient.get("/admin/authorization")
2023-03-09 19:46:04 +00:00
form = res.forms["next"]
testclient.post(
"/admin/authorization",
2023-03-28 18:30:29 +00:00
{"csrf_token": form["csrf_token"].value, "page": "-1"},
status=404,
)
2023-03-07 17:29:18 +00:00
def test_authorization_list_search(testclient, logged_admin, client):
id1 = gen_salt(48)
auth1 = AuthorizationCode(authorization_code_id=id1, client=client, subject=client)
auth1.save()
id2 = gen_salt(48)
auth2 = AuthorizationCode(authorization_code_id=id2, client=client, subject=client)
auth2.save()
res = testclient.get("/admin/authorization")
res.mustcontain("2 items")
res.mustcontain(id1)
res.mustcontain(id2)
2023-03-07 17:29:18 +00:00
form = res.forms["search"]
form["query"] = id1
res = form.submit()
res.mustcontain("1 items")
res.mustcontain(id1)
res.mustcontain(no=id2)
2023-03-07 17:29:18 +00:00
2020-08-26 14:27:08 +00:00
def test_authorizaton_view(testclient, authorization, logged_admin):
res = testclient.get("/admin/authorization/" + authorization.authorization_code_id)
for attr in authorization.may() + authorization.must():
res.mustcontain(attr)