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
|
|
|
|
2022-03-20 12:15:23 +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
|
|
|
|
|
|
|
|
|
2021-11-03 10:23:28 +01:00
|
|
|
@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()
|
2021-11-03 10:23:28 +01:00
|
|
|
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
|
|
|
|
|
|
|
|
|
2023-05-19 23:08:12 -06:00
|
|
|
@pytest.fixture()
|
|
|
|
def user_1_raw_speed() -> 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')
|
|
|
|
user.is_active = True
|
|
|
|
user.use_raw_gpx_speed = True
|
|
|
|
user.accepted_policy = datetime.datetime.utcnow()
|
|
|
|
db.session.add(user)
|
|
|
|
db.session.commit()
|
|
|
|
return user
|
|
|
|
|
2023-05-21 11:29:56 -06:00
|
|
|
|
2021-01-30 11:20:15 +01:00
|
|
|
@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:
|
2022-03-19 20:34:36 +01:00
|
|
|
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:
|
2022-03-19 20:34:36 +01:00
|
|
|
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'
|
|
|
|
)
|
2022-03-20 12:15:23 +01:00
|
|
|
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
|
2021-11-12 12:33:25 +01:00
|
|
|
|
|
|
|
|
|
|
|
@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
|