mirror of
https://github.com/aljazceru/CTFd.git
synced 2025-12-17 22:14:25 +01:00
156 lines
5.7 KiB
Python
156 lines
5.7 KiB
Python
#!/usr/bin/env python
|
|
# -*- coding: utf-8 -*-
|
|
|
|
from flask_caching import make_template_fragment_key
|
|
|
|
from CTFd.cache import clear_standings
|
|
from CTFd.models import Users
|
|
from tests.helpers import (
|
|
create_ctfd,
|
|
destroy_ctfd,
|
|
gen_award,
|
|
gen_challenge,
|
|
gen_flag,
|
|
gen_solve,
|
|
gen_team,
|
|
login_as_user,
|
|
register_user,
|
|
)
|
|
|
|
|
|
def test_scoreboard_is_cached():
|
|
"""Test that /api/v1/scoreboard is properly cached and cleared"""
|
|
app = create_ctfd()
|
|
with app.app_context():
|
|
# create user1
|
|
register_user(app, name="user1", email="user1@examplectf.com")
|
|
|
|
# create challenge
|
|
chal = gen_challenge(app.db, value=100)
|
|
gen_flag(app.db, challenge_id=chal.id, content="flag")
|
|
chal_id = chal.id
|
|
|
|
# create a solve for the challenge for user1. (the id is 2 because of the admin)
|
|
gen_solve(app.db, user_id=2, challenge_id=chal_id)
|
|
|
|
with login_as_user(app, "user1") as client:
|
|
# No cached data
|
|
assert app.cache.get("view/api.scoreboard_scoreboard_list") is None
|
|
assert app.cache.get("view/api.scoreboard_scoreboard_detail") is None
|
|
|
|
# Load and check cached data
|
|
client.get("/api/v1/scoreboard")
|
|
assert app.cache.get("view/api.scoreboard_scoreboard_list")
|
|
client.get("/api/v1/scoreboard/top/10")
|
|
assert app.cache.get("view/api.scoreboard_scoreboard_detail")
|
|
|
|
# Check scoreboard page
|
|
assert (
|
|
app.cache.get(make_template_fragment_key("public_scoreboard_table"))
|
|
is None
|
|
)
|
|
client.get("/scoreboard")
|
|
assert app.cache.get(make_template_fragment_key("public_scoreboard_table"))
|
|
|
|
# Empty standings and check that the cached data is gone
|
|
clear_standings()
|
|
assert app.cache.get("view/api.scoreboard_scoreboard_list") is None
|
|
assert app.cache.get("view/api.scoreboard_scoreboard_detail") is None
|
|
assert (
|
|
app.cache.get(make_template_fragment_key("public_scoreboard_table"))
|
|
is None
|
|
)
|
|
destroy_ctfd(app)
|
|
|
|
|
|
def test_scoreboard_tie_break_ordering_with_awards():
|
|
"""
|
|
Test that scoreboard tie break ordering respects the addition of awards
|
|
"""
|
|
app = create_ctfd()
|
|
with app.app_context():
|
|
# create user1
|
|
register_user(app, name="user1", email="user1@examplectf.com")
|
|
# create user2
|
|
register_user(app, name="user2", email="user2@examplectf.com")
|
|
|
|
chal = gen_challenge(app.db, value=100)
|
|
gen_flag(app.db, challenge_id=chal.id, content="flag")
|
|
|
|
chal = gen_challenge(app.db, value=200)
|
|
gen_flag(app.db, challenge_id=chal.id, content="flag")
|
|
|
|
# create solves for the challenges. (the user_ids are off by 1 because of the admin)
|
|
gen_solve(app.db, user_id=2, challenge_id=1)
|
|
gen_solve(app.db, user_id=3, challenge_id=2)
|
|
|
|
with login_as_user(app, "user1") as client:
|
|
r = client.get("/api/v1/scoreboard")
|
|
resp = r.get_json()
|
|
assert len(resp["data"]) == 2
|
|
assert resp["data"][0]["name"] == "user2"
|
|
assert resp["data"][0]["score"] == 200
|
|
assert resp["data"][1]["name"] == "user1"
|
|
assert resp["data"][1]["score"] == 100
|
|
|
|
# Give user1 an award for 100 points.
|
|
# At this point user2 should still be ahead
|
|
gen_award(app.db, user_id=2, value=100)
|
|
|
|
with login_as_user(app, "user1") as client:
|
|
r = client.get("/api/v1/scoreboard")
|
|
resp = r.get_json()
|
|
assert len(resp["data"]) == 2
|
|
assert resp["data"][0]["name"] == "user2"
|
|
assert resp["data"][0]["score"] == 200
|
|
assert resp["data"][1]["name"] == "user1"
|
|
assert resp["data"][1]["score"] == 200
|
|
destroy_ctfd(app)
|
|
|
|
|
|
def test_scoreboard_tie_break_ordering_with_awards_under_teams():
|
|
"""
|
|
Test that team mode scoreboard tie break ordering respects the addition of awards
|
|
"""
|
|
app = create_ctfd(user_mode="teams")
|
|
with app.app_context():
|
|
gen_team(app.db, name="team1", email="team1@examplectf.com")
|
|
gen_team(app.db, name="team2", email="team2@examplectf.com")
|
|
|
|
chal = gen_challenge(app.db, value=100)
|
|
gen_flag(app.db, challenge_id=chal.id, content="flag")
|
|
|
|
chal = gen_challenge(app.db, value=200)
|
|
gen_flag(app.db, challenge_id=chal.id, content="flag")
|
|
|
|
# create solves for the challenges. (the user_ids are off by 1 because of the admin)
|
|
gen_solve(app.db, user_id=2, team_id=1, challenge_id=1)
|
|
gen_solve(app.db, user_id=6, team_id=2, challenge_id=2)
|
|
|
|
user = Users.query.filter_by(id=2).first()
|
|
|
|
with login_as_user(app, user.name) as client:
|
|
r = client.get("/api/v1/scoreboard")
|
|
resp = r.get_json()
|
|
print(resp)
|
|
assert len(resp["data"]) == 2
|
|
assert resp["data"][0]["name"] == "team2"
|
|
assert resp["data"][0]["score"] == 200
|
|
assert resp["data"][1]["name"] == "team1"
|
|
assert resp["data"][1]["score"] == 100
|
|
|
|
# Give a user on the team an award for 100 points.
|
|
# At this point team2 should still be ahead
|
|
gen_award(app.db, user_id=3, team_id=1, value=100)
|
|
|
|
with login_as_user(app, user.name) as client:
|
|
r = client.get("/api/v1/scoreboard")
|
|
resp = r.get_json()
|
|
print(resp)
|
|
assert len(resp["data"]) == 2
|
|
assert resp["data"][0]["name"] == "team2"
|
|
assert resp["data"][0]["score"] == 200
|
|
assert resp["data"][1]["name"] == "team1"
|
|
assert resp["data"][1]["score"] == 200
|
|
destroy_ctfd(app)
|