API - fix new sports addition
- add data migration and fix data init for new instances - update and fix tests
This commit is contained in:
		
							
								
								
									
										3
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										3
									
								
								Makefile
									
									
									
									
									
								
							| @@ -134,6 +134,9 @@ migrate-db: | |||||||
| recalculate: | recalculate: | ||||||
| 	$(FLASK) recalculate | 	$(FLASK) recalculate | ||||||
|  |  | ||||||
|  | revision: | ||||||
|  | 	$(FLASK) db revision --directory $(MIGRATIONS) --message $(MIGRATION_MESSAGE) | ||||||
|  |  | ||||||
| run: | run: | ||||||
| 	$(MAKE) P="run-server run-workers" make-p | 	$(MAKE) P="run-server run-workers" make-p | ||||||
|  |  | ||||||
|   | |||||||
| @@ -6,7 +6,6 @@ from fittrackee.application.utils import ( | |||||||
|     update_app_config_from_database, |     update_app_config_from_database, | ||||||
| ) | ) | ||||||
| from fittrackee.users.models import User | from fittrackee.users.models import User | ||||||
| from fittrackee.workouts.models import Sport |  | ||||||
|  |  | ||||||
|  |  | ||||||
| def init_database(app: Flask) -> None: | def init_database(app: Flask) -> None: | ||||||
| @@ -17,50 +16,6 @@ def init_database(app: Flask) -> None: | |||||||
|     admin.admin = True |     admin.admin = True | ||||||
|     admin.timezone = 'Europe/Paris' |     admin.timezone = 'Europe/Paris' | ||||||
|     db.session.add(admin) |     db.session.add(admin) | ||||||
|     sport = Sport(label='Cycling (Sport)') |  | ||||||
|     sport.img = '/img/sports/cycling-sport.png' |  | ||||||
|     sport.is_default = True |  | ||||||
|     db.session.add(sport) |  | ||||||
|     sport = Sport(label='Cycling (Transport)') |  | ||||||
|     sport.img = '/img/sports/cycling-transport.png' |  | ||||||
|     sport.is_default = True |  | ||||||
|     db.session.add(sport) |  | ||||||
|     sport = Sport(label='Hiking') |  | ||||||
|     sport.img = '/img/sports/hiking.png' |  | ||||||
|     sport.is_default = True |  | ||||||
|     db.session.add(sport) |  | ||||||
|     sport = Sport(label='Mountain Biking') |  | ||||||
|     sport.img = '/img/sports/mountain-biking.png' |  | ||||||
|     sport.is_default = True |  | ||||||
|     db.session.add(sport) |  | ||||||
|     sport = Sport(label='Mountain Biking (Electric)') |  | ||||||
|     sport.img = '/img/sports/electric-mountain-biking.png' |  | ||||||
|     sport.is_default = True |  | ||||||
|     db.session.add(sport) |  | ||||||
|     sport = Sport(label='Running') |  | ||||||
|     sport.img = '/img/sports/running.png' |  | ||||||
|     sport.is_default = True |  | ||||||
|     db.session.add(sport) |  | ||||||
|     sport = Sport(label='Trail') |  | ||||||
|     sport.img = '/img/sports/trail.png' |  | ||||||
|     sport.is_default = True |  | ||||||
|     db.session.add(sport) |  | ||||||
|     sport = Sport(label='Walking') |  | ||||||
|     sport.img = '/img/sports/walking.png' |  | ||||||
|     sport.is_default = True |  | ||||||
|     db.session.add(sport) |  | ||||||
|     sport = Sport(label='Skiing (Alpine)') |  | ||||||
|     sport.img = '/img/sports/alpine-skiing.png' |  | ||||||
|     sport.is_default = True |  | ||||||
|     db.session.add(sport) |  | ||||||
|     sport = Sport(label='Skiing (Cross Country)') |  | ||||||
|     sport.img = '/img/sports/cross-country-skiing.png' |  | ||||||
|     sport.is_default = True |  | ||||||
|     db.session.add(sport) |  | ||||||
|     sport = Sport(label='Rowing') |  | ||||||
|     sport.img = '/img/sports/rowing.png' |  | ||||||
|     sport.is_default = True |  | ||||||
|     db.session.add(sport) |  | ||||||
|     db.session.commit() |     db.session.commit() | ||||||
|     _, db_app_config = init_config() |     _, db_app_config = init_config() | ||||||
|     update_app_config_from_database(app, db_app_config) |     update_app_config_from_database(app, db_app_config) | ||||||
|   | |||||||
| @@ -51,6 +51,19 @@ def upgrade(): | |||||||
|     ) |     ) | ||||||
|     # ### end Alembic commands ### |     # ### end Alembic commands ### | ||||||
|  |  | ||||||
|  |     op.execute( | ||||||
|  |         """ | ||||||
|  |         INSERT INTO sports (label, img, is_default) | ||||||
|  |         VALUES  | ||||||
|  |             ('Cycling (Sport)', '/img/sports/cycling-sport.png', True), | ||||||
|  |             ('Cycling (Transport)', '/img/sports/cycling-transport.png', True), | ||||||
|  |             ('Hiking', '/img/sports/hiking.png', True), | ||||||
|  |             ('Mountain Biking', '/img/sports/mountain-biking.png', True), | ||||||
|  |             ('Running', '/img/sports/running.png', True), | ||||||
|  |             ('Walking', '/img/sports/walking.png', True) | ||||||
|  |         """ | ||||||
|  |     ) | ||||||
|  |  | ||||||
|  |  | ||||||
| def downgrade(): | def downgrade(): | ||||||
|     # ### commands auto generated by Alembic - please adjust! ### |     # ### commands auto generated by Alembic - please adjust! ### | ||||||
|   | |||||||
| @@ -0,0 +1,39 @@ | |||||||
|  | """ Add new sports | ||||||
|  |  | ||||||
|  | Revision ID: cee0830497f8 | ||||||
|  | Revises: 4e8597c50064 | ||||||
|  | Create Date: 2021-08-25 13:58:52.333603 | ||||||
|  |  | ||||||
|  | """ | ||||||
|  | from alembic import op | ||||||
|  |  | ||||||
|  |  | ||||||
|  | # revision identifiers, used by Alembic. | ||||||
|  | revision = 'cee0830497f8' | ||||||
|  | down_revision = '4e8597c50064' | ||||||
|  | branch_labels = None | ||||||
|  | depends_on = None | ||||||
|  |  | ||||||
|  |  | ||||||
|  | def upgrade(): | ||||||
|  |  | ||||||
|  |     op.execute( | ||||||
|  |         """ | ||||||
|  |         INSERT INTO sports (label, img, is_active) | ||||||
|  |         VALUES  | ||||||
|  |             ('Mountain Biking (Electric)', '/img/sports/electric-mountain-biking.png', True), | ||||||
|  |             ('Trail', '/img/sports/trail.png', True), | ||||||
|  |             ('Skiing (Alpine)', '/img/sports/alpine-skiing.png', True), | ||||||
|  |             ('Skiing (Cross Country)', '/img/sports/cross-country-skiing.png', True), | ||||||
|  |             ('Rowing', '/img/sports/rowing.png', True) | ||||||
|  |         """ | ||||||
|  |     ) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | def downgrade(): | ||||||
|  |     op.execute( | ||||||
|  |         """ | ||||||
|  |         DELETE FROM sports | ||||||
|  |         WHERE label = 'Mountain Biking (Electric)'; | ||||||
|  |         """ | ||||||
|  |     ) | ||||||
							
								
								
									
										18
									
								
								fittrackee/tests/fixtures/fixtures_workouts.py
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										18
									
								
								fittrackee/tests/fixtures/fixtures_workouts.py
									
									
									
									
										vendored
									
									
								
							| @@ -108,8 +108,11 @@ def seven_workouts_user_1() -> Workout: | |||||||
|     ) |     ) | ||||||
|     workout.ave_speed = float(workout.distance) / (1024 / 3600) |     workout.ave_speed = float(workout.distance) / (1024 / 3600) | ||||||
|     workout.moving = workout.duration |     workout.moving = workout.duration | ||||||
|  |     workout.ascent = 120 | ||||||
|  |     workout.descent = 200 | ||||||
|     db.session.add(workout) |     db.session.add(workout) | ||||||
|     db.session.flush() |     db.session.flush() | ||||||
|  |  | ||||||
|     workout = Workout( |     workout = Workout( | ||||||
|         user_id=1, |         user_id=1, | ||||||
|         sport_id=1, |         sport_id=1, | ||||||
| @@ -119,8 +122,11 @@ def seven_workouts_user_1() -> Workout: | |||||||
|     ) |     ) | ||||||
|     workout.ave_speed = float(workout.distance) / (3456 / 3600) |     workout.ave_speed = float(workout.distance) / (3456 / 3600) | ||||||
|     workout.moving = workout.duration |     workout.moving = workout.duration | ||||||
|  |     workout.ascent = 100 | ||||||
|  |     workout.descent = 80 | ||||||
|     db.session.add(workout) |     db.session.add(workout) | ||||||
|     db.session.flush() |     db.session.flush() | ||||||
|  |  | ||||||
|     workout = Workout( |     workout = Workout( | ||||||
|         user_id=1, |         user_id=1, | ||||||
|         sport_id=1, |         sport_id=1, | ||||||
| @@ -130,8 +136,11 @@ def seven_workouts_user_1() -> Workout: | |||||||
|     ) |     ) | ||||||
|     workout.ave_speed = float(workout.distance) / (1024 / 3600) |     workout.ave_speed = float(workout.distance) / (1024 / 3600) | ||||||
|     workout.moving = workout.duration |     workout.moving = workout.duration | ||||||
|  |     workout.ascent = 80 | ||||||
|  |     workout.descent = 100 | ||||||
|     db.session.add(workout) |     db.session.add(workout) | ||||||
|     db.session.flush() |     db.session.flush() | ||||||
|  |  | ||||||
|     workout = Workout( |     workout = Workout( | ||||||
|         user_id=1, |         user_id=1, | ||||||
|         sport_id=1, |         sport_id=1, | ||||||
| @@ -141,8 +150,11 @@ def seven_workouts_user_1() -> Workout: | |||||||
|     ) |     ) | ||||||
|     workout.ave_speed = float(workout.distance) / (600 / 3600) |     workout.ave_speed = float(workout.distance) / (600 / 3600) | ||||||
|     workout.moving = workout.duration |     workout.moving = workout.duration | ||||||
|  |     workout.ascent = 120 | ||||||
|  |     workout.descent = 180 | ||||||
|     db.session.add(workout) |     db.session.add(workout) | ||||||
|     db.session.flush() |     db.session.flush() | ||||||
|  |  | ||||||
|     workout = Workout( |     workout = Workout( | ||||||
|         user_id=1, |         user_id=1, | ||||||
|         sport_id=1, |         sport_id=1, | ||||||
| @@ -152,8 +164,11 @@ def seven_workouts_user_1() -> Workout: | |||||||
|     ) |     ) | ||||||
|     workout.ave_speed = float(workout.distance) / (1000 / 3600) |     workout.ave_speed = float(workout.distance) / (1000 / 3600) | ||||||
|     workout.moving = workout.duration |     workout.moving = workout.duration | ||||||
|  |     workout.ascent = 100 | ||||||
|  |     workout.descent = 200 | ||||||
|     db.session.add(workout) |     db.session.add(workout) | ||||||
|     db.session.flush() |     db.session.flush() | ||||||
|  |  | ||||||
|     workout = Workout( |     workout = Workout( | ||||||
|         user_id=1, |         user_id=1, | ||||||
|         sport_id=1, |         sport_id=1, | ||||||
| @@ -163,8 +178,11 @@ def seven_workouts_user_1() -> Workout: | |||||||
|     ) |     ) | ||||||
|     workout.ave_speed = float(workout.distance) / (6000 / 3600) |     workout.ave_speed = float(workout.distance) / (6000 / 3600) | ||||||
|     workout.moving = workout.duration |     workout.moving = workout.duration | ||||||
|  |     workout.ascent = 40 | ||||||
|  |     workout.descent = 20 | ||||||
|     db.session.add(workout) |     db.session.add(workout) | ||||||
|     db.session.flush() |     db.session.flush() | ||||||
|  |  | ||||||
|     workout = Workout( |     workout = Workout( | ||||||
|         user_id=1, |         user_id=1, | ||||||
|         sport_id=1, |         sport_id=1, | ||||||
|   | |||||||
| @@ -110,6 +110,8 @@ class TestGetStatsByTime(ApiTestCaseMixin): | |||||||
|             '2017': { |             '2017': { | ||||||
|                 '1': { |                 '1': { | ||||||
|                     'nb_workouts': 2, |                     'nb_workouts': 2, | ||||||
|  |                     'total_ascent': 220.0, | ||||||
|  |                     'total_descent': 280.0, | ||||||
|                     'total_distance': 15.0, |                     'total_distance': 15.0, | ||||||
|                     'total_duration': 4480, |                     'total_duration': 4480, | ||||||
|                 } |                 } | ||||||
| @@ -117,11 +119,15 @@ class TestGetStatsByTime(ApiTestCaseMixin): | |||||||
|             '2018': { |             '2018': { | ||||||
|                 '1': { |                 '1': { | ||||||
|                     'nb_workouts': 5, |                     'nb_workouts': 5, | ||||||
|  |                     'total_ascent': 340.0, | ||||||
|  |                     'total_descent': 500.0, | ||||||
|                     'total_distance': 39.0, |                     'total_distance': 39.0, | ||||||
|                     'total_duration': 11624, |                     'total_duration': 11624, | ||||||
|                 }, |                 }, | ||||||
|                 '2': { |                 '2': { | ||||||
|                     'nb_workouts': 1, |                     'nb_workouts': 1, | ||||||
|  |                     'total_ascent': 0.0, | ||||||
|  |                     'total_descent': 0.0, | ||||||
|                     'total_distance': 12.0, |                     'total_distance': 12.0, | ||||||
|                     'total_duration': 6000, |                     'total_duration': 6000, | ||||||
|                 }, |                 }, | ||||||
| @@ -151,11 +157,15 @@ class TestGetStatsByTime(ApiTestCaseMixin): | |||||||
|             '2018': { |             '2018': { | ||||||
|                 '1': { |                 '1': { | ||||||
|                     'nb_workouts': 1, |                     'nb_workouts': 1, | ||||||
|  |                     'total_ascent': 40.0, | ||||||
|  |                     'total_descent': 20.0, | ||||||
|                     'total_distance': 8.0, |                     'total_distance': 8.0, | ||||||
|                     'total_duration': 6000, |                     'total_duration': 6000, | ||||||
|                 }, |                 }, | ||||||
|                 '2': { |                 '2': { | ||||||
|                     'nb_workouts': 1, |                     'nb_workouts': 1, | ||||||
|  |                     'total_ascent': 0.0, | ||||||
|  |                     'total_descent': 0.0, | ||||||
|                     'total_distance': 12.0, |                     'total_distance': 12.0, | ||||||
|                     'total_duration': 6000, |                     'total_duration': 6000, | ||||||
|                 }, |                 }, | ||||||
| @@ -186,11 +196,15 @@ class TestGetStatsByTime(ApiTestCaseMixin): | |||||||
|             '2018': { |             '2018': { | ||||||
|                 '1': { |                 '1': { | ||||||
|                     'nb_workouts': 1, |                     'nb_workouts': 1, | ||||||
|  |                     'total_ascent': 40.0, | ||||||
|  |                     'total_descent': 20.0, | ||||||
|                     'total_distance': 8.0, |                     'total_distance': 8.0, | ||||||
|                     'total_duration': 6000, |                     'total_duration': 6000, | ||||||
|                 }, |                 }, | ||||||
|                 '2': { |                 '2': { | ||||||
|                     'nb_workouts': 1, |                     'nb_workouts': 1, | ||||||
|  |                     'total_ascent': 0.0, | ||||||
|  |                     'total_descent': 0.0, | ||||||
|                     'total_distance': 12.0, |                     'total_distance': 12.0, | ||||||
|                     'total_duration': 6000, |                     'total_duration': 6000, | ||||||
|                 }, |                 }, | ||||||
| @@ -220,6 +234,8 @@ class TestGetStatsByTime(ApiTestCaseMixin): | |||||||
|             '2017': { |             '2017': { | ||||||
|                 '1': { |                 '1': { | ||||||
|                     'nb_workouts': 2, |                     'nb_workouts': 2, | ||||||
|  |                     'total_ascent': 220.0, | ||||||
|  |                     'total_descent': 280.0, | ||||||
|                     'total_distance': 15.0, |                     'total_distance': 15.0, | ||||||
|                     'total_duration': 4480, |                     'total_duration': 4480, | ||||||
|                 } |                 } | ||||||
| @@ -227,11 +243,15 @@ class TestGetStatsByTime(ApiTestCaseMixin): | |||||||
|             '2018': { |             '2018': { | ||||||
|                 '1': { |                 '1': { | ||||||
|                     'nb_workouts': 5, |                     'nb_workouts': 5, | ||||||
|  |                     'total_ascent': 340.0, | ||||||
|  |                     'total_descent': 500.0, | ||||||
|                     'total_distance': 39.0, |                     'total_distance': 39.0, | ||||||
|                     'total_duration': 11624, |                     'total_duration': 11624, | ||||||
|                 }, |                 }, | ||||||
|                 '2': { |                 '2': { | ||||||
|                     'nb_workouts': 1, |                     'nb_workouts': 1, | ||||||
|  |                     'total_ascent': 0.0, | ||||||
|  |                     'total_descent': 0.0, | ||||||
|                     'total_distance': 12.0, |                     'total_distance': 12.0, | ||||||
|                     'total_duration': 6000, |                     'total_duration': 6000, | ||||||
|                 }, |                 }, | ||||||
| @@ -261,11 +281,15 @@ class TestGetStatsByTime(ApiTestCaseMixin): | |||||||
|             '2018': { |             '2018': { | ||||||
|                 '1': { |                 '1': { | ||||||
|                     'nb_workouts': 1, |                     'nb_workouts': 1, | ||||||
|  |                     'total_ascent': 40.0, | ||||||
|  |                     'total_descent': 20.0, | ||||||
|                     'total_distance': 8.0, |                     'total_distance': 8.0, | ||||||
|                     'total_duration': 6000, |                     'total_duration': 6000, | ||||||
|                 }, |                 }, | ||||||
|                 '2': { |                 '2': { | ||||||
|                     'nb_workouts': 1, |                     'nb_workouts': 1, | ||||||
|  |                     'total_ascent': 0.0, | ||||||
|  |                     'total_descent': 0.0, | ||||||
|                     'total_distance': 12.0, |                     'total_distance': 12.0, | ||||||
|                     'total_duration': 6000, |                     'total_duration': 6000, | ||||||
|                 }, |                 }, | ||||||
| @@ -296,11 +320,15 @@ class TestGetStatsByTime(ApiTestCaseMixin): | |||||||
|             '2018': { |             '2018': { | ||||||
|                 '1': { |                 '1': { | ||||||
|                     'nb_workouts': 1, |                     'nb_workouts': 1, | ||||||
|  |                     'total_ascent': 40.0, | ||||||
|  |                     'total_descent': 20.0, | ||||||
|                     'total_distance': 8.0, |                     'total_distance': 8.0, | ||||||
|                     'total_duration': 6000, |                     'total_duration': 6000, | ||||||
|                 }, |                 }, | ||||||
|                 '2': { |                 '2': { | ||||||
|                     'nb_workouts': 1, |                     'nb_workouts': 1, | ||||||
|  |                     'total_ascent': 0.0, | ||||||
|  |                     'total_descent': 0.0, | ||||||
|                     'total_distance': 12.0, |                     'total_distance': 12.0, | ||||||
|                     'total_duration': 6000, |                     'total_duration': 6000, | ||||||
|                 }, |                 }, | ||||||
| @@ -330,6 +358,8 @@ class TestGetStatsByTime(ApiTestCaseMixin): | |||||||
|             '2017-03': { |             '2017-03': { | ||||||
|                 '1': { |                 '1': { | ||||||
|                     'nb_workouts': 1, |                     'nb_workouts': 1, | ||||||
|  |                     'total_ascent': 120.0, | ||||||
|  |                     'total_descent': 200.0, | ||||||
|                     'total_distance': 5.0, |                     'total_distance': 5.0, | ||||||
|                     'total_duration': 1024, |                     'total_duration': 1024, | ||||||
|                 } |                 } | ||||||
| @@ -337,6 +367,8 @@ class TestGetStatsByTime(ApiTestCaseMixin): | |||||||
|             '2017-06': { |             '2017-06': { | ||||||
|                 '1': { |                 '1': { | ||||||
|                     'nb_workouts': 1, |                     'nb_workouts': 1, | ||||||
|  |                     'total_ascent': 100.0, | ||||||
|  |                     'total_descent': 80.0, | ||||||
|                     'total_distance': 10.0, |                     'total_distance': 10.0, | ||||||
|                     'total_duration': 3456, |                     'total_duration': 3456, | ||||||
|                 } |                 } | ||||||
| @@ -344,6 +376,8 @@ class TestGetStatsByTime(ApiTestCaseMixin): | |||||||
|             '2018-01': { |             '2018-01': { | ||||||
|                 '1': { |                 '1': { | ||||||
|                     'nb_workouts': 1, |                     'nb_workouts': 1, | ||||||
|  |                     'total_ascent': 80.0, | ||||||
|  |                     'total_descent': 100.0, | ||||||
|                     'total_distance': 10.0, |                     'total_distance': 10.0, | ||||||
|                     'total_duration': 1024, |                     'total_duration': 1024, | ||||||
|                 } |                 } | ||||||
| @@ -351,6 +385,8 @@ class TestGetStatsByTime(ApiTestCaseMixin): | |||||||
|             '2018-02': { |             '2018-02': { | ||||||
|                 '1': { |                 '1': { | ||||||
|                     'nb_workouts': 2, |                     'nb_workouts': 2, | ||||||
|  |                     'total_ascent': 220.0, | ||||||
|  |                     'total_descent': 380.0, | ||||||
|                     'total_distance': 11.0, |                     'total_distance': 11.0, | ||||||
|                     'total_duration': 1600, |                     'total_duration': 1600, | ||||||
|                 } |                 } | ||||||
| @@ -358,11 +394,15 @@ class TestGetStatsByTime(ApiTestCaseMixin): | |||||||
|             '2018-04': { |             '2018-04': { | ||||||
|                 '1': { |                 '1': { | ||||||
|                     'nb_workouts': 1, |                     'nb_workouts': 1, | ||||||
|  |                     'total_ascent': 40.0, | ||||||
|  |                     'total_descent': 20.0, | ||||||
|                     'total_distance': 8.0, |                     'total_distance': 8.0, | ||||||
|                     'total_duration': 6000, |                     'total_duration': 6000, | ||||||
|                 }, |                 }, | ||||||
|                 '2': { |                 '2': { | ||||||
|                     'nb_workouts': 1, |                     'nb_workouts': 1, | ||||||
|  |                     'total_ascent': 0.0, | ||||||
|  |                     'total_descent': 0.0, | ||||||
|                     'total_distance': 12.0, |                     'total_distance': 12.0, | ||||||
|                     'total_duration': 6000, |                     'total_duration': 6000, | ||||||
|                 }, |                 }, | ||||||
| @@ -370,6 +410,8 @@ class TestGetStatsByTime(ApiTestCaseMixin): | |||||||
|             '2018-05': { |             '2018-05': { | ||||||
|                 '1': { |                 '1': { | ||||||
|                     'nb_workouts': 1, |                     'nb_workouts': 1, | ||||||
|  |                     'total_ascent': 0.0, | ||||||
|  |                     'total_descent': 0.0, | ||||||
|                     'total_distance': 10.0, |                     'total_distance': 10.0, | ||||||
|                     'total_duration': 3000, |                     'total_duration': 3000, | ||||||
|                 } |                 } | ||||||
| @@ -399,6 +441,8 @@ class TestGetStatsByTime(ApiTestCaseMixin): | |||||||
|             '2017-03': { |             '2017-03': { | ||||||
|                 '1': { |                 '1': { | ||||||
|                     'nb_workouts': 1, |                     'nb_workouts': 1, | ||||||
|  |                     'total_ascent': 120.0, | ||||||
|  |                     'total_descent': 200.0, | ||||||
|                     'total_distance': 5.0, |                     'total_distance': 5.0, | ||||||
|                     'total_duration': 1024, |                     'total_duration': 1024, | ||||||
|                 } |                 } | ||||||
| @@ -406,6 +450,8 @@ class TestGetStatsByTime(ApiTestCaseMixin): | |||||||
|             '2017-06': { |             '2017-06': { | ||||||
|                 '1': { |                 '1': { | ||||||
|                     'nb_workouts': 1, |                     'nb_workouts': 1, | ||||||
|  |                     'total_ascent': 100.0, | ||||||
|  |                     'total_descent': 80.0, | ||||||
|                     'total_distance': 10.0, |                     'total_distance': 10.0, | ||||||
|                     'total_duration': 3456, |                     'total_duration': 3456, | ||||||
|                 } |                 } | ||||||
| @@ -413,6 +459,8 @@ class TestGetStatsByTime(ApiTestCaseMixin): | |||||||
|             '2018-01': { |             '2018-01': { | ||||||
|                 '1': { |                 '1': { | ||||||
|                     'nb_workouts': 1, |                     'nb_workouts': 1, | ||||||
|  |                     'total_ascent': 80.0, | ||||||
|  |                     'total_descent': 100.0, | ||||||
|                     'total_distance': 10.0, |                     'total_distance': 10.0, | ||||||
|                     'total_duration': 1024, |                     'total_duration': 1024, | ||||||
|                 } |                 } | ||||||
| @@ -420,6 +468,8 @@ class TestGetStatsByTime(ApiTestCaseMixin): | |||||||
|             '2018-02': { |             '2018-02': { | ||||||
|                 '1': { |                 '1': { | ||||||
|                     'nb_workouts': 2, |                     'nb_workouts': 2, | ||||||
|  |                     'total_ascent': 220.0, | ||||||
|  |                     'total_descent': 380.0, | ||||||
|                     'total_distance': 11.0, |                     'total_distance': 11.0, | ||||||
|                     'total_duration': 1600, |                     'total_duration': 1600, | ||||||
|                 } |                 } | ||||||
| @@ -427,11 +477,15 @@ class TestGetStatsByTime(ApiTestCaseMixin): | |||||||
|             '2018-04': { |             '2018-04': { | ||||||
|                 '1': { |                 '1': { | ||||||
|                     'nb_workouts': 1, |                     'nb_workouts': 1, | ||||||
|  |                     'total_ascent': 40.0, | ||||||
|  |                     'total_descent': 20.0, | ||||||
|                     'total_distance': 8.0, |                     'total_distance': 8.0, | ||||||
|                     'total_duration': 6000, |                     'total_duration': 6000, | ||||||
|                 }, |                 }, | ||||||
|                 '2': { |                 '2': { | ||||||
|                     'nb_workouts': 1, |                     'nb_workouts': 1, | ||||||
|  |                     'total_ascent': 0.0, | ||||||
|  |                     'total_descent': 0.0, | ||||||
|                     'total_distance': 12.0, |                     'total_distance': 12.0, | ||||||
|                     'total_duration': 6000, |                     'total_duration': 6000, | ||||||
|                 }, |                 }, | ||||||
| @@ -439,6 +493,8 @@ class TestGetStatsByTime(ApiTestCaseMixin): | |||||||
|             '2018-05': { |             '2018-05': { | ||||||
|                 '1': { |                 '1': { | ||||||
|                     'nb_workouts': 1, |                     'nb_workouts': 1, | ||||||
|  |                     'total_ascent': 0.0, | ||||||
|  |                     'total_descent': 0.0, | ||||||
|                     'total_distance': 10.0, |                     'total_distance': 10.0, | ||||||
|                     'total_duration': 3000, |                     'total_duration': 3000, | ||||||
|                 } |                 } | ||||||
| @@ -468,11 +524,15 @@ class TestGetStatsByTime(ApiTestCaseMixin): | |||||||
|             '2018-04': { |             '2018-04': { | ||||||
|                 '1': { |                 '1': { | ||||||
|                     'nb_workouts': 1, |                     'nb_workouts': 1, | ||||||
|  |                     'total_ascent': 40.0, | ||||||
|  |                     'total_descent': 20.0, | ||||||
|                     'total_distance': 8.0, |                     'total_distance': 8.0, | ||||||
|                     'total_duration': 6000, |                     'total_duration': 6000, | ||||||
|                 }, |                 }, | ||||||
|                 '2': { |                 '2': { | ||||||
|                     'nb_workouts': 1, |                     'nb_workouts': 1, | ||||||
|  |                     'total_ascent': 0.0, | ||||||
|  |                     'total_descent': 0.0, | ||||||
|                     'total_distance': 12.0, |                     'total_distance': 12.0, | ||||||
|                     'total_duration': 6000, |                     'total_duration': 6000, | ||||||
|                 }, |                 }, | ||||||
| @@ -502,6 +562,8 @@ class TestGetStatsByTime(ApiTestCaseMixin): | |||||||
|             '2017-03-19': { |             '2017-03-19': { | ||||||
|                 '1': { |                 '1': { | ||||||
|                     'nb_workouts': 1, |                     'nb_workouts': 1, | ||||||
|  |                     'total_ascent': 120.0, | ||||||
|  |                     'total_descent': 200.0, | ||||||
|                     'total_distance': 5.0, |                     'total_distance': 5.0, | ||||||
|                     'total_duration': 1024, |                     'total_duration': 1024, | ||||||
|                 } |                 } | ||||||
| @@ -509,6 +571,8 @@ class TestGetStatsByTime(ApiTestCaseMixin): | |||||||
|             '2017-05-28': { |             '2017-05-28': { | ||||||
|                 '1': { |                 '1': { | ||||||
|                     'nb_workouts': 1, |                     'nb_workouts': 1, | ||||||
|  |                     'total_ascent': 100.0, | ||||||
|  |                     'total_descent': 80.0, | ||||||
|                     'total_distance': 10.0, |                     'total_distance': 10.0, | ||||||
|                     'total_duration': 3456, |                     'total_duration': 3456, | ||||||
|                 } |                 } | ||||||
| @@ -516,6 +580,8 @@ class TestGetStatsByTime(ApiTestCaseMixin): | |||||||
|             '2017-12-31': { |             '2017-12-31': { | ||||||
|                 '1': { |                 '1': { | ||||||
|                     'nb_workouts': 1, |                     'nb_workouts': 1, | ||||||
|  |                     'total_ascent': 80.0, | ||||||
|  |                     'total_descent': 100.0, | ||||||
|                     'total_distance': 10.0, |                     'total_distance': 10.0, | ||||||
|                     'total_duration': 1024, |                     'total_duration': 1024, | ||||||
|                 } |                 } | ||||||
| @@ -523,6 +589,8 @@ class TestGetStatsByTime(ApiTestCaseMixin): | |||||||
|             '2018-02-18': { |             '2018-02-18': { | ||||||
|                 '1': { |                 '1': { | ||||||
|                     'nb_workouts': 2, |                     'nb_workouts': 2, | ||||||
|  |                     'total_ascent': 220.0, | ||||||
|  |                     'total_descent': 380.0, | ||||||
|                     'total_distance': 11.0, |                     'total_distance': 11.0, | ||||||
|                     'total_duration': 1600, |                     'total_duration': 1600, | ||||||
|                 } |                 } | ||||||
| @@ -530,11 +598,15 @@ class TestGetStatsByTime(ApiTestCaseMixin): | |||||||
|             '2018-04-01': { |             '2018-04-01': { | ||||||
|                 '1': { |                 '1': { | ||||||
|                     'nb_workouts': 1, |                     'nb_workouts': 1, | ||||||
|  |                     'total_ascent': 40.0, | ||||||
|  |                     'total_descent': 20.0, | ||||||
|                     'total_distance': 8.0, |                     'total_distance': 8.0, | ||||||
|                     'total_duration': 6000, |                     'total_duration': 6000, | ||||||
|                 }, |                 }, | ||||||
|                 '2': { |                 '2': { | ||||||
|                     'nb_workouts': 1, |                     'nb_workouts': 1, | ||||||
|  |                     'total_ascent': 0.0, | ||||||
|  |                     'total_descent': 0.0, | ||||||
|                     'total_distance': 12.0, |                     'total_distance': 12.0, | ||||||
|                     'total_duration': 6000, |                     'total_duration': 6000, | ||||||
|                 }, |                 }, | ||||||
| @@ -542,6 +614,8 @@ class TestGetStatsByTime(ApiTestCaseMixin): | |||||||
|             '2018-05-06': { |             '2018-05-06': { | ||||||
|                 '1': { |                 '1': { | ||||||
|                     'nb_workouts': 1, |                     'nb_workouts': 1, | ||||||
|  |                     'total_ascent': 0.0, | ||||||
|  |                     'total_descent': 0.0, | ||||||
|                     'total_distance': 10.0, |                     'total_distance': 10.0, | ||||||
|                     'total_duration': 3000, |                     'total_duration': 3000, | ||||||
|                 } |                 } | ||||||
| @@ -571,11 +645,15 @@ class TestGetStatsByTime(ApiTestCaseMixin): | |||||||
|             '2018-04-01': { |             '2018-04-01': { | ||||||
|                 '1': { |                 '1': { | ||||||
|                     'nb_workouts': 1, |                     'nb_workouts': 1, | ||||||
|  |                     'total_ascent': 40.0, | ||||||
|  |                     'total_descent': 20.0, | ||||||
|                     'total_distance': 8.0, |                     'total_distance': 8.0, | ||||||
|                     'total_duration': 6000, |                     'total_duration': 6000, | ||||||
|                 }, |                 }, | ||||||
|                 '2': { |                 '2': { | ||||||
|                     'nb_workouts': 1, |                     'nb_workouts': 1, | ||||||
|  |                     'total_ascent': 0.0, | ||||||
|  |                     'total_descent': 0.0, | ||||||
|                     'total_distance': 12.0, |                     'total_distance': 12.0, | ||||||
|                     'total_duration': 6000, |                     'total_duration': 6000, | ||||||
|                 }, |                 }, | ||||||
| @@ -605,6 +683,8 @@ class TestGetStatsByTime(ApiTestCaseMixin): | |||||||
|             '2017-03-20': { |             '2017-03-20': { | ||||||
|                 '1': { |                 '1': { | ||||||
|                     'nb_workouts': 1, |                     'nb_workouts': 1, | ||||||
|  |                     'total_ascent': 120.0, | ||||||
|  |                     'total_descent': 200.0, | ||||||
|                     'total_distance': 5.0, |                     'total_distance': 5.0, | ||||||
|                     'total_duration': 1024, |                     'total_duration': 1024, | ||||||
|                 } |                 } | ||||||
| @@ -612,6 +692,8 @@ class TestGetStatsByTime(ApiTestCaseMixin): | |||||||
|             '2017-05-29': { |             '2017-05-29': { | ||||||
|                 '1': { |                 '1': { | ||||||
|                     'nb_workouts': 1, |                     'nb_workouts': 1, | ||||||
|  |                     'total_ascent': 100.0, | ||||||
|  |                     'total_descent': 80.0, | ||||||
|                     'total_distance': 10.0, |                     'total_distance': 10.0, | ||||||
|                     'total_duration': 3456, |                     'total_duration': 3456, | ||||||
|                 } |                 } | ||||||
| @@ -619,6 +701,8 @@ class TestGetStatsByTime(ApiTestCaseMixin): | |||||||
|             '2018-01-01': { |             '2018-01-01': { | ||||||
|                 '1': { |                 '1': { | ||||||
|                     'nb_workouts': 1, |                     'nb_workouts': 1, | ||||||
|  |                     'total_ascent': 80.0, | ||||||
|  |                     'total_descent': 100.0, | ||||||
|                     'total_distance': 10.0, |                     'total_distance': 10.0, | ||||||
|                     'total_duration': 1024, |                     'total_duration': 1024, | ||||||
|                 } |                 } | ||||||
| @@ -626,6 +710,8 @@ class TestGetStatsByTime(ApiTestCaseMixin): | |||||||
|             '2018-02-19': { |             '2018-02-19': { | ||||||
|                 '1': { |                 '1': { | ||||||
|                     'nb_workouts': 2, |                     'nb_workouts': 2, | ||||||
|  |                     'total_ascent': 220.0, | ||||||
|  |                     'total_descent': 380.0, | ||||||
|                     'total_distance': 11.0, |                     'total_distance': 11.0, | ||||||
|                     'total_duration': 1600, |                     'total_duration': 1600, | ||||||
|                 } |                 } | ||||||
| @@ -633,11 +719,15 @@ class TestGetStatsByTime(ApiTestCaseMixin): | |||||||
|             '2018-03-26': { |             '2018-03-26': { | ||||||
|                 '1': { |                 '1': { | ||||||
|                     'nb_workouts': 1, |                     'nb_workouts': 1, | ||||||
|  |                     'total_ascent': 40.0, | ||||||
|  |                     'total_descent': 20.0, | ||||||
|                     'total_distance': 8.0, |                     'total_distance': 8.0, | ||||||
|                     'total_duration': 6000, |                     'total_duration': 6000, | ||||||
|                 }, |                 }, | ||||||
|                 '2': { |                 '2': { | ||||||
|                     'nb_workouts': 1, |                     'nb_workouts': 1, | ||||||
|  |                     'total_ascent': 0.0, | ||||||
|  |                     'total_descent': 0.0, | ||||||
|                     'total_distance': 12.0, |                     'total_distance': 12.0, | ||||||
|                     'total_duration': 6000, |                     'total_duration': 6000, | ||||||
|                 }, |                 }, | ||||||
| @@ -645,6 +735,8 @@ class TestGetStatsByTime(ApiTestCaseMixin): | |||||||
|             '2018-05-07': { |             '2018-05-07': { | ||||||
|                 '1': { |                 '1': { | ||||||
|                     'nb_workouts': 1, |                     'nb_workouts': 1, | ||||||
|  |                     'total_ascent': 0.0, | ||||||
|  |                     'total_descent': 0.0, | ||||||
|                     'total_distance': 10.0, |                     'total_distance': 10.0, | ||||||
|                     'total_duration': 3000, |                     'total_duration': 3000, | ||||||
|                 } |                 } | ||||||
| @@ -674,11 +766,15 @@ class TestGetStatsByTime(ApiTestCaseMixin): | |||||||
|             '2018-03-26': { |             '2018-03-26': { | ||||||
|                 '1': { |                 '1': { | ||||||
|                     'nb_workouts': 1, |                     'nb_workouts': 1, | ||||||
|  |                     'total_ascent': 40.0, | ||||||
|  |                     'total_descent': 20.0, | ||||||
|                     'total_distance': 8.0, |                     'total_distance': 8.0, | ||||||
|                     'total_duration': 6000, |                     'total_duration': 6000, | ||||||
|                 }, |                 }, | ||||||
|                 '2': { |                 '2': { | ||||||
|                     'nb_workouts': 1, |                     'nb_workouts': 1, | ||||||
|  |                     'total_ascent': 0.0, | ||||||
|  |                     'total_descent': 0.0, | ||||||
|                     'total_distance': 12.0, |                     'total_distance': 12.0, | ||||||
|                     'total_duration': 6000, |                     'total_duration': 6000, | ||||||
|                 }, |                 }, | ||||||
| @@ -709,11 +805,15 @@ class TestGetStatsBySport(ApiTestCaseMixin): | |||||||
|         assert data['data']['statistics'] == { |         assert data['data']['statistics'] == { | ||||||
|             '1': { |             '1': { | ||||||
|                 'nb_workouts': 7, |                 'nb_workouts': 7, | ||||||
|  |                 'total_ascent': 560.0, | ||||||
|  |                 'total_descent': 780.0, | ||||||
|                 'total_distance': 54.0, |                 'total_distance': 54.0, | ||||||
|                 'total_duration': 16104, |                 'total_duration': 16104, | ||||||
|             }, |             }, | ||||||
|             '2': { |             '2': { | ||||||
|                 'nb_workouts': 1, |                 'nb_workouts': 1, | ||||||
|  |                 'total_ascent': 0.0, | ||||||
|  |                 'total_descent': 0.0, | ||||||
|                 'total_distance': 12.0, |                 'total_distance': 12.0, | ||||||
|                 'total_duration': 6000, |                 'total_duration': 6000, | ||||||
|             }, |             }, | ||||||
| @@ -741,6 +841,8 @@ class TestGetStatsBySport(ApiTestCaseMixin): | |||||||
|         assert data['data']['statistics'] == { |         assert data['data']['statistics'] == { | ||||||
|             '1': { |             '1': { | ||||||
|                 'nb_workouts': 7, |                 'nb_workouts': 7, | ||||||
|  |                 'total_ascent': 560.0, | ||||||
|  |                 'total_descent': 780.0, | ||||||
|                 'total_distance': 54.0, |                 'total_distance': 54.0, | ||||||
|                 'total_duration': 16104, |                 'total_duration': 16104, | ||||||
|             } |             } | ||||||
|   | |||||||
| @@ -77,9 +77,11 @@ def get_workouts( | |||||||
|                 workouts_list_by_sport[sport_id][ |                 workouts_list_by_sport[sport_id][ | ||||||
|                     'total_duration' |                     'total_duration' | ||||||
|                 ] += convert_timedelta_to_integer(workout.moving) |                 ] += convert_timedelta_to_integer(workout.moving) | ||||||
|  |                 if workout.ascent: | ||||||
|                     workouts_list_by_sport[sport_id]['total_ascent'] += float( |                     workouts_list_by_sport[sport_id]['total_ascent'] += float( | ||||||
|                         workout.ascent |                         workout.ascent | ||||||
|                     ) |                     ) | ||||||
|  |                 if workout.descent: | ||||||
|                     workouts_list_by_sport[sport_id]['total_descent'] += float( |                     workouts_list_by_sport[sport_id]['total_descent'] += float( | ||||||
|                         workout.descent |                         workout.descent | ||||||
|                     ) |                     ) | ||||||
| @@ -133,11 +135,11 @@ def get_workouts( | |||||||
|                 if workout.ascent: |                 if workout.ascent: | ||||||
|                     workouts_list_by_time[time_period][sport_id][ |                     workouts_list_by_time[time_period][sport_id][ | ||||||
|                         'total_ascent' |                         'total_ascent' | ||||||
|                     ] += float(workout.ascent / 1000) |                     ] += float(workout.ascent) | ||||||
|                 if workout.descent: |                 if workout.descent: | ||||||
|                     workouts_list_by_time[time_period][sport_id][ |                     workouts_list_by_time[time_period][sport_id][ | ||||||
|                         'total_descent' |                         'total_descent' | ||||||
|                     ] += float(workout.descent / 1000) |                     ] += float(workout.descent) | ||||||
|         return { |         return { | ||||||
|             'status': 'success', |             'status': 'success', | ||||||
|             'data': { |             'data': { | ||||||
| @@ -188,6 +190,8 @@ def get_workouts_by_time( | |||||||
|             "2017": { |             "2017": { | ||||||
|               "3": { |               "3": { | ||||||
|                 "nb_workouts": 2, |                 "nb_workouts": 2, | ||||||
|  |                 "total_ascent": 203.0, | ||||||
|  |                 "total_ascent": 156.0, | ||||||
|                 "total_distance": 15.282, |                 "total_distance": 15.282, | ||||||
|                 "total_duration": 12341 |                 "total_duration": 12341 | ||||||
|               } |               } | ||||||
| @@ -195,11 +199,15 @@ def get_workouts_by_time( | |||||||
|             "2019": { |             "2019": { | ||||||
|               "1": { |               "1": { | ||||||
|                 "nb_workouts": 3, |                 "nb_workouts": 3, | ||||||
|  |                 "total_ascent": 150.0, | ||||||
|  |                 "total_ascent": 178.0, | ||||||
|                 "total_distance": 47, |                 "total_distance": 47, | ||||||
|                 "total_duration": 9960 |                 "total_duration": 9960 | ||||||
|               }, |               }, | ||||||
|               "2": { |               "2": { | ||||||
|                 "nb_workouts": 1, |                 "nb_workouts": 1, | ||||||
|  |                 "total_ascent": 46.0, | ||||||
|  |                 "total_ascent": 78.0, | ||||||
|                 "total_distance": 5.613, |                 "total_distance": 5.613, | ||||||
|                 "total_duration": 1267 |                 "total_duration": 1267 | ||||||
|               } |               } | ||||||
| @@ -285,16 +293,22 @@ def get_workouts_by_sport( | |||||||
|           "statistics": { |           "statistics": { | ||||||
|             "1": { |             "1": { | ||||||
|               "nb_workouts": 3, |               "nb_workouts": 3, | ||||||
|  |               "total_ascent": 150.0, | ||||||
|  |               "total_ascent": 178.0, | ||||||
|               "total_distance": 47, |               "total_distance": 47, | ||||||
|               "total_duration": 9960 |               "total_duration": 9960 | ||||||
|             }, |             }, | ||||||
|             "2": { |             "2": { | ||||||
|               "nb_workouts": 1, |               "nb_workouts": 1, | ||||||
|  |               "total_ascent": 46.0, | ||||||
|  |               "total_ascent": 78.0, | ||||||
|               "total_distance": 5.613, |               "total_distance": 5.613, | ||||||
|               "total_duration": 1267 |               "total_duration": 1267 | ||||||
|             }, |             }, | ||||||
|             "3": { |             "3": { | ||||||
|               "nb_workouts": 2, |               "nb_workouts": 2, | ||||||
|  |               "total_ascent": 203.0, | ||||||
|  |               "total_ascent": 156.0, | ||||||
|               "total_distance": 15.282, |               "total_distance": 15.282, | ||||||
|               "total_duration": 12341 |               "total_duration": 12341 | ||||||
|             } |             } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user