-
Notifications
You must be signed in to change notification settings - Fork 0
/
test_user_model.py
122 lines (80 loc) · 3.4 KB
/
test_user_model.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
"""User model tests."""
# run these tests like:
#
# python -m unittest test_user_model.py
import os
from unittest import TestCase
from models import db, User, connect_db
from sqlalchemy import exc
# BEFORE we import our app, let's set an environmental variable
# to use a different database for tests (we need to do this
# before we import our app, since that will have already
# connected to the database
os.environ['DATABASE_URL'] = "postgresql:///warbler_test"
# Now we can import app
from app import app
# Create our tables (we do this here, so we only create the tables
# once for all tests --- in each test, we'll delete the data
# and create fresh new clean test data
connect_db(app)
db.drop_all()
db.create_all()
class UserModelTestCase(TestCase):
def setUp(self):
"""Set up users and messages"""
User.query.delete()
u1 = User.signup("u1", "[email protected]", "password", None)
u2 = User.signup("u2", "[email protected]", "password", None)
db.session.commit()
self.u1_id = u1.id
self.u2_id = u2.id
self.client = app.test_client()
def tearDown(self):
db.session.rollback()
def test_user_model(self):
"""Tests that user exists"""
u1 = User.query.get(self.u1_id)
# User should have no messages & no followers
self.assertEqual(len(u1.messages), 0)
self.assertEqual(len(u1.followers), 0)
def test_is_following(self):
"""Tests that is_follow method displays follows properly"""
u1 = User.query.get(self.u1_id)
u2 = User.query.get(self.u2_id)
u1.following.append(u2)
db.session.commit()
self.assertTrue(u1.is_following(u2))
self.assertFalse(u2.is_following(u1))
def test_is_followed_by(self):
"""Tests that is_followed_by method displays followed by properly"""
u1 = User.query.get(self.u1_id)
u2 = User.query.get(self.u2_id)
u1.following.append(u2)
db.session.commit()
self.assertTrue(u2.is_followed_by(u1))
self.assertFalse(u1.is_followed_by(u2))
def test_successful_user_signup(self):
"""Tests that user can sign up properly"""
new_user = User.signup("new_user", "[email protected]", "password", None)
db.session.commit()
self.assertEqual(new_user.username, "new_user")
self.assertEqual(new_user.email, "[email protected]")
self.assertNotEqual(new_user.password, "password")
def test_unsuccessful_user_signup(self):
"""Tests that user cannot use existing email or username properly"""
with self.assertRaises(exc.IntegrityError):
User.signup("u1", "[email protected]", "password", None)
db.session.commit()
def test_valid_credentials(self):
"""Tests that valid credentials can log in properly"""
u1 = User.query.get(self.u1_id)
valid_credentials = User.authenticate("u1", "password")
self.assertEqual(valid_credentials, u1)
def test_invalid_username(self):
"""Tests that invalid username cannot log in, properly"""
invalid_credentials = User.authenticate("u3", "password")
self.assertFalse(invalid_credentials)
def test_invalid_password(self):
"""Tests that invalid password cannot log in, properly"""
invalid_credentials = User.authenticate("u1", "wrongpassword")
self.assertFalse(invalid_credentials)