143 lines
3.7 KiB
Python
Raw Normal View History

2021-01-30 11:20:15 +01:00
import datetime
import pytest
from fittrackee import db
2021-11-12 12:22:07 +01:00
from fittrackee.users.models import User, UserSportPreference
from fittrackee.workouts.models import Sport
2021-01-30 11:20:15 +01:00
from ..utils import random_string
2021-01-30 11:20:15 +01:00
@pytest.fixture()
def user_1() -> User:
user = User(username='test', email='test@test.com', password='12345678')
2022-03-19 22:02:06 +01:00
user.is_active = True
2023-02-25 14:06:49 +01:00
user.accepted_policy = datetime.datetime.utcnow()
2021-01-30 11:20:15 +01:00
db.session.add(user)
db.session.commit()
return user
@pytest.fixture()
def user_1_upper() -> User:
user = User(username='TEST', email='TEST@TEST.COM', password='12345678')
2022-03-19 22:02:06 +01:00
user.is_active = True
2023-02-25 14:06:49 +01:00
user.accepted_policy = datetime.datetime.utcnow()
db.session.add(user)
db.session.commit()
return user
2021-01-30 11:20:15 +01:00
@pytest.fixture()
def user_1_admin() -> User:
admin = User(
username='admin', email='admin@example.com', password='12345678'
)
admin.admin = True
2022-03-19 22:02:06 +01:00
admin.is_active = True
2023-02-25 14:06:49 +01:00
admin.accepted_policy = datetime.datetime.utcnow()
2021-01-30 11:20:15 +01:00
db.session.add(admin)
db.session.commit()
return admin
@pytest.fixture()
def user_1_full() -> User:
user = User(username='test', email='test@test.com', password='12345678')
user.first_name = 'John'
user.last_name = 'Doe'
user.bio = 'just a random guy'
user.location = 'somewhere'
user.language = 'en'
user.timezone = 'America/New_York'
user.birth_date = datetime.datetime.strptime('01/01/1980', '%d/%m/%Y')
2022-03-19 22:02:06 +01:00
user.is_active = True
2023-02-25 14:06:49 +01:00
user.accepted_policy = datetime.datetime.utcnow()
2021-01-30 11:20:15 +01:00
db.session.add(user)
db.session.commit()
return user
@pytest.fixture()
def user_1_paris() -> User:
user = User(username='test', email='test@test.com', password='12345678')
user.timezone = 'Europe/Paris'
2022-03-19 22:02:06 +01:00
user.is_active = True
2023-02-25 14:06:49 +01:00
user.accepted_policy = datetime.datetime.utcnow()
2021-01-30 11:20:15 +01:00
db.session.add(user)
db.session.commit()
return user
@pytest.fixture()
def user_2() -> User:
user = User(username='toto', email='toto@toto.com', password='12345678')
2022-03-19 22:02:06 +01:00
user.is_active = True
2023-02-25 14:06:49 +01:00
user.accepted_policy = datetime.datetime.utcnow()
2021-01-30 11:20:15 +01:00
db.session.add(user)
db.session.commit()
return user
@pytest.fixture()
def user_2_admin() -> User:
user = User(username='toto', email='toto@toto.com', password='12345678')
2022-03-19 22:02:06 +01:00
user.is_active = True
2021-01-30 11:20:15 +01:00
user.admin = True
2023-02-25 14:06:49 +01:00
user.accepted_policy = datetime.datetime.utcnow()
2021-01-30 11:20:15 +01:00
db.session.add(user)
db.session.commit()
return user
@pytest.fixture()
def user_3() -> User:
user = User(username='sam', email='sam@test.com', password='12345678')
2022-03-19 22:02:06 +01:00
user.is_active = True
2021-01-30 11:20:15 +01:00
user.weekm = True
2023-02-25 14:06:49 +01:00
user.accepted_policy = datetime.datetime.utcnow()
2021-01-30 11:20:15 +01:00
db.session.add(user)
db.session.commit()
return user
2021-11-12 12:22:07 +01:00
2022-03-19 22:02:06 +01:00
@pytest.fixture()
def inactive_user() -> User:
user = User(
username='inactive', email='inactive@example.com', password='12345678'
)
user.confirmation_token = random_string()
2023-02-25 14:06:49 +01:00
user.accepted_policy = datetime.datetime.utcnow()
2022-03-19 22:02:06 +01:00
db.session.add(user)
db.session.commit()
return user
2021-11-12 12:22:07 +01:00
@pytest.fixture()
def user_sport_1_preference(
user_1: User, sport_1_cycling: Sport
) -> UserSportPreference:
user_sport = UserSportPreference(
user_id=user_1.id,
sport_id=sport_1_cycling.id,
stopped_speed_threshold=sport_1_cycling.stopped_speed_threshold,
)
db.session.add(user_sport)
db.session.commit()
return user_sport
@pytest.fixture()
def user_admin_sport_1_preference(
user_1_admin: User, sport_1_cycling: Sport
) -> UserSportPreference:
user_sport = UserSportPreference(
user_id=user_1_admin.id,
sport_id=sport_1_cycling.id,
stopped_speed_threshold=sport_1_cycling.stopped_speed_threshold,
)
db.session.add(user_sport)
db.session.commit()
return user_sport