init CTFd source
This commit is contained in:
121
tests/api/v1/test_awards.py
Normal file
121
tests/api/v1/test_awards.py
Normal file
@@ -0,0 +1,121 @@
|
||||
#!/usr/bin/env python
|
||||
# -*- coding: utf-8 -*-
|
||||
|
||||
from CTFd.models import Awards
|
||||
from tests.helpers import (
|
||||
create_ctfd,
|
||||
destroy_ctfd,
|
||||
gen_award,
|
||||
gen_team,
|
||||
login_as_user,
|
||||
register_user,
|
||||
)
|
||||
|
||||
|
||||
def test_api_awards_access_non_admin():
|
||||
"""Can a user post /api/v1/awards if not admin"""
|
||||
app = create_ctfd()
|
||||
with app.app_context():
|
||||
with app.test_client() as client:
|
||||
r = client.post("/api/v1/awards", json="")
|
||||
assert r.status_code == 403
|
||||
|
||||
# test_api_award_get_non_admin
|
||||
"""Can a user get /api/v1/awards/<award_id> if not admin"""
|
||||
r = client.get("/api/v1/awards/1", json="")
|
||||
assert r.status_code == 403
|
||||
|
||||
# test_api_award_delete_non_admin
|
||||
"""Can a user delete /api/v1/awards/<award_id> if not admin"""
|
||||
r = client.delete("/api/v1/awards/1", json="")
|
||||
assert r.status_code == 403
|
||||
|
||||
destroy_ctfd(app)
|
||||
|
||||
|
||||
def test_api_awards_post_admin():
|
||||
"""Can a user post /api/v1/awards if admin"""
|
||||
app = create_ctfd()
|
||||
with app.app_context():
|
||||
register_user(app)
|
||||
with login_as_user(app, "admin") as client:
|
||||
r = client.post(
|
||||
"/api/v1/awards",
|
||||
json={
|
||||
"name": "Name",
|
||||
"value": "100",
|
||||
"category": "Cate",
|
||||
"description": "Desc",
|
||||
"user_id": 2,
|
||||
},
|
||||
)
|
||||
assert r.status_code == 200
|
||||
assert r.get_json()["success"] is True
|
||||
r = client.post("/api/v1/awards", json="")
|
||||
assert r.status_code == 400
|
||||
destroy_ctfd(app)
|
||||
|
||||
|
||||
def test_api_awards_post_admin_teams_mode():
|
||||
"""Can a user post /api/v1/awards if admin in team mode"""
|
||||
app = create_ctfd(user_mode="teams")
|
||||
with app.app_context():
|
||||
register_user(app)
|
||||
with login_as_user(app, "admin") as client:
|
||||
r = client.post(
|
||||
"/api/v1/awards",
|
||||
json={
|
||||
"name": "Name",
|
||||
"value": "100",
|
||||
"category": "Cate",
|
||||
"description": "Desc",
|
||||
"user_id": 2,
|
||||
},
|
||||
)
|
||||
|
||||
# This should fail because the user doesn't have a team
|
||||
assert r.status_code == 400
|
||||
assert "team_id" in r.get_json()["errors"].keys()
|
||||
assert r.get_json()["success"] is False
|
||||
|
||||
gen_team(app.db)
|
||||
r = client.post(
|
||||
"/api/v1/awards",
|
||||
json={
|
||||
"name": "Name",
|
||||
"value": "100",
|
||||
"category": "Cate",
|
||||
"description": "Desc",
|
||||
"user_id": 3,
|
||||
},
|
||||
)
|
||||
|
||||
# This should pass as we should auto determine the user's team
|
||||
assert r.status_code == 200
|
||||
assert r.get_json()["success"] is True
|
||||
award = Awards.query.filter_by(id=1).first()
|
||||
assert award.user_id == 3
|
||||
assert award.team_id == 1
|
||||
destroy_ctfd(app)
|
||||
|
||||
|
||||
def test_api_award_get_admin():
|
||||
"""Can a user get /api/v1/awards/<award_id> if admin"""
|
||||
app = create_ctfd()
|
||||
with app.app_context():
|
||||
gen_award(app.db, 1)
|
||||
with login_as_user(app, "admin") as client:
|
||||
r = client.get("/api/v1/awards/1", json="")
|
||||
assert r.status_code == 200
|
||||
destroy_ctfd(app)
|
||||
|
||||
|
||||
def test_api_award_delete_admin():
|
||||
"""Can a user delete /api/v1/awards/<award_id> if admin"""
|
||||
app = create_ctfd()
|
||||
with app.app_context():
|
||||
gen_award(app.db, 1)
|
||||
with login_as_user(app, "admin") as client:
|
||||
r = client.delete("/api/v1/awards/1", json="")
|
||||
assert r.status_code == 200
|
||||
destroy_ctfd(app)
|
||||
Reference in New Issue
Block a user