Merge branch 'develop' into feature/bo-endpoints

# Conflicts:
#	apps/product/serializers/common.py
This commit is contained in:
Anatoly 2019-11-13 14:48:44 +03:00
commit 23a1af1870
9 changed files with 275 additions and 21 deletions

View File

@ -1,9 +1,8 @@
from transfer.serializers.notification import SubscriberSerializer
from notification.models import Subscriber
from transfer.models import EmailAddresses
from django.db.models import Value, IntegerField, F
from pprint import pprint
from transfer.models import EmailAddresses
from transfer.serializers.notification import SubscriberSerializer
def transfer_subscriber():
queryset = EmailAddresses.objects.filter(state="usable")
@ -16,6 +15,10 @@ def transfer_subscriber():
pprint(f"News serializer errors: {serialized_data.errors}")
def transfer_newsletter_subscriber():
pass
data_types = {
"subscriber": [transfer_subscriber]
}

View File

@ -27,8 +27,7 @@ class Command(BaseCommand):
def add_category_tag(self):
objects = []
for c in tqdm(self.category_sql(), desc='Add category tags'):
categories = TagCategory.objects.filter(index_name=c.category,
value_type=c.value_type
categories = TagCategory.objects.filter(index_name=c.category
)
if not categories.exists():
objects.append(
@ -91,8 +90,9 @@ class Command(BaseCommand):
tag.filter(lower_value=t.tag_value, category=category)
products = Product.objects.filter(old_id=t.product_id)
if products.exists():
products.tags.add(tag)
products.save()
for p in products:
p.tags.add(*list(tag))
p.save()
self.stdout.write(self.style.WARNING(f'Add or get tag objects.'))
@ -112,5 +112,5 @@ class Command(BaseCommand):
def handle(self, *args, **kwargs):
self.add_category_tag()
self.add_tag()
self.check_tag()
self.add_product_tag()
self.check_tag()

View File

@ -89,6 +89,8 @@ class ProductBaseSerializer(serializers.ModelSerializer):
subtypes = ProductSubTypeBaseSerializer(many=True, read_only=True)
establishment_detail = EstablishmentShortSerializer(source='establishment', read_only=True)
tags = ProductTagSerializer(source='related_tags', many=True, read_only=True)
wine_region = WineRegionBaseSerializer(read_only=True)
wine_colors = TagBaseSerializer(many=True, read_only=True)
preview_image_url = serializers.URLField(source='preview_main_image_url',
allow_null=True,
read_only=True)
@ -107,6 +109,8 @@ class ProductBaseSerializer(serializers.ModelSerializer):
'vintage',
'tags',
'preview_image_url',
'wine_region',
'wine_colors',
]
@ -117,9 +121,7 @@ class ProductDetailSerializer(ProductBaseSerializer):
awards = AwardSerializer(many=True, read_only=True)
classifications = ProductClassificationBaseSerializer(many=True, read_only=True)
standards = ProductStandardBaseSerializer(many=True, read_only=True)
wine_region = WineRegionBaseSerializer(read_only=True)
wine_sub_region = WineSubRegionBaseSerializer(read_only=True)
wine_colors = TagBaseSerializer(many=True, read_only=True)
bottles_produced = TagBaseSerializer(many=True, read_only=True)
sugar_contents = TagBaseSerializer(many=True, read_only=True)
image_url = serializers.ImageField(source='main_image_url',
@ -133,9 +135,7 @@ class ProductDetailSerializer(ProductBaseSerializer):
'awards',
'classifications',
'standards',
'wine_region',
'wine_sub_region',
'wine_colors',
'bottles_produced',
'sugar_contents',
'image_url',

View File

@ -1,5 +1,6 @@
from rest_framework import serializers
from review.models import Review
from review.models import Review, Inquiries, GridItems
class ReviewBaseSerializer(serializers.ModelSerializer):
@ -27,3 +28,41 @@ class ReviewShortSerializer(ReviewBaseSerializer):
fields = (
'text_translated',
)
class InquiriesBaseSerializer(serializers.ModelSerializer):
"""Serializer for model Inquiries."""
class Meta:
model = Inquiries
fields = (
'id',
'review',
'comment',
'final_comment',
'mark',
'attachment_file',
'author',
'bill_file',
'price',
'moment',
'gallery',
'decibels',
'nomination',
'nominee',
'published',
)
class GridItemsBaseSerializer(serializers.ModelSerializer):
"""Serializer for model GridItems."""
class Meta:
model = GridItems
fields = (
'id',
'inquiry',
'sub_name',
'name',
'value',
'desc',
'dish_title',
)

View File

@ -1,3 +1,134 @@
from django.test import TestCase
from http.cookies import SimpleCookie
# Create your tests here.
from rest_framework import status
from rest_framework.test import APITestCase
from account.models import User
from location.models import Country
from review.models import Review, Inquiries, GridItems
from translation.models import Language
class BaseTestCase(APITestCase):
def setUp(self):
self.username = 'test_user'
self.password = 'test_user_password'
self.email = 'test_user@mail.com'
self.user = User.objects.create_user(
username=self.username,
email=self.email,
password=self.password,
)
tokens = User.create_jwt_tokens(self.user)
self.client.cookies = SimpleCookie({
'access_token': tokens.get('access_token'),
'refresh_token': tokens.get('refresh_token'),
})
self.lang = Language.objects.create(
title='Russia',
locale='ru-RU'
)
self.country_ru = Country.objects.create(
name={'en-GB': 'Russian'},
code='RU',
)
self.test_review = Review.objects.create(
reviewer=self.user,
status=Review.READY,
language=self.lang,
vintage=2020,
country=self.country_ru,
text={'en-GB': 'Text review'},
created_by=self.user,
modified_by=self.user,
object_id=1,
content_type_id=1,
)
self.test_inquiry = Inquiries.objects.create(
review=self.test_review,
author=self.user,
comment='Test comment',
)
self.test_grid = GridItems.objects.create(
inquiry=self.test_inquiry,
name='Test name',
)
class InquiriesTestCase(BaseTestCase):
def setUp(self):
super().setUp()
def test_inquiry_list(self):
response = self.client.get('/api/back/review/inquiries/')
self.assertEqual(response.status_code, status.HTTP_200_OK)
def test_inquiry_list_by_review_id(self):
response = self.client.get(f'/api/back/review/{self.test_review.id}/inquiries/')
self.assertEqual(response.status_code, status.HTTP_200_OK)
def test_inquiry_post(self):
test_inquiry = {
'review': self.test_review.pk,
'author': self.user.pk,
'comment': 'New test comment',
}
response = self.client.post('/api/back/review/inquiries/', data=test_inquiry)
self.assertEqual(response.status_code, status.HTTP_201_CREATED)
def test_inquiry_detail(self):
response = self.client.get(f'/api/back/review/inquiries/{self.test_inquiry.id}/')
self.assertEqual(response.status_code, status.HTTP_200_OK)
def test_inquiry_detail_put(self):
data = {
'id': self.test_inquiry.id,
'review': self.test_review.pk,
'author': self.user.pk,
'comment': 'New test comment 2',
}
response = self.client.put(f'/api/back/review/inquiries/{self.test_inquiry.id}/', data=data)
self.assertEqual(response.status_code, status.HTTP_200_OK)
class GridItemsTestCase(BaseTestCase):
def setUp(self):
super().setUp()
def test_grid_list(self):
response = self.client.get('/api/back/review/inquiries/grid/')
self.assertEqual(response.status_code, status.HTTP_200_OK)
def test_grid_list_by_inquiry_id(self):
response = self.client.get(f'/api/back/review/inquiries/{self.test_inquiry.id}/grid/')
self.assertEqual(response.status_code, status.HTTP_200_OK)
def test_grid_post(self):
test_grid = {
'inquiry': self.test_inquiry.pk,
'name': 'New test name',
}
response = self.client.post('/api/back/review/inquiries/grid/', data=test_grid)
self.assertEqual(response.status_code, status.HTTP_201_CREATED)
def test_grid_detail(self):
response = self.client.get(f'/api/back/review/inquiries/grid/{self.test_grid.id}/')
self.assertEqual(response.status_code, status.HTTP_200_OK)
def test_grid_detail_put(self):
data = {
'id': self.test_grid.id,
'inquiry': self.test_inquiry.pk,
'name': 'New test name 2',
}
response = self.client.put(f'/api/back/review/inquiries/grid/{self.test_inquiry.id}/', data=data)
self.assertEqual(response.status_code, status.HTTP_200_OK)

View File

@ -8,4 +8,10 @@ app_name = 'review'
urlpatterns = [
path('', views.ReviewLstView.as_view(), name='review-list-create'),
path('<int:id>/', views.ReviewRUDView.as_view(), name='review-crud'),
path('<int:review_id>/inquiries/', views.InquiriesLstView.as_view(), name='inquiries-list'),
path('inquiries/', views.InquiriesLstView.as_view(), name='inquiries-list-create'),
path('inquiries/<int:id>/', views.InquiriesRUDView.as_view(), name='inquiries-crud'),
path('inquiries/<int:inquiry_id>/grid/', views.GridItemsLstView.as_view(), name='grid-list-create'),
path('inquiries/grid/', views.GridItemsLstView.as_view(), name='grid-list-create'),
path('inquiries/grid/<int:id>/', views.GridItemsRUDView.as_view(), name='grid-crud'),
]

View File

@ -1,6 +1,7 @@
from rest_framework import generics, permissions
from review import serializers
from review import models
from review import serializers
from utils.permissions import IsReviewerManager, IsRestaurantReviewer
@ -8,12 +9,55 @@ class ReviewLstView(generics.ListCreateAPIView):
"""Comment list create view."""
serializer_class = serializers.ReviewBaseSerializer
queryset = models.Review.objects.all()
permission_classes = [permissions.IsAuthenticatedOrReadOnly,]
permission_classes = [permissions.IsAuthenticatedOrReadOnly, ]
class ReviewRUDView(generics.RetrieveUpdateDestroyAPIView):
"""Comment RUD view."""
serializer_class = serializers.ReviewBaseSerializer
queryset = models.Review.objects.all()
permission_classes = [IsReviewerManager|IsRestaurantReviewer]
permission_classes = [IsReviewerManager | IsRestaurantReviewer]
lookup_field = 'id'
class InquiriesLstView(generics.ListCreateAPIView):
"""Inquiries list create view."""
serializer_class = serializers.InquiriesBaseSerializer
queryset = models.Inquiries.objects.all()
permission_classes = (permissions.IsAuthenticatedOrReadOnly,)
def get_queryset(self):
review_id = self.kwargs.get('review_id')
if review_id:
return super().get_queryset().filter(review_id=review_id)
return super().get_queryset()
class InquiriesRUDView(generics.RetrieveUpdateDestroyAPIView):
"""Inquiries RUD view."""
serializer_class = serializers.InquiriesBaseSerializer
queryset = models.Inquiries.objects.all()
permission_classes = (permissions.IsAuthenticatedOrReadOnly,)
lookup_field = 'id'
class GridItemsLstView(generics.ListCreateAPIView):
"""GridItems list create view."""
serializer_class = serializers.GridItemsBaseSerializer
queryset = models.GridItems.objects.all()
permission_classes = (permissions.IsAuthenticatedOrReadOnly,)
def get_queryset(self):
inquiry_id = self.kwargs.get('inquiry_id')
if inquiry_id:
return super().get_queryset().filter(inquiry_id=inquiry_id)
return super().get_queryset()
class GridItemsRUDView(generics.RetrieveUpdateDestroyAPIView):
"""GridItems RUD view."""
serializer_class = serializers.GridItemsBaseSerializer
queryset = models.GridItems.objects.all()
permission_classes = (permissions.IsAuthenticatedOrReadOnly,)
lookup_field = 'id'

View File

@ -0,0 +1,18 @@
# Generated by Django 2.2.7 on 2019-11-13 09:30
from django.db import migrations, models
class Migration(migrations.Migration):
dependencies = [
('tag', '0012_merge_20191112_1552'),
]
operations = [
migrations.AlterField(
model_name='tagcategory',
name='value_type',
field=models.CharField(choices=[('string', 'string'), ('list', 'list'), ('integer', 'integer'), ('float', 'float'), ('percentage', 'percentage')], default='list', max_length=255, verbose_name='value type'),
),
]

View File

@ -1156,7 +1156,6 @@ class GridItems(MigrateMixin):
class Assemblages(MigrateMixin):
using = 'legacy'
percent = models.FloatField()
@ -1169,7 +1168,6 @@ class Assemblages(MigrateMixin):
class Cepages(MigrateMixin):
using = 'legacy'
name = models.CharField(max_length=255)
@ -1177,3 +1175,18 @@ class Cepages(MigrateMixin):
class Meta:
managed = False
db_table = 'cepages'
class NewsletterSubscriber(MigrateMixin):
using = 'legacy'
site = models.ForeignKey(Sites, models.DO_NOTHING, blank=True, null=True)
email_address = models.ForeignKey(EmailAddresses, models.DO_NOTHING, blank=True, null=True)
state = models.CharField(max_length=255, blank=True, null=True)
consent_at = models.DateTimeField()
created_at = models.DateTimeField()
updated_at = models.DateTimeField()
class Meta:
managed = False
db_table = 'newsletter_subscriber'