1
0
Fork 0
canaille-globuzma/tests/oidc/test_token_admin.py
Éloi Rivard b4908d5e57
modals are HTML pages instead of JS elements
This will help providing the very same user experience for users with
and without javascript. We will still be able to re-enable javascript
modals in the future, but this should be done from the ground up, HTML
first and javascript after.
2023-07-18 18:34:10 +02:00

150 lines
4.1 KiB
Python

import datetime
from canaille.app import models
from werkzeug.security import gen_salt
def test_no_logged_no_access(testclient):
testclient.get("/admin/token", status=403)
def test_no_admin_no_access(testclient, logged_user):
testclient.get("/admin/token", status=403)
def test_token_list(testclient, token, logged_admin):
res = testclient.get("/admin/token")
res.mustcontain(token.token_id)
def test_token_list_pagination(testclient, logged_admin, client):
res = testclient.get("/admin/token")
res.mustcontain("0 items")
tokens = []
for _ in range(26):
token = models.Token(
token_id=gen_salt(48),
access_token="my-valid-token",
client=client,
subject=logged_admin,
type=None,
refresh_token=gen_salt(48),
scope="openid profile",
issue_date=(
datetime.datetime.now(datetime.timezone.utc).replace(microsecond=0)
),
lifetime=3600,
)
token.save()
tokens.append(token)
res = testclient.get("/admin/token")
res.mustcontain("26 items")
token_id = res.pyquery(".tokens tbody tr td:nth-of-type(1) a").text()
assert token_id
form = res.forms["next"]
form["page"] = 2
res = form.submit()
assert token_id not in res.pyquery(
".tokens tbody tr:nth-of-type(1) td:nth-of-type(1) a"
).text().split(" ")
for token in tokens:
token.delete()
res = testclient.get("/admin/token")
res.mustcontain("0 items")
def test_token_list_bad_pages(testclient, logged_admin):
res = testclient.get("/admin/token")
form = res.forms["next"]
testclient.post(
"/admin/token",
{"csrf_token": form["csrf_token"].value, "page": "2"},
status=404,
)
res = testclient.get("/admin/token")
form = res.forms["next"]
testclient.post(
"/admin/token",
{"csrf_token": form["csrf_token"].value, "page": "-1"},
status=404,
)
def test_token_list_search(testclient, logged_admin, client):
token1 = models.Token(
token_id=gen_salt(48),
access_token="this-token-is-ok",
client=client,
subject=logged_admin,
type=None,
refresh_token=gen_salt(48),
scope="openid profile",
issue_date=(
datetime.datetime.now(datetime.timezone.utc).replace(microsecond=0)
),
lifetime=3600,
)
token1.save()
token2 = models.Token(
token_id=gen_salt(48),
access_token="this-token-is-valid",
client=client,
subject=logged_admin,
type=None,
refresh_token=gen_salt(48),
scope="openid profile",
issue_date=(
datetime.datetime.now(datetime.timezone.utc).replace(microsecond=0)
),
lifetime=3600,
)
token2.save()
res = testclient.get("/admin/token")
res.mustcontain("2 items")
res.mustcontain(token1.token_id)
res.mustcontain(token2.token_id)
form = res.forms["search"]
form["query"] = "valid"
res = form.submit()
res.mustcontain("1 item")
res.mustcontain(token2.token_id)
res.mustcontain(no=token1.token_id)
def test_token_view(testclient, token, logged_admin):
res = testclient.get("/admin/token/" + token.token_id)
res.mustcontain(token.access_token)
def test_token_not_found(testclient, logged_admin):
testclient.get("/admin/token/" + "yolo", status=404)
def test_revoke_bad_request(testclient, token, logged_admin):
assert not token.revoked
res = testclient.get(f"/admin/token/{token.token_id}")
res = res.form.submit(name="action", value="invalid", status=400)
def test_revoke_token(testclient, token, logged_admin):
assert not token.revoked
res = testclient.get(f"/admin/token/{token.token_id}")
res = res.form.submit(name="action", value="confirm-revoke")
res = res.form.submit(name="action", value="revoke")
assert ("success", "The token has successfully been revoked.") in res.flashes
token.reload()
assert token.revoked
def test_revoke_invalid_token(testclient, logged_admin):
testclient.get("/admin/token/invalid/revoke", status=404)