more work on serializing tags

This commit is contained in:
Sam
2021-01-26 10:58:57 +00:00
parent e42559bfbe
commit 0e5aee73c3
4 changed files with 12 additions and 14 deletions

View File

@@ -3,6 +3,7 @@ from companies.models import Company
class CompanySerializer(serializers.ModelSerializer): class CompanySerializer(serializers.ModelSerializer):
class Meta: class Meta:
model = Company model = Company
exclude = ['created', 'updated', 'creator'] exclude = ['created', 'updated', 'creator']

View File

@@ -6,7 +6,7 @@ from products.models import Product
from utils.tag_serializers import SingleTagSerializerField, CustomTagSerializer from utils.tag_serializers import SingleTagSerializerField, CustomTagSerializer
class ProductSerializer(CustomTagSerializer): class ProductSerializer(TaggitSerializer, serializers.ModelSerializer):
tags = TagListSerializerField(required=False) tags = TagListSerializerField(required=False)
category = SingleTagSerializerField(required=False) # main tag category category = SingleTagSerializerField(required=False) # main tag category

View File

@@ -8,6 +8,7 @@ from django.utils import timezone
from rest_framework.test import APITestCase from rest_framework.test import APITestCase
from rest_framework import status from rest_framework import status
from companies.factories import CompanyFactory
from products.factories import ProductFactory from products.factories import ProductFactory
from products.models import Product from products.models import Product
@@ -101,12 +102,12 @@ class ProductViewSetTest(APITestCase):
"""Regular logged-in user can create new instance """Regular logged-in user can create new instance
""" """
# Define request data # Define request data
company = CompanyFactory()
data = { data = {
'company': None, 'company': company.id,
'sku': 'qwerewq', 'sku': 'qwerewq',
'name': 'qwerewq', 'name': 'qwerewq',
'description': 'qwerewq', 'description': 'qwerewq',
'image': None,
'url': 'http://qwerewq.com', 'url': 'http://qwerewq.com',
'price': '12.21', 'price': '12.21',
'shipping_cost': '21.12', 'shipping_cost': '21.12',
@@ -128,7 +129,6 @@ class ProductViewSetTest(APITestCase):
# Query endpoint # Query endpoint
response = self.client.post(self.endpoint, data=data, format='json') response = self.client.post(self.endpoint, data=data, format='json')
# Assert endpoint returns created status # Assert endpoint returns created status
self.assertEqual(response.status_code, status.HTTP_201_CREATED) self.assertEqual(response.status_code, status.HTTP_201_CREATED)
@@ -145,8 +145,9 @@ class ProductViewSetTest(APITestCase):
instance.save() instance.save()
# Define request data # Define request data
company = CompanyFactory()
data = { data = {
'company': None, 'company': company.id,
'sku': 'qwerewq', 'sku': 'qwerewq',
'name': 'qwerewq', 'name': 'qwerewq',
'description': 'qwerewq', 'description': 'qwerewq',
@@ -173,7 +174,7 @@ class ProductViewSetTest(APITestCase):
# Query endpoint # Query endpoint
url = self.endpoint + f'{instance.pk}/' url = self.endpoint + f'{instance.pk}/'
response = self.client.put(url, data, format='json') response = self.client.put(url, data, format='json')
import ipdb; ipdb.set_trace()
# Assert endpoint returns OK code # Assert endpoint returns OK code
self.assertEqual(response.status_code, status.HTTP_200_OK) self.assertEqual(response.status_code, status.HTTP_200_OK)

View File

@@ -47,16 +47,11 @@ class SingleTagSerializerField(serializers.Field):
return value return value
class CustomTagSerializer(serializers.ModelSerializer): class CustomTagSerializer(serializers.Serializer):
""" """
Differentiate between tags and single-tags Differentiate between tags and single-tags
""" """
def __init__(self, instance=None, data='', **kwargs):
self.serializer_field_mapping[SingleTagSerializerField] = CharField
self.serializer_field_mapping[TagListSerializerField] = ListField
super(CustomTagSerializer, self).__init__(instance, data, **kwargs)
def create(self, validated_data): def create(self, validated_data):
to_be_tagged, validated_data = self._pop_tags(validated_data) to_be_tagged, validated_data = self._pop_tags(validated_data)
@@ -149,8 +144,9 @@ class CustomTagSerializer(serializers.ModelSerializer):
def _pop_tags(self, validated_data): def _pop_tags(self, validated_data):
to_be_tagged = {} to_be_tagged = {}
for key in self.serializer_field_mapping.keys():
field = self.serializer_field_mapping[key] for key in self.fields.keys():
field = self.fields[key]
if isinstance(field, TagListSerializerField): if isinstance(field, TagListSerializerField):
if key in validated_data: if key in validated_data:
to_be_tagged[key] = validated_data.pop(key) to_be_tagged[key] = validated_data.pop(key)