Compare commits
1 Commits
a850a526e6
...
00619cbd05
Author | SHA1 | Date | |
---|---|---|---|
00619cbd05 |
@ -24,7 +24,7 @@ def auth(username, password):
|
|||||||
if user is None:
|
if user is None:
|
||||||
user = User(auth_id=username)
|
user = User(auth_id=username)
|
||||||
db.session.add(user)
|
db.session.add(user)
|
||||||
|
|
||||||
token = Token(token=str(uuid.uuid4()), user=user)
|
token = Token(token=str(uuid.uuid4()), user=user)
|
||||||
db.session.add(token)
|
db.session.add(token)
|
||||||
db.session.commit()
|
db.session.commit()
|
||||||
|
@ -13,7 +13,7 @@ class User(db.Model):
|
|||||||
auth_id = Column(String(50), nullable=False, unique=True)
|
auth_id = Column(String(50), nullable=False, unique=True)
|
||||||
profile_id = Column(Integer, ForeignKey("profile.id"), nullable=True)
|
profile_id = Column(Integer, ForeignKey("profile.id"), nullable=True)
|
||||||
|
|
||||||
tokens = relationship("Token", uselist=False, back_populates="user")
|
tokens = relationship("Token", back_populates="user")
|
||||||
profile = relationship("Profile", back_populates="user")
|
profile = relationship("Profile", back_populates="user")
|
||||||
|
|
||||||
def to_dict(self):
|
def to_dict(self):
|
||||||
|
39
ki/test/test_login_endpoint.py
Normal file
39
ki/test/test_login_endpoint.py
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
from alembic import command
|
||||||
|
import json
|
||||||
|
import unittest
|
||||||
|
|
||||||
|
from app import app, migrate
|
||||||
|
from ki.commands import seed
|
||||||
|
|
||||||
|
|
||||||
|
class TestLoginEndpoint(unittest.TestCase):
|
||||||
|
def setUp(self):
|
||||||
|
app.debug = True
|
||||||
|
app.config["SQLALCHEMY_DATABASE_URI"] = "sqlite:///:memory:"
|
||||||
|
self.client = app.test_client()
|
||||||
|
|
||||||
|
with app.app_context():
|
||||||
|
config = migrate.get_config()
|
||||||
|
command.upgrade(config, "head")
|
||||||
|
|
||||||
|
seed()
|
||||||
|
|
||||||
|
def test_login(self):
|
||||||
|
response1_data = self.login()
|
||||||
|
response2_data = self.login()
|
||||||
|
self.assertNotEqual(response1_data["token"], response2_data["token"])
|
||||||
|
|
||||||
|
def login(self):
|
||||||
|
response = self.client.post("/users/login",
|
||||||
|
data=json.dumps({
|
||||||
|
"username": "peter",
|
||||||
|
"password": "geheim"
|
||||||
|
}),
|
||||||
|
content_type="application/json")
|
||||||
|
self.assertEqual(response.status_code, 200)
|
||||||
|
self.assertIn("token", response.json)
|
||||||
|
return response.json
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == "main":
|
||||||
|
unittest.main()
|
Loading…
Reference in New Issue
Block a user