mirror of https://github.com/JohnHammond/CTFd.git
Starting to write tests
test_index test_register_user test_user_isnt_adminselenium-screenshot-testing
parent
0e5c7aa972
commit
28d8a02ec6
|
@ -0,0 +1,5 @@
|
||||||
|
-r requirements.txt
|
||||||
|
coverage>=4.1
|
||||||
|
mock>=2.0.0
|
||||||
|
nose>=1.3.7
|
||||||
|
rednose>=1.1.1
|
|
@ -0,0 +1,5 @@
|
||||||
|
[nosetests]
|
||||||
|
stop=1
|
||||||
|
verbosity=2
|
||||||
|
with-coverage=1
|
||||||
|
cover-package=CTFd
|
|
@ -0,0 +1,61 @@
|
||||||
|
from CTFd import create_app
|
||||||
|
from sqlalchemy_utils import database_exists, create_database, drop_database
|
||||||
|
from sqlalchemy.engine.url import make_url
|
||||||
|
|
||||||
|
def create_ctfd(ctf_name="CTFd", name="admin", email="admin@ctfd.io", password="password"):
|
||||||
|
app = create_app()
|
||||||
|
app.config['PRESERVE_CONTEXT_ON_EXCEPTION'] = False
|
||||||
|
app.config['TESTING'] = True
|
||||||
|
app.config['DEBUG'] = True
|
||||||
|
|
||||||
|
url = make_url(app.config['SQLALCHEMY_DATABASE_URI'])
|
||||||
|
if url.drivername == 'postgres':
|
||||||
|
url.drivername = 'postgresql'
|
||||||
|
|
||||||
|
if database_exists(url):
|
||||||
|
drop_database(url)
|
||||||
|
create_database(url)
|
||||||
|
app.db.create_all()
|
||||||
|
|
||||||
|
with app.app_context():
|
||||||
|
with app.test_client() as client:
|
||||||
|
data = {}
|
||||||
|
r = client.get('/setup') # Populate session with nonce
|
||||||
|
with client.session_transaction() as sess:
|
||||||
|
data = {
|
||||||
|
"ctf_name": ctf_name,
|
||||||
|
"name": name,
|
||||||
|
"email": email,
|
||||||
|
"password": password,
|
||||||
|
"nonce": sess.get('nonce')
|
||||||
|
}
|
||||||
|
client.post('/setup', data=data)
|
||||||
|
return app
|
||||||
|
|
||||||
|
|
||||||
|
def register_user(app, name="user", email="user@ctfd.io", password="password"):
|
||||||
|
with app.app_context():
|
||||||
|
with app.test_client() as client:
|
||||||
|
r = client.get('/register')
|
||||||
|
with client.session_transaction() as sess:
|
||||||
|
data = {
|
||||||
|
"name": name,
|
||||||
|
"email": email,
|
||||||
|
"password": password,
|
||||||
|
"nonce": sess.get('nonce')
|
||||||
|
}
|
||||||
|
client.post('/register', data=data)
|
||||||
|
|
||||||
|
|
||||||
|
def login_as_user(app, name="user", password="password"):
|
||||||
|
with app.app_context():
|
||||||
|
with app.test_client() as client:
|
||||||
|
r = client.get('/login')
|
||||||
|
with client.session_transaction() as sess:
|
||||||
|
data = {
|
||||||
|
"name": name,
|
||||||
|
"password": password,
|
||||||
|
"nonce": sess.get('nonce')
|
||||||
|
}
|
||||||
|
client.post('/login', data=data)
|
||||||
|
return client
|
|
@ -0,0 +1,28 @@
|
||||||
|
from helpers import create_ctfd, register_user, login_as_user
|
||||||
|
from CTFd.models import Teams
|
||||||
|
|
||||||
|
|
||||||
|
def test_index():
|
||||||
|
app = create_ctfd()
|
||||||
|
with app.app_context():
|
||||||
|
with app.test_client() as client:
|
||||||
|
r = client.get('/')
|
||||||
|
assert r.status_code == 200
|
||||||
|
|
||||||
|
|
||||||
|
def test_register_user():
|
||||||
|
app = create_ctfd()
|
||||||
|
with app.app_context():
|
||||||
|
register_user(app)
|
||||||
|
team_count = app.db.session.query(app.db.func.count(Teams.id)).first()[0]
|
||||||
|
assert team_count == 2 # There's the admin user and the created user
|
||||||
|
|
||||||
|
|
||||||
|
def test_user_isnt_admin():
|
||||||
|
app = create_ctfd()
|
||||||
|
with app.app_context():
|
||||||
|
register_user(app)
|
||||||
|
client = login_as_user(app)
|
||||||
|
r = client.get('/admin/graphs')
|
||||||
|
assert r.location == "http://localhost/login"
|
||||||
|
assert r.status_code == 302
|
Loading…
Reference in New Issue