2019-02-09 19:42:36 +04:00
|
|
|
from fastapi.encoders import jsonable_encoder
|
2024-02-29 15:42:55 -05:00
|
|
|
from sqlmodel import Session
|
2019-02-09 19:42:36 +04:00
|
|
|
|
2019-03-11 13:36:42 +04:00
|
|
|
from app import crud
|
2020-04-20 19:03:13 +02:00
|
|
|
from app.core.security import verify_password
|
2024-02-29 15:42:55 -05:00
|
|
|
from app.models import User, UserCreate, UserUpdate
|
2020-04-20 19:03:13 +02:00
|
|
|
from app.tests.utils.utils import random_email, random_lower_string
|
2019-02-09 19:42:36 +04:00
|
|
|
|
|
|
|
|
|
2020-04-20 19:03:13 +02:00
|
|
|
def test_create_user(db: Session) -> None:
|
2020-04-06 11:36:29 +02:00
|
|
|
email = random_email()
|
2019-02-09 19:42:36 +04:00
|
|
|
password = random_lower_string()
|
2019-04-19 09:45:23 +04:00
|
|
|
user_in = UserCreate(email=email, password=password)
|
2024-02-29 15:42:55 -05:00
|
|
|
user = crud.create_user(session=db, user_create=user_in)
|
2019-02-23 18:44:29 +04:00
|
|
|
assert user.email == email
|
2019-02-09 19:42:36 +04:00
|
|
|
assert hasattr(user, "hashed_password")
|
|
|
|
|
|
|
|
|
|
|
2020-04-20 19:03:13 +02:00
|
|
|
def test_authenticate_user(db: Session) -> None:
|
2020-04-06 11:36:29 +02:00
|
|
|
email = random_email()
|
2019-02-09 19:42:36 +04:00
|
|
|
password = random_lower_string()
|
2019-04-19 09:45:23 +04:00
|
|
|
user_in = UserCreate(email=email, password=password)
|
2024-02-29 15:42:55 -05:00
|
|
|
user = crud.create_user(session=db, user_create=user_in)
|
|
|
|
|
authenticated_user = crud.authenticate(session=db, email=email, password=password)
|
2019-02-09 19:42:36 +04:00
|
|
|
assert authenticated_user
|
2019-02-23 18:44:29 +04:00
|
|
|
assert user.email == authenticated_user.email
|
2019-02-09 19:42:36 +04:00
|
|
|
|
|
|
|
|
|
2020-04-20 19:03:13 +02:00
|
|
|
def test_not_authenticate_user(db: Session) -> None:
|
2020-04-06 11:36:29 +02:00
|
|
|
email = random_email()
|
2019-02-09 19:42:36 +04:00
|
|
|
password = random_lower_string()
|
2024-02-29 15:42:55 -05:00
|
|
|
user = crud.authenticate(session=db, email=email, password=password)
|
2019-03-11 13:36:42 +04:00
|
|
|
assert user is None
|
2019-02-09 19:42:36 +04:00
|
|
|
|
|
|
|
|
|
2020-04-20 19:03:13 +02:00
|
|
|
def test_check_if_user_is_active(db: Session) -> None:
|
2020-04-06 11:36:29 +02:00
|
|
|
email = random_email()
|
2019-02-09 19:42:36 +04:00
|
|
|
password = random_lower_string()
|
2019-04-19 09:45:23 +04:00
|
|
|
user_in = UserCreate(email=email, password=password)
|
2024-02-29 15:42:55 -05:00
|
|
|
user = crud.create_user(session=db, user_create=user_in)
|
|
|
|
|
assert user.is_active is True
|
2019-02-09 19:42:36 +04:00
|
|
|
|
|
|
|
|
|
2020-04-20 19:03:13 +02:00
|
|
|
def test_check_if_user_is_active_inactive(db: Session) -> None:
|
2020-04-06 11:36:29 +02:00
|
|
|
email = random_email()
|
2019-02-09 19:42:36 +04:00
|
|
|
password = random_lower_string()
|
2019-04-19 09:45:23 +04:00
|
|
|
user_in = UserCreate(email=email, password=password, disabled=True)
|
2024-02-29 15:42:55 -05:00
|
|
|
user = crud.create_user(session=db, user_create=user_in)
|
|
|
|
|
assert user.is_active
|
2019-02-09 19:42:36 +04:00
|
|
|
|
|
|
|
|
|
2020-04-20 19:03:13 +02:00
|
|
|
def test_check_if_user_is_superuser(db: Session) -> None:
|
2020-04-06 11:36:29 +02:00
|
|
|
email = random_email()
|
2019-02-09 19:42:36 +04:00
|
|
|
password = random_lower_string()
|
2019-04-19 09:45:23 +04:00
|
|
|
user_in = UserCreate(email=email, password=password, is_superuser=True)
|
2024-02-29 15:42:55 -05:00
|
|
|
user = crud.create_user(session=db, user_create=user_in)
|
|
|
|
|
assert user.is_superuser is True
|
2019-02-09 19:42:36 +04:00
|
|
|
|
|
|
|
|
|
2020-04-20 19:03:13 +02:00
|
|
|
def test_check_if_user_is_superuser_normal_user(db: Session) -> None:
|
2020-04-06 11:36:29 +02:00
|
|
|
username = random_email()
|
2019-02-09 19:42:36 +04:00
|
|
|
password = random_lower_string()
|
2019-04-19 09:45:23 +04:00
|
|
|
user_in = UserCreate(email=username, password=password)
|
2024-02-29 15:42:55 -05:00
|
|
|
user = crud.create_user(session=db, user_create=user_in)
|
|
|
|
|
assert user.is_superuser is False
|
2019-02-09 19:42:36 +04:00
|
|
|
|
|
|
|
|
|
2020-04-20 19:03:13 +02:00
|
|
|
def test_get_user(db: Session) -> None:
|
2019-02-09 19:42:36 +04:00
|
|
|
password = random_lower_string()
|
2020-04-06 11:36:29 +02:00
|
|
|
username = random_email()
|
2019-04-19 09:45:23 +04:00
|
|
|
user_in = UserCreate(email=username, password=password, is_superuser=True)
|
2024-02-29 15:42:55 -05:00
|
|
|
user = crud.create_user(session=db, user_create=user_in)
|
|
|
|
|
user_2 = db.get(User, user.id)
|
2020-04-20 19:03:13 +02:00
|
|
|
assert user_2
|
2019-02-23 18:44:29 +04:00
|
|
|
assert user.email == user_2.email
|
2019-02-09 19:42:36 +04:00
|
|
|
assert jsonable_encoder(user) == jsonable_encoder(user_2)
|
2020-04-17 09:20:00 +02:00
|
|
|
|
|
|
|
|
|
2020-04-20 19:03:13 +02:00
|
|
|
def test_update_user(db: Session) -> None:
|
2020-04-17 09:20:00 +02:00
|
|
|
password = random_lower_string()
|
|
|
|
|
email = random_email()
|
|
|
|
|
user_in = UserCreate(email=email, password=password, is_superuser=True)
|
2024-02-29 15:42:55 -05:00
|
|
|
user = crud.create_user(session=db, user_create=user_in)
|
2020-04-17 09:20:00 +02:00
|
|
|
new_password = random_lower_string()
|
2020-04-20 19:03:13 +02:00
|
|
|
user_in_update = UserUpdate(password=new_password, is_superuser=True)
|
2024-02-29 15:42:55 -05:00
|
|
|
if user.id is not None:
|
|
|
|
|
crud.update_user(session=db, user_id=user.id, user_in=user_in_update)
|
|
|
|
|
user_2 = db.get(User, user.id)
|
2020-04-20 19:03:13 +02:00
|
|
|
assert user_2
|
2020-04-17 09:20:00 +02:00
|
|
|
assert user.email == user_2.email
|
|
|
|
|
assert verify_password(new_password, user_2.hashed_password)
|