2023-04-26 19:51:09 -04:00
|
|
|
import pytest
|
|
|
|
from math import ceil
|
|
|
|
import json
|
|
|
|
|
|
|
|
"""Test ability to paginate endpoint responses."""
|
|
|
|
|
|
|
|
|
|
|
|
def test_files(client, users, auth):
|
|
|
|
"""Test /files endpoint."""
|
|
|
|
|
|
|
|
# create multiple shares
|
|
|
|
shares = set()
|
|
|
|
share_count = 20
|
|
|
|
|
|
|
|
for i in range(share_count):
|
|
|
|
resp = client.post(
|
|
|
|
"/files", headers=auth("jeff"), json={"file_name": "content.bin"}
|
|
|
|
)
|
|
|
|
assert resp.status_code == 201
|
|
|
|
data = resp.get_json()
|
|
|
|
share_id = data.get("url").split("/")[-1]
|
|
|
|
shares.add(share_id)
|
|
|
|
|
|
|
|
# we'll paginate through all shares and ensure that:
|
|
|
|
# - we see all the shares
|
|
|
|
# - no shares are seen twice
|
|
|
|
|
|
|
|
def paginate(forwards=True, page=1):
|
|
|
|
"""Goes through the pages.
|
|
|
|
|
|
|
|
Parameters
|
|
|
|
----------
|
|
|
|
forwards : bool, optional
|
|
|
|
Set direction to paginate in.
|
|
|
|
page : int
|
|
|
|
Page to start at.
|
|
|
|
|
|
|
|
Returns
|
|
|
|
-------
|
|
|
|
int
|
|
|
|
Page we ended at.
|
|
|
|
"""
|
|
|
|
seen = set()
|
|
|
|
|
|
|
|
per_page = 9
|
|
|
|
while page is not None:
|
|
|
|
resp = client.get(
|
2023-06-09 13:27:05 -04:00
|
|
|
"/files",
|
|
|
|
headers=auth("jeff"),
|
|
|
|
query_string=dict(page=page, per_page=per_page),
|
2023-04-26 19:51:09 -04:00
|
|
|
)
|
|
|
|
assert resp.status_code == 200
|
|
|
|
|
|
|
|
data = resp.get_json().get("data")
|
|
|
|
assert len(data) == per_page or len(data) == share_count % per_page
|
|
|
|
|
2023-06-09 19:45:28 -04:00
|
|
|
assert resp.get_json().get("pages") == ceil(share_count / per_page)
|
|
|
|
|
2023-04-26 19:51:09 -04:00
|
|
|
for share in data:
|
|
|
|
share_id = share.get("share_id")
|
|
|
|
assert share_id in shares
|
|
|
|
assert share_id not in seen
|
|
|
|
seen.add(share_id)
|
|
|
|
|
|
|
|
if forwards:
|
|
|
|
new_page = resp.get_json().get("next")
|
|
|
|
assert new_page == page + 1 or new_page is None
|
|
|
|
else:
|
|
|
|
new_page = resp.get_json().get("prev")
|
|
|
|
assert new_page == page - 1 or new_page is None
|
|
|
|
if new_page is not None:
|
|
|
|
page = new_page
|
|
|
|
else:
|
|
|
|
break
|
|
|
|
|
|
|
|
assert seen == shares
|
|
|
|
|
|
|
|
return page
|
|
|
|
|
|
|
|
end_page = paginate(forwards=True)
|
|
|
|
paginate(forwards=False, page=end_page)
|
2023-04-27 21:16:10 -04:00
|
|
|
|
|
|
|
|
2023-05-18 22:06:16 -04:00
|
|
|
def test_users(client, users, auth):
|
|
|
|
"""Test /users endpoint."""
|
|
|
|
|
|
|
|
# suck it for me violating DRY this is a test
|
|
|
|
|
|
|
|
# create multiple users
|
|
|
|
total_users = set()
|
|
|
|
# this is the amount of shares we'll create
|
|
|
|
user_count = 20
|
|
|
|
|
|
|
|
for i in range(user_count):
|
|
|
|
resp = client.post(
|
|
|
|
"/users",
|
|
|
|
headers=auth("administrator"),
|
|
|
|
json={"username": f"user{i}", "permissions": [], "password": "123"},
|
|
|
|
)
|
|
|
|
assert resp.status_code == 201
|
|
|
|
data = resp.get_json()
|
|
|
|
total_users.add(f"user{i}")
|
|
|
|
|
|
|
|
# add on the existing amount of users
|
|
|
|
user_count += len(users)
|
|
|
|
for user in users.keys():
|
|
|
|
total_users.add(user)
|
|
|
|
|
|
|
|
# we'll paginate through all users and ensure that:
|
|
|
|
# - we see all the users
|
|
|
|
# - no users are seen twice
|
|
|
|
|
|
|
|
def paginate(forwards=True, page=1):
|
|
|
|
"""Goes through the pages.
|
|
|
|
|
|
|
|
Parameters
|
|
|
|
----------
|
|
|
|
forwards : bool, optional
|
|
|
|
Set direction to paginate in.
|
|
|
|
page : int
|
|
|
|
Page to start at.
|
|
|
|
|
|
|
|
Returns
|
|
|
|
-------
|
|
|
|
int
|
|
|
|
Page we ended at.
|
|
|
|
"""
|
|
|
|
seen = set()
|
|
|
|
|
|
|
|
per_page = 9
|
|
|
|
while page is not None:
|
|
|
|
resp = client.get(
|
|
|
|
"/users",
|
|
|
|
headers=auth("administrator"),
|
2023-06-09 13:27:05 -04:00
|
|
|
query_string=dict(page=page, per_page=per_page),
|
2023-05-18 22:06:16 -04:00
|
|
|
)
|
|
|
|
assert resp.status_code == 200
|
|
|
|
|
|
|
|
data = resp.get_json().get("data")
|
|
|
|
assert len(data) == per_page or len(data) == user_count % per_page
|
|
|
|
|
2023-06-09 19:45:28 -04:00
|
|
|
assert resp.get_json().get("pages") == ceil(user_count / per_page)
|
|
|
|
|
2023-05-18 22:06:16 -04:00
|
|
|
for user in data:
|
|
|
|
username = user.get("username")
|
|
|
|
assert username in total_users
|
|
|
|
assert username not in seen
|
|
|
|
seen.add(username)
|
|
|
|
|
|
|
|
if forwards:
|
|
|
|
new_page = resp.get_json().get("next")
|
|
|
|
assert new_page == page + 1 or new_page is None
|
|
|
|
else:
|
|
|
|
new_page = resp.get_json().get("prev")
|
|
|
|
assert new_page == page - 1 or new_page is None
|
|
|
|
if new_page is not None:
|
|
|
|
page = new_page
|
|
|
|
else:
|
|
|
|
break
|
|
|
|
|
|
|
|
assert seen == total_users
|
|
|
|
|
|
|
|
return page
|
|
|
|
|
|
|
|
end_page = paginate(forwards=True)
|
|
|
|
paginate(forwards=False, page=end_page)
|
|
|
|
|
|
|
|
|
2023-04-27 21:16:10 -04:00
|
|
|
def test_invalid(client, auth):
|
|
|
|
"""Test invalid requests to pagination."""
|
|
|
|
|
|
|
|
resp = client.get(
|
2023-06-09 13:27:05 -04:00
|
|
|
"/files", headers=auth("jeff"), query_string=dict(page="one", per_page="two")
|
2023-04-27 21:16:10 -04:00
|
|
|
)
|
|
|
|
assert resp.status_code == 400
|