API - limit access to users for now
- only auth user can access his preference - only admin can visualize users
This commit is contained in:
@@ -1,33 +1,71 @@
|
||||
from typing import Dict
|
||||
|
||||
import pytest
|
||||
from flask import Flask
|
||||
|
||||
from fittrackee.users.exceptions import UserNotFoundException
|
||||
from fittrackee.users.models import User, UserSportPreference
|
||||
from fittrackee.workouts.models import Sport, Workout
|
||||
|
||||
|
||||
class TestUserModel:
|
||||
def test_user_model(self, app: Flask, user_1: User) -> None:
|
||||
assert '<User \'test\'>' == str(user_1)
|
||||
|
||||
serialized_user = user_1.serialize()
|
||||
assert 'test' == serialized_user['username']
|
||||
@staticmethod
|
||||
def assert_serialized_used(serialized_user: Dict) -> None:
|
||||
assert 'created_at' in serialized_user
|
||||
assert serialized_user['admin'] is False
|
||||
assert serialized_user['first_name'] is None
|
||||
assert serialized_user['last_name'] is None
|
||||
assert serialized_user['imperial_units'] is False
|
||||
assert serialized_user['bio'] is None
|
||||
assert serialized_user['location'] is None
|
||||
assert serialized_user['birth_date'] is None
|
||||
assert serialized_user['picture'] is False
|
||||
assert serialized_user['timezone'] is None
|
||||
assert serialized_user['weekm'] is False
|
||||
assert serialized_user['language'] is None
|
||||
assert serialized_user['nb_sports'] == 0
|
||||
assert serialized_user['nb_workouts'] == 0
|
||||
|
||||
def test_user_model_as_auth_user(self, app: Flask, user_1: User) -> None:
|
||||
assert '<User \'test\'>' == str(user_1)
|
||||
|
||||
serialized_user = user_1.serialize(user_1)
|
||||
|
||||
self.assert_serialized_used(serialized_user)
|
||||
assert 'test' == serialized_user['username']
|
||||
assert 'test@test.com' == serialized_user['email']
|
||||
assert serialized_user['nb_sports'] == 0
|
||||
assert serialized_user['records'] == []
|
||||
assert serialized_user['sports_list'] == []
|
||||
assert serialized_user['total_distance'] == 0
|
||||
assert serialized_user['total_duration'] == '0:00:00'
|
||||
assert serialized_user['imperial_units'] is False
|
||||
assert serialized_user['language'] is None
|
||||
assert serialized_user['timezone'] is None
|
||||
assert serialized_user['weekm'] is False
|
||||
assert serialized_user['email_to_confirm'] is None
|
||||
assert 'confirmation_token' not in serialized_user
|
||||
|
||||
def test_user_model_as_admin(
|
||||
self, app: Flask, user_1_admin: User, user_2: User
|
||||
) -> None:
|
||||
serialized_user = user_2.serialize(user_1_admin)
|
||||
|
||||
self.assert_serialized_used(serialized_user)
|
||||
assert 'toto' == serialized_user['username']
|
||||
assert 'toto@toto.com' == serialized_user['email']
|
||||
assert serialized_user['nb_sports'] == 0
|
||||
assert serialized_user['records'] == []
|
||||
assert serialized_user['sports_list'] == []
|
||||
assert serialized_user['total_distance'] == 0
|
||||
assert serialized_user['total_duration'] == '0:00:00'
|
||||
assert serialized_user['email_to_confirm'] is None
|
||||
assert 'imperial_units' not in serialized_user
|
||||
assert 'language' not in serialized_user
|
||||
assert 'timezone' not in serialized_user
|
||||
assert 'weekm' not in serialized_user
|
||||
assert 'confirmation_token' not in serialized_user
|
||||
|
||||
def test_user_model_as_regular_user(
|
||||
self, app: Flask, user_1: User, user_2: User
|
||||
) -> None:
|
||||
with pytest.raises(UserNotFoundException):
|
||||
user_2.serialize(user_1)
|
||||
|
||||
def test_encode_auth_token(self, app: Flask, user_1: User) -> None:
|
||||
auth_token = user_1.encode_auth_token(user_1.id)
|
||||
@@ -49,7 +87,7 @@ class TestUserModel:
|
||||
sport_1_cycling: Sport,
|
||||
workout_cycling_user_1: Workout,
|
||||
) -> None:
|
||||
serialized_user = user_1.serialize()
|
||||
serialized_user = user_1.serialize(user_1)
|
||||
assert len(serialized_user['records']) == 4
|
||||
assert serialized_user['records'][0]['record_type'] == 'AS'
|
||||
assert serialized_user['records'][0]['sport_id'] == sport_1_cycling.id
|
||||
|
||||
Reference in New Issue
Block a user