aboutsummaryrefslogtreecommitdiff
path: root/tests/integration/test_login.py
diff options
context:
space:
mode:
authorDaniel Schadt <kingdread@gmx.de>2022-07-09 19:30:18 +0200
committerDaniel Schadt <kingdread@gmx.de>2022-07-09 19:30:18 +0200
commit8cdf665c0c8c83abf6bf3ccdc4c594e039e59107 (patch)
treeb60234bc0d10aadc44fa1d743131a5e4869a30b2 /tests/integration/test_login.py
parentcd9d1b1c31cfce7ffb2563fca1bea5907d575eee (diff)
downloadfietsboek-8cdf665c0c8c83abf6bf3ccdc4c594e039e59107.tar.gz
fietsboek-8cdf665c0c8c83abf6bf3ccdc4c594e039e59107.tar.bz2
fietsboek-8cdf665c0c8c83abf6bf3ccdc4c594e039e59107.zip
add tests for the login form
Diffstat (limited to 'tests/integration/test_login.py')
-rw-r--r--tests/integration/test_login.py65
1 files changed, 65 insertions, 0 deletions
diff --git a/tests/integration/test_login.py b/tests/integration/test_login.py
new file mode 100644
index 0000000..8be77d7
--- /dev/null
+++ b/tests/integration/test_login.py
@@ -0,0 +1,65 @@
+import pytest
+
+from fietsboek import models
+
+
+@pytest.fixture()
+def testuser(dbsession):
+ user = models.User(email='foo@bar.com')
+ user.set_password("foobar")
+ dbsession.add(user)
+ return user
+
+
+def test_login_working(testapp, testuser):
+ """Ensures that a verified user can log in with the right password."""
+ testuser.is_verified = True
+
+ login = testapp.get('/login')
+ form = login.form
+ form['email'] = 'foo@bar.com'
+ form['password'] = 'foobar'
+ response = form.submit().maybe_follow()
+
+ assert b'Logout' in response.body
+
+
+def test_login_not_verified(testapp, testuser):
+ """Ensures that a user that has not yet verified their email address can
+ not log in.
+ """
+ login = testapp.get('/login')
+ form = login.form
+ form['email'] = 'foo@bar.com'
+ form['password'] = 'foobar'
+ response = form.submit().maybe_follow()
+
+ assert b'Logout' not in response.body
+ assert b'not verified yet' in response.body
+
+
+def test_login_wrong_email(testapp, testuser):
+ """Ensures that a wrong email address won't let you log in."""
+ login = testapp.get('/login')
+
+ form = login.form
+ form['email'] = 'fooooooooo@bar.com'
+ form['password'] = 'foobar'
+ response = form.submit().maybe_follow()
+
+ assert b'Logout' not in response.body
+ assert b'Invalid login credentials' in response.body
+
+
+def test_login_wrong_password(testapp, testuser):
+ """Ensures that a wrong password won't let you log in."""
+ testuser.is_verified = True
+
+ login = testapp.get('/login')
+ form = login.form
+ form['email'] = 'foo@bar.com'
+ form['password'] = 'raboof'
+ response = form.submit().maybe_follow()
+
+ assert b'Logout' not in response.body
+ assert b'Invalid login credentials' in response.body