diff --git a/ofu_app/__init__.py b/ofu_app/__init__.py new file mode 100644 index 0000000..e69de29 diff --git a/ofu_app/apps/food/api/serializers.py b/ofu_app/apps/food/api/serializers.py index b48d4e2..98f2cfc 100644 --- a/ofu_app/apps/food/api/serializers.py +++ b/ofu_app/apps/food/api/serializers.py @@ -1,6 +1,6 @@ from rest_framework import serializers -from apps.food.models import Menu, SingleFood, HappyHour, Allergene, UserFoodImage +from apps.food.models import Menu, SingleFood, HappyHour, Allergene, UserFoodImage, FoodImage class UserFoodImageSerializer(serializers.HyperlinkedModelSerializer): @@ -9,6 +9,12 @@ class UserFoodImageSerializer(serializers.HyperlinkedModelSerializer): fields = ('id', 'image_image', 'image_thumb') +class FoodImageSerializer(serializers.HyperlinkedModelSerializer): + class Meta: + model = FoodImage + fields = ('id', 'image', 'thumb') + + class AllergensSerializer(serializers.HyperlinkedModelSerializer): class Meta: model = Allergene @@ -17,7 +23,7 @@ class AllergensSerializer(serializers.HyperlinkedModelSerializer): class SingleFoodSerializer(serializers.HyperlinkedModelSerializer): allergens = AllergensSerializer(many=True, read_only=True) - image = UserFoodImageSerializer(many=True, read_only=True) + image = FoodImageSerializer(many=False, read_only=True) class Meta: model = SingleFood diff --git a/ofu_app/apps/food/api/urls.py b/ofu_app/apps/food/api/urls.py index 5cd1457..66bcd5b 100644 --- a/ofu_app/apps/food/api/urls.py +++ b/ofu_app/apps/food/api/urls.py @@ -19,15 +19,15 @@ from apps.food.models import Menu urlpatterns = [ # API Version 1.1 - url(r'^food/$', api_views.FoodViewSetV1_1.as_view({'get': 'list'})), + url(r'^food/$', api_views.FoodViewSetV1_1.as_view({'get': 'list'}), name='api-v1_1-food-all'), url(r'^food/(?P' + Menu.FEKI + '|' + Menu.MARKUSPLATZ + '|' + Menu.ERBA + '|' + Menu.AUSTRASSE + ')/$', - api_views.FoodViewSetV1_1.as_view({'get': 'list'})), + api_views.FoodViewSetV1_1.as_view({'get': 'list'}), name='api-v1_1-food-location'), url(r'food/(?P[0-9]{4})/(?P[0-9]{2})/(?P[0-9]{2})/$', - api_views.FoodViewSetV1_1.as_view({'get': 'list'})), + api_views.FoodViewSetV1_1.as_view({'get': 'list'}), name='api-v1_1-food-date'), url( r'food/(?P' + Menu.FEKI + '|' + Menu.MARKUSPLATZ + '|' + Menu.ERBA + '|' + Menu.AUSTRASSE + ')/(?P[0-9]{4})/(?P[0-9]{2})/(?P[0-9]{2})/$', - api_views.FoodViewSetV1_1.as_view({'get': 'list'})), - url(r'food/today/$', api_views.FoodViewSetV1_1.as_view({'get': 'list'})), - url(r'food/week/$', api_views.FoodViewSetV1_1.as_view({'get': 'list'})), - url(r'happy-hour', api_views.HappyHourViewSet.as_view({'get': 'list'})), + api_views.FoodViewSetV1_1.as_view({'get': 'list'}), name='api-v1_1-food-location-date'), + url(r'food/today/$', api_views.FoodViewSetV1_1.as_view({'get': 'list'}), name='api-v1_1-food-today'), + url(r'food/week/$', api_views.FoodViewSetV1_1.as_view({'get': 'list'}), name='api-v1_1-food-week'), + url(r'happy-hour', api_views.HappyHourViewSet.as_view({'get': 'list'}), name='api-v1_1-happy-hour-all'), ] diff --git a/ofu_app/apps/food/tests/__init__.py b/ofu_app/apps/food/tests/__init__.py new file mode 100644 index 0000000..e69de29 diff --git a/ofu_app/apps/food/tests/tests_api.py b/ofu_app/apps/food/tests/tests_api.py new file mode 100644 index 0000000..ce2bdbc --- /dev/null +++ b/ofu_app/apps/food/tests/tests_api.py @@ -0,0 +1,113 @@ +# -*- coding: utf-8 -*- +from __future__ import unicode_literals + +from django.test import TestCase +from django.urls import reverse +from apps.food.models import SingleFood, Menu +from apps.food.api.serializers import MenuSerializer +from rest_framework import status +from rest_framework.test import APIRequestFactory + +from datetime import datetime + + +# Create your tests here. + +class SingleFood_Scope(TestCase): + def setUp(self): + self.singlefood_1 = SingleFood.objects.create(name="testfood1") + self.singlefood_2 = SingleFood.objects.create(name="testfood2") + self.singlefood_3 = SingleFood.objects.create(name="testfood3") + self.singlefood_4 = SingleFood.objects.create(name="testfood4") + self.singlefood_5 = SingleFood.objects.create(name="testfood5") + self.singlefood_6 = SingleFood.objects.create(name="testfood6") + self.menu_1 = Menu.objects.create(date='2017-01-15', location=Menu.ERBA) + self.menu_1.menu.add(self.singlefood_1) + self.menu_1.menu.add(self.singlefood_2) + self.menu_1.menu.add(self.singlefood_3) + self.menu_2 = Menu.objects.create(date='2017-01-10', location=Menu.FEKI) + self.menu_2.menu.add(self.singlefood_4) + self.menu_2.menu.add(self.singlefood_5) + self.menu_2.menu.add(self.singlefood_6) + + def test_get_food_root(self): + """ + Right response on /food/api/v1.1/food + """ + menus = Menu.objects.all() + serializer = MenuSerializer(menus, many=True) + response = self.client.get(reverse('api-v1_1-food-all')) + self.assertEqual(response.status_code, status.HTTP_200_OK) + self.assertEqual(response.data, serializer.data) + + def test_get_food_date_param(self): + """ + Right response on /food/api/v1.1/food/2017/02/15/ + """ + serializer = MenuSerializer(self.menu_2, many=False) + response_1 = self.client.get(reverse('api-v1_1-food-date', kwargs={'year': '2017', 'month': '01', 'day': '10'})) + self.assertEqual(response_1.status_code, 200) + self.assertEqual(response_1.data, [serializer.data]) + + serializer_2 = MenuSerializer(self.menu_1, many=False) + response_2 = self.client.get(reverse('api-v1_1-food-date', kwargs={'year': '2017', 'month': '01', 'day': '15'})) + self.assertEqual(response_2.status_code, 200) + self.assertEqual(response_2.data, [serializer_2.data]) + + def test_get_food_date_param_not_in_set(self): + """ + Right response on /food/api/v1.1/food/2017/02/15/ + """ + response_1 = self.client.get(reverse('api-v1_1-food-date', kwargs={'year': '2017', 'month': '01', 'day': '11'})) + self.assertEqual(response_1.status_code, 200) + self.assertEqual(response_1.data, []) + + def test_get_food_location_param(self): + """ + Right response on /food/api/v1.1/food/2017/02/15/ + """ + serializer_1 = MenuSerializer(self.menu_1, many=False) + response_1 = self.client.get(reverse('api-v1_1-food-location', kwargs={'location': Menu.ERBA})) + self.assertEqual(response_1.status_code, 200) + self.assertEqual(response_1.data, [serializer_1.data]) + + serializer_2 = MenuSerializer(self.menu_2, many=False) + response_2 = self.client.get(reverse('api-v1_1-food-location', kwargs={'location': Menu.FEKI})) + self.assertEqual(response_2.status_code, 200) + self.assertEqual(response_2.data, [serializer_2.data]) + + def test_get_food_location_param_not_in_set(self): + """ + Right response on /food/api/v1.1/food/2017/02/15/ + """ + response_1 = self.client.get(reverse('api-v1_1-food-location', kwargs={'location': Menu.AUSTRASSE})) + self.assertEqual(response_1.status_code, 200) + self.assertEqual(response_1.data, []) + + def test_get_food_location_date_param(self): + """ + Right response on /food/api/v1.1/food/2017/02/15/ + """ + + serializer = MenuSerializer(self.menu_2, many=False) + response = self.client.get(reverse('api-v1_1-food-location-date', + kwargs={'year': '2017', 'month': '01', 'day': '10', + 'location': Menu.FEKI})) + self.assertEqual(response.status_code, 200) + self.assertEqual(response.data, [serializer.data]) + + def test_get_food_location_date_param_not_in_set(self): + """ + Right response on /food/api/v1.1/food/2017/02/15/ + """ + response_1 = self.client.get(reverse('api-v1_1-food-location-date', + kwargs={'year': '2017', 'month': '01', 'day': '11', + 'location': Menu.FEKI})) + self.assertEqual(response_1.status_code, 200) + self.assertEqual(response_1.data, []) + + response_1 = self.client.get(reverse('api-v1_1-food-location-date', + kwargs={'year': '2017', 'month': '01', 'day': '10', + 'location': Menu.AUSTRASSE})) + self.assertEqual(response_1.status_code, 200) + self.assertEqual(response_1.data, []) diff --git a/ofu_app/apps/food/tests.py b/ofu_app/apps/food/tests/tests_model.py similarity index 93% rename from ofu_app/apps/food/tests.py rename to ofu_app/apps/food/tests/tests_model.py index 7c5a500..7c2aa3b 100644 --- a/ofu_app/apps/food/tests.py +++ b/ofu_app/apps/food/tests/tests_model.py @@ -8,7 +8,7 @@ from apps.food.models import SingleFood # Create your tests here. -class SingleFood_Created_Just_with_name(TestCase): +class SingleFood_Scope(TestCase): def setUp(self): SingleFood.objects.create(name="testfood") diff --git a/ofu_app/requirements.txt b/ofu_app/requirements.txt index 0f2cf6f..3953827 100644 --- a/ofu_app/requirements.txt +++ b/ofu_app/requirements.txt @@ -6,4 +6,5 @@ requests==2.18.4 beautifulsoup4==4.6.0 #psycopg2==2.7.3.2 xmltodict==0.11.0 +coverage==3.6