-
Notifications
You must be signed in to change notification settings - Fork 0
/
test_user_model.py
142 lines (95 loc) · 3.85 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
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
"""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, Message, Follows, connect_db
from psycopg2.errors import UniqueViolation
from sqlalchemy.exc import IntegrityError as SQLIntegrityError
# 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):
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.u1 = u1
self.u2 = u2
self.client = app.test_client()
def tearDown(self):
db.session.rollback()
def test_user_model(self):
""" Test fresh user with no messages and followers """
u1 = User.query.get(self.u1_id)
self.assertEqual(len(u1.messages), 0)
self.assertEqual(len(u1.followers), 0)
def test_is_not_following(self):
""" Test u1 not following u2"""
self.assertEqual(self.u1.is_following(self.u2), False)
def test_is_following(self):
""" Test u1 following u2 """
self.u1.following.append(self.u2)
self.assertEqual(self.u1.is_following(self.u2), True)
def test_is_followed_by(self):
""" Test u2 following u1"""
self.u1.followers.append(self.u2)
self.assertEqual(self.u1.is_followed_by(self.u2), True)
def test_is_not_followed_by(self):
""" Test u2 not following u1"""
self.assertEqual(self.u1.is_followed_by(self.u2), False)
def test_user_signed_up(self):
""" Test user signed up successfully """
self.assertIsInstance(self.u1, User)
def test_user_empty_password(self):
"""Throw error if empty password."""
with self.assertRaises(ValueError):
User.signup("notCoolUser", "[email protected]", "", None)
db.session.commit()
def test_user_username_duplicates(self):
"""Throw error if duplicate username."""
with self.assertRaises(SQLIntegrityError):
User.signup("notCoolUser", "[email protected]", "asdasd", None)
User.signup("notCoolUser", "[email protected]", "asdasd", None)
db.session.commit()
def test_user_email_duplicates(self):
"""Throw error if duplicate email."""
with self.assertRaises(SQLIntegrityError):
User.signup("notCoolUser", "[email protected]", "asdasd", None)
User.signup("asdasdasda", "[email protected]", "asdasd", None)
db.session.commit()
def test_user_authentication_valid_data(self):
"""Return user if valid credentials."""
u = User.authenticate(
username=self.u1.username,
password="password"
)
self.assertIsInstance(u, User)
def test_user_authentication_invalid_user(self):
"""Fail to return user if username invalid."""
u = User.authenticate(
username="bob",
password="password"
)
self.assertNotIsInstance(u, User)
def test_user_authentication_invalid_password(self):
"""Fail to return user if password invalid."""
u = User.authenticate(
username="u1",
password="asdasdasdasdasdasdasdasdasdasdasds"
)
self.assertNotIsInstance(u, User)