init CTFd source
This commit is contained in:
0
tests/oauth/__init__.py
Normal file
0
tests/oauth/__init__.py
Normal file
113
tests/oauth/test_redirect.py
Normal file
113
tests/oauth/test_redirect.py
Normal file
@@ -0,0 +1,113 @@
|
||||
#!/usr/bin/env python
|
||||
# -*- coding: utf-8 -*-
|
||||
|
||||
from CTFd.models import Teams, Users
|
||||
from CTFd.utils import set_config
|
||||
from tests.helpers import (
|
||||
create_ctfd,
|
||||
destroy_ctfd,
|
||||
login_as_user,
|
||||
login_with_mlc,
|
||||
register_user,
|
||||
)
|
||||
|
||||
|
||||
def test_oauth_not_configured():
|
||||
"""Test that OAuth redirection fails if OAuth settings aren't configured"""
|
||||
app = create_ctfd()
|
||||
with app.app_context():
|
||||
with app.test_client() as client:
|
||||
r = client.get("/oauth", follow_redirects=False)
|
||||
assert r.location == "/login"
|
||||
r = client.get(r.location)
|
||||
resp = r.get_data(as_text=True)
|
||||
assert "OAuth Settings not configured" in resp
|
||||
destroy_ctfd(app)
|
||||
|
||||
|
||||
def test_oauth_configured_flow():
|
||||
"""Test that MLC integration works properly but does not allow registration (account creation) if disabled"""
|
||||
app = create_ctfd(user_mode="teams")
|
||||
app.config.update(
|
||||
{
|
||||
"OAUTH_CLIENT_ID": "ctfd_testing_client_id",
|
||||
"OAUTH_CLIENT_SECRET": "ctfd_testing_client_secret",
|
||||
"OAUTH_AUTHORIZATION_ENDPOINT": "http://auth.localhost/oauth/authorize",
|
||||
"OAUTH_TOKEN_ENDPOINT": "http://auth.localhost/oauth/token",
|
||||
"OAUTH_API_ENDPOINT": "http://api.localhost/user",
|
||||
}
|
||||
)
|
||||
with app.app_context():
|
||||
set_config("registration_visibility", "private")
|
||||
assert Users.query.count() == 1
|
||||
assert Teams.query.count() == 0
|
||||
|
||||
client = login_with_mlc(app, raise_for_error=False)
|
||||
|
||||
assert Users.query.count() == 1
|
||||
|
||||
# Users shouldn't be able to register because registration is disabled
|
||||
resp = client.get("http://localhost/login").get_data(as_text=True)
|
||||
assert "Public registration is disabled" in resp
|
||||
|
||||
set_config("registration_visibility", "public")
|
||||
client = login_with_mlc(app)
|
||||
|
||||
# Users should be able to register now
|
||||
assert Users.query.count() == 2
|
||||
user = Users.query.filter_by(email="user@examplectf.com").first()
|
||||
assert user.oauth_id == 1337
|
||||
assert user.team_id == 1
|
||||
|
||||
# Teams should be created
|
||||
assert Teams.query.count() == 1
|
||||
team = Teams.query.filter_by(id=1).first()
|
||||
assert team.oauth_id == 1234
|
||||
|
||||
client.get("/logout")
|
||||
|
||||
# Users should still be able to login if registration is disabled
|
||||
set_config("registration_visibility", "private")
|
||||
client = login_with_mlc(app)
|
||||
with client.session_transaction() as sess:
|
||||
assert sess["id"]
|
||||
assert sess["nonce"]
|
||||
assert sess["hash"]
|
||||
destroy_ctfd(app)
|
||||
|
||||
|
||||
def test_oauth_login_upgrade():
|
||||
"""Test that users who use MLC after having registered will be associated with their MLC account"""
|
||||
app = create_ctfd(user_mode="teams")
|
||||
app.config.update(
|
||||
{
|
||||
"OAUTH_CLIENT_ID": "ctfd_testing_client_id",
|
||||
"OAUTH_CLIENT_SECRET": "ctfd_testing_client_secret",
|
||||
"OAUTH_AUTHORIZATION_ENDPOINT": "http://auth.localhost/oauth/authorize",
|
||||
"OAUTH_TOKEN_ENDPOINT": "http://auth.localhost/oauth/token",
|
||||
"OAUTH_API_ENDPOINT": "http://api.localhost/user",
|
||||
}
|
||||
)
|
||||
with app.app_context():
|
||||
register_user(app)
|
||||
assert Users.query.count() == 2
|
||||
set_config("registration_visibility", "private")
|
||||
|
||||
# Users should still be able to login
|
||||
client = login_as_user(app)
|
||||
client.get("/logout")
|
||||
|
||||
user = Users.query.filter_by(id=2).first()
|
||||
assert user.oauth_id is None
|
||||
assert user.team_id is None
|
||||
|
||||
login_with_mlc(app)
|
||||
|
||||
assert Users.query.count() == 2
|
||||
|
||||
# Logging in with MLC should insert an OAuth ID and team ID
|
||||
user = Users.query.filter_by(id=2).first()
|
||||
assert user.oauth_id
|
||||
assert user.verified
|
||||
assert user.team_id
|
||||
destroy_ctfd(app)
|
||||
71
tests/oauth/test_teams.py
Normal file
71
tests/oauth/test_teams.py
Normal file
@@ -0,0 +1,71 @@
|
||||
#!/usr/bin/env python
|
||||
# -*- coding: utf-8 -*-
|
||||
from CTFd.models import Teams
|
||||
from CTFd.utils import set_config
|
||||
from tests.helpers import create_ctfd, destroy_ctfd, gen_team, login_with_mlc
|
||||
|
||||
|
||||
def test_team_size_limit():
|
||||
"""Only team_size amount of members can join a team even via MLC"""
|
||||
app = create_ctfd(user_mode="teams")
|
||||
app.config.update(
|
||||
{
|
||||
"OAUTH_CLIENT_ID": "ctfd_testing_client_id",
|
||||
"OAUTH_CLIENT_SECRET": "ctfd_testing_client_secret",
|
||||
"OAUTH_AUTHORIZATION_ENDPOINT": "http://auth.localhost/oauth/authorize",
|
||||
"OAUTH_TOKEN_ENDPOINT": "http://auth.localhost/oauth/token",
|
||||
"OAUTH_API_ENDPOINT": "http://api.localhost/user",
|
||||
}
|
||||
)
|
||||
with app.app_context():
|
||||
set_config("team_size", 1)
|
||||
team = gen_team(app.db, member_count=1, oauth_id=1234)
|
||||
team_id = team.id
|
||||
login_with_mlc(
|
||||
app, team_name="team_name", team_oauth_id=1234, raise_for_error=False
|
||||
)
|
||||
assert len(Teams.query.filter_by(id=team_id).first().members) == 1
|
||||
|
||||
set_config("team_size", 2)
|
||||
login_with_mlc(app, team_name="team_name", team_oauth_id=1234)
|
||||
assert len(Teams.query.filter_by(id=team_id).first().members) == 2
|
||||
destroy_ctfd(app)
|
||||
|
||||
|
||||
def test_num_teams_limit():
|
||||
"""Only num_teams teams can be created even via MLC"""
|
||||
app = create_ctfd(user_mode="teams")
|
||||
app.config.update(
|
||||
{
|
||||
"OAUTH_CLIENT_ID": "ctfd_testing_client_id",
|
||||
"OAUTH_CLIENT_SECRET": "ctfd_testing_client_secret",
|
||||
"OAUTH_AUTHORIZATION_ENDPOINT": "http://auth.localhost/oauth/authorize",
|
||||
"OAUTH_TOKEN_ENDPOINT": "http://auth.localhost/oauth/token",
|
||||
"OAUTH_API_ENDPOINT": "http://api.localhost/user",
|
||||
}
|
||||
)
|
||||
with app.app_context():
|
||||
set_config("num_teams", 1)
|
||||
gen_team(app.db, member_count=1, oauth_id=1234)
|
||||
login_with_mlc(
|
||||
app,
|
||||
name="foobar",
|
||||
email="foobar@a.com",
|
||||
oauth_id=111,
|
||||
team_name="foobar",
|
||||
team_oauth_id=1111,
|
||||
raise_for_error=False,
|
||||
)
|
||||
assert Teams.query.count() == 1
|
||||
|
||||
set_config("num_teams", 2)
|
||||
login_with_mlc(
|
||||
app,
|
||||
name="foobarbaz",
|
||||
email="foobarbaz@a.com",
|
||||
oauth_id=222,
|
||||
team_name="foobarbaz",
|
||||
team_oauth_id=2222,
|
||||
)
|
||||
assert Teams.query.count() == 2
|
||||
destroy_ctfd(app)
|
||||
48
tests/oauth/test_users.py
Normal file
48
tests/oauth/test_users.py
Normal file
@@ -0,0 +1,48 @@
|
||||
#!/usr/bin/env python
|
||||
# -*- coding: utf-8 -*-
|
||||
from CTFd.models import Users
|
||||
from CTFd.utils import set_config
|
||||
from tests.helpers import create_ctfd, destroy_ctfd, login_with_mlc, register_user
|
||||
|
||||
|
||||
def test_num_users_oauth_limit():
|
||||
"""Only num_users users can be created even via MLC"""
|
||||
app = create_ctfd()
|
||||
app.config.update(
|
||||
{
|
||||
"OAUTH_CLIENT_ID": "ctfd_testing_client_id",
|
||||
"OAUTH_CLIENT_SECRET": "ctfd_testing_client_secret",
|
||||
"OAUTH_AUTHORIZATION_ENDPOINT": "http://auth.localhost/oauth/authorize",
|
||||
"OAUTH_TOKEN_ENDPOINT": "http://auth.localhost/oauth/token",
|
||||
"OAUTH_API_ENDPOINT": "http://api.localhost/user",
|
||||
}
|
||||
)
|
||||
with app.app_context():
|
||||
register_user(app)
|
||||
# There should be the admin and our registered user
|
||||
assert Users.query.count() == 2
|
||||
set_config("num_users", 1)
|
||||
|
||||
# This registration should fail and we should still have 2 users
|
||||
login_with_mlc(
|
||||
app,
|
||||
name="foobarbaz",
|
||||
email="foobarbaz@a.com",
|
||||
oauth_id=111,
|
||||
scope="profile",
|
||||
raise_for_error=False,
|
||||
)
|
||||
assert Users.query.count() == 2
|
||||
|
||||
# We increment num_users to 2 and then login again
|
||||
set_config("num_users", 2)
|
||||
login_with_mlc(
|
||||
app,
|
||||
name="foobarbaz",
|
||||
email="foobarbaz@a.com",
|
||||
oauth_id=111,
|
||||
scope="profile",
|
||||
)
|
||||
# The above login should have succeeded
|
||||
assert Users.query.count() == 3
|
||||
destroy_ctfd(app)
|
||||
Reference in New Issue
Block a user