|
|
@@ -1,5 +1,3 @@
|
|
|
-from datetime import date
|
|
|
-
|
|
|
from django.contrib.contenttypes.models import ContentType
|
|
|
from django.urls import reverse
|
|
|
from rest_framework import status
|
|
|
@@ -7,7 +5,7 @@ from rest_framework import status
|
|
|
from dcim.forms import SiteCSVForm
|
|
|
from dcim.models import Site
|
|
|
from extras.choices import *
|
|
|
-from extras.models import CustomField, CustomFieldValue, CustomFieldChoice
|
|
|
+from extras.models import CustomField
|
|
|
from utilities.testing import APITestCase, TestCase
|
|
|
from virtualization.models import VirtualMachine
|
|
|
|
|
|
@@ -30,7 +28,7 @@ class CustomFieldTest(TestCase):
|
|
|
{'field_type': CustomFieldTypeChoices.TYPE_INTEGER, 'field_value': 42, 'empty_value': None},
|
|
|
{'field_type': CustomFieldTypeChoices.TYPE_BOOLEAN, 'field_value': True, 'empty_value': None},
|
|
|
{'field_type': CustomFieldTypeChoices.TYPE_BOOLEAN, 'field_value': False, 'empty_value': None},
|
|
|
- {'field_type': CustomFieldTypeChoices.TYPE_DATE, 'field_value': date(2016, 6, 23), 'empty_value': None},
|
|
|
+ {'field_type': CustomFieldTypeChoices.TYPE_DATE, 'field_value': '2016-06-23', 'empty_value': None},
|
|
|
{'field_type': CustomFieldTypeChoices.TYPE_URL, 'field_value': 'http://example.com/', 'empty_value': ''},
|
|
|
)
|
|
|
|
|
|
@@ -46,18 +44,18 @@ class CustomFieldTest(TestCase):
|
|
|
|
|
|
# Assign a value to the first Site
|
|
|
site = Site.objects.first()
|
|
|
- cfv = CustomFieldValue(field=cf, obj_type=obj_type, obj_id=site.id)
|
|
|
- cfv.value = data['field_value']
|
|
|
- cfv.save()
|
|
|
+ site.custom_field_data[cf.name] = data['field_value']
|
|
|
+ site.save()
|
|
|
|
|
|
# Retrieve the stored value
|
|
|
- cfv = CustomFieldValue.objects.filter(obj_type=obj_type, obj_id=site.pk).first()
|
|
|
- self.assertEqual(cfv.value, data['field_value'])
|
|
|
+ site.refresh_from_db()
|
|
|
+ self.assertEqual(site.custom_field_data[cf.name], data['field_value'])
|
|
|
|
|
|
# Delete the stored value
|
|
|
- cfv.value = data['empty_value']
|
|
|
- cfv.save()
|
|
|
- self.assertEqual(CustomFieldValue.objects.filter(obj_type=obj_type, obj_id=site.pk).count(), 0)
|
|
|
+ site.custom_field_data.pop(cf.name)
|
|
|
+ site.save()
|
|
|
+ site.refresh_from_db()
|
|
|
+ self.assertIsNone(site.custom_field_data.get(cf.name))
|
|
|
|
|
|
# Delete the custom field
|
|
|
cf.delete()
|
|
|
@@ -67,32 +65,30 @@ class CustomFieldTest(TestCase):
|
|
|
obj_type = ContentType.objects.get_for_model(Site)
|
|
|
|
|
|
# Create a custom field
|
|
|
- cf = CustomField(type=CustomFieldTypeChoices.TYPE_SELECT, name='my_field', required=False)
|
|
|
+ cf = CustomField(
|
|
|
+ type=CustomFieldTypeChoices.TYPE_SELECT,
|
|
|
+ name='my_field',
|
|
|
+ required=False,
|
|
|
+ choices=['Option A', 'Option B', 'Option C']
|
|
|
+ )
|
|
|
cf.save()
|
|
|
cf.obj_type.set([obj_type])
|
|
|
cf.save()
|
|
|
|
|
|
- # Create some choices for the field
|
|
|
- CustomFieldChoice.objects.bulk_create([
|
|
|
- CustomFieldChoice(field=cf, value='Option A'),
|
|
|
- CustomFieldChoice(field=cf, value='Option B'),
|
|
|
- CustomFieldChoice(field=cf, value='Option C'),
|
|
|
- ])
|
|
|
-
|
|
|
# Assign a value to the first Site
|
|
|
site = Site.objects.first()
|
|
|
- cfv = CustomFieldValue(field=cf, obj_type=obj_type, obj_id=site.id)
|
|
|
- cfv.value = cf.choices.first()
|
|
|
- cfv.save()
|
|
|
+ site.custom_field_data[cf.name] = 'Option A'
|
|
|
+ site.save()
|
|
|
|
|
|
# Retrieve the stored value
|
|
|
- cfv = CustomFieldValue.objects.filter(obj_type=obj_type, obj_id=site.pk).first()
|
|
|
- self.assertEqual(str(cfv.value), 'Option A')
|
|
|
+ site.refresh_from_db()
|
|
|
+ self.assertEqual(site.custom_field_data[cf.name], 'Option A')
|
|
|
|
|
|
# Delete the stored value
|
|
|
- cfv.value = None
|
|
|
- cfv.save()
|
|
|
- self.assertEqual(CustomFieldValue.objects.filter(obj_type=obj_type, obj_id=site.pk).count(), 0)
|
|
|
+ site.custom_field_data.pop(cf.name)
|
|
|
+ site.save()
|
|
|
+ site.refresh_from_db()
|
|
|
+ self.assertIsNone(site.custom_field_data.get(cf.name))
|
|
|
|
|
|
# Delete the custom field
|
|
|
cf.delete()
|
|
|
@@ -143,18 +139,10 @@ class CustomFieldAPITest(APITestCase):
|
|
|
cls.cf_url.obj_type.set([content_type])
|
|
|
|
|
|
# Select custom field
|
|
|
- cls.cf_select = CustomField(type=CustomFieldTypeChoices.TYPE_SELECT, name='choice_field')
|
|
|
+ cls.cf_select = CustomField(type=CustomFieldTypeChoices.TYPE_SELECT, name='choice_field', choices=['Foo', 'Bar', 'Baz'])
|
|
|
+ cls.cf_select.default = 'Foo'
|
|
|
cls.cf_select.save()
|
|
|
cls.cf_select.obj_type.set([content_type])
|
|
|
- cls.cf_select_choice1 = CustomFieldChoice(field=cls.cf_select, value='Foo')
|
|
|
- cls.cf_select_choice1.save()
|
|
|
- cls.cf_select_choice2 = CustomFieldChoice(field=cls.cf_select, value='Bar')
|
|
|
- cls.cf_select_choice2.save()
|
|
|
- cls.cf_select_choice3 = CustomFieldChoice(field=cls.cf_select, value='Baz')
|
|
|
- cls.cf_select_choice3.save()
|
|
|
-
|
|
|
- cls.cf_select.default = cls.cf_select_choice1.value
|
|
|
- cls.cf_select.save()
|
|
|
|
|
|
# Create some sites
|
|
|
cls.sites = (
|
|
|
@@ -164,20 +152,17 @@ class CustomFieldAPITest(APITestCase):
|
|
|
Site.objects.bulk_create(cls.sites)
|
|
|
|
|
|
# Assign custom field values for site 2
|
|
|
- site2_cfvs = {
|
|
|
- cls.cf_text: 'bar',
|
|
|
- cls.cf_integer: 456,
|
|
|
- cls.cf_boolean: True,
|
|
|
- cls.cf_date: '2020-01-02',
|
|
|
- cls.cf_url: 'http://example.com/2',
|
|
|
- cls.cf_select: cls.cf_select_choice2.pk,
|
|
|
+ cls.sites[1].custom_field_data = {
|
|
|
+ cls.cf_text.name: 'bar',
|
|
|
+ cls.cf_integer.name: 456,
|
|
|
+ cls.cf_boolean.name: True,
|
|
|
+ cls.cf_date.name: '2020-01-02',
|
|
|
+ cls.cf_url.name: 'http://example.com/2',
|
|
|
+ cls.cf_select.name: 'Bar',
|
|
|
}
|
|
|
- for field, value in site2_cfvs.items():
|
|
|
- cfv = CustomFieldValue(field=field, obj=cls.sites[1])
|
|
|
- cfv.value = value
|
|
|
- cfv.save()
|
|
|
+ cls.sites[1].save()
|
|
|
|
|
|
- def test_get_single_object_without_custom_field_values(self):
|
|
|
+ def test_get_single_object_without_custom_field_data(self):
|
|
|
"""
|
|
|
Validate that custom fields are present on an object even if it has no values defined.
|
|
|
"""
|
|
|
@@ -195,13 +180,11 @@ class CustomFieldAPITest(APITestCase):
|
|
|
'choice_field': None,
|
|
|
})
|
|
|
|
|
|
- def test_get_single_object_with_custom_field_values(self):
|
|
|
+ def test_get_single_object_with_custom_field_data(self):
|
|
|
"""
|
|
|
Validate that custom fields are present and correctly set for an object with values defined.
|
|
|
"""
|
|
|
- site2_cfvs = {
|
|
|
- cfv.field.name: cfv.value for cfv in self.sites[1].custom_field_values.all()
|
|
|
- }
|
|
|
+ site2_cfvs = self.sites[1].custom_field_data
|
|
|
url = reverse('dcim-api:site-detail', kwargs={'pk': self.sites[1].pk})
|
|
|
self.add_permissions('dcim.view_site')
|
|
|
|
|
|
@@ -212,7 +195,7 @@ class CustomFieldAPITest(APITestCase):
|
|
|
self.assertEqual(response.data['custom_fields']['boolean_field'], site2_cfvs['boolean_field'])
|
|
|
self.assertEqual(response.data['custom_fields']['date_field'], site2_cfvs['date_field'])
|
|
|
self.assertEqual(response.data['custom_fields']['url_field'], site2_cfvs['url_field'])
|
|
|
- self.assertEqual(response.data['custom_fields']['choice_field']['label'], self.cf_select_choice2.value)
|
|
|
+ self.assertEqual(response.data['custom_fields']['choice_field'], site2_cfvs['choice_field'])
|
|
|
|
|
|
def test_create_single_object_with_defaults(self):
|
|
|
"""
|
|
|
@@ -235,19 +218,16 @@ class CustomFieldAPITest(APITestCase):
|
|
|
self.assertEqual(response_cf['boolean_field'], self.cf_boolean.default)
|
|
|
self.assertEqual(response_cf['date_field'], self.cf_date.default)
|
|
|
self.assertEqual(response_cf['url_field'], self.cf_url.default)
|
|
|
- self.assertEqual(response_cf['choice_field'], self.cf_select_choice1.pk)
|
|
|
+ self.assertEqual(response_cf['choice_field'], self.cf_select.default)
|
|
|
|
|
|
# Validate database data
|
|
|
site = Site.objects.get(pk=response.data['id'])
|
|
|
- cfvs = {
|
|
|
- cfv.field.name: cfv.value for cfv in site.custom_field_values.all()
|
|
|
- }
|
|
|
- self.assertEqual(cfvs['text_field'], self.cf_text.default)
|
|
|
- self.assertEqual(cfvs['number_field'], self.cf_integer.default)
|
|
|
- self.assertEqual(cfvs['boolean_field'], self.cf_boolean.default)
|
|
|
- self.assertEqual(str(cfvs['date_field']), self.cf_date.default)
|
|
|
- self.assertEqual(cfvs['url_field'], self.cf_url.default)
|
|
|
- self.assertEqual(cfvs['choice_field'].pk, self.cf_select_choice1.pk)
|
|
|
+ self.assertEqual(site.custom_field_data['text_field'], self.cf_text.default)
|
|
|
+ self.assertEqual(site.custom_field_data['number_field'], self.cf_integer.default)
|
|
|
+ self.assertEqual(site.custom_field_data['boolean_field'], self.cf_boolean.default)
|
|
|
+ self.assertEqual(str(site.custom_field_data['date_field']), self.cf_date.default)
|
|
|
+ self.assertEqual(site.custom_field_data['url_field'], self.cf_url.default)
|
|
|
+ self.assertEqual(site.custom_field_data['choice_field'], self.cf_select.default)
|
|
|
|
|
|
def test_create_single_object_with_values(self):
|
|
|
"""
|
|
|
@@ -262,7 +242,7 @@ class CustomFieldAPITest(APITestCase):
|
|
|
'boolean_field': True,
|
|
|
'date_field': '2020-01-02',
|
|
|
'url_field': 'http://example.com/2',
|
|
|
- 'choice_field': self.cf_select_choice2.pk,
|
|
|
+ 'choice_field': 'Bar',
|
|
|
},
|
|
|
}
|
|
|
url = reverse('dcim-api:site-list')
|
|
|
@@ -283,15 +263,12 @@ class CustomFieldAPITest(APITestCase):
|
|
|
|
|
|
# Validate database data
|
|
|
site = Site.objects.get(pk=response.data['id'])
|
|
|
- cfvs = {
|
|
|
- cfv.field.name: cfv.value for cfv in site.custom_field_values.all()
|
|
|
- }
|
|
|
- self.assertEqual(cfvs['text_field'], data_cf['text_field'])
|
|
|
- self.assertEqual(cfvs['number_field'], data_cf['number_field'])
|
|
|
- self.assertEqual(cfvs['boolean_field'], data_cf['boolean_field'])
|
|
|
- self.assertEqual(str(cfvs['date_field']), data_cf['date_field'])
|
|
|
- self.assertEqual(cfvs['url_field'], data_cf['url_field'])
|
|
|
- self.assertEqual(cfvs['choice_field'].pk, data_cf['choice_field'])
|
|
|
+ self.assertEqual(site.custom_field_data['text_field'], data_cf['text_field'])
|
|
|
+ self.assertEqual(site.custom_field_data['number_field'], data_cf['number_field'])
|
|
|
+ self.assertEqual(site.custom_field_data['boolean_field'], data_cf['boolean_field'])
|
|
|
+ self.assertEqual(str(site.custom_field_data['date_field']), data_cf['date_field'])
|
|
|
+ self.assertEqual(site.custom_field_data['url_field'], data_cf['url_field'])
|
|
|
+ self.assertEqual(site.custom_field_data['choice_field'], data_cf['choice_field'])
|
|
|
|
|
|
def test_create_multiple_objects_with_defaults(self):
|
|
|
"""
|
|
|
@@ -328,19 +305,16 @@ class CustomFieldAPITest(APITestCase):
|
|
|
self.assertEqual(response_cf['boolean_field'], self.cf_boolean.default)
|
|
|
self.assertEqual(response_cf['date_field'], self.cf_date.default)
|
|
|
self.assertEqual(response_cf['url_field'], self.cf_url.default)
|
|
|
- self.assertEqual(response_cf['choice_field'], self.cf_select_choice1.pk)
|
|
|
+ self.assertEqual(response_cf['choice_field'], self.cf_select.default)
|
|
|
|
|
|
# Validate database data
|
|
|
site = Site.objects.get(pk=response.data[i]['id'])
|
|
|
- cfvs = {
|
|
|
- cfv.field.name: cfv.value for cfv in site.custom_field_values.all()
|
|
|
- }
|
|
|
- self.assertEqual(cfvs['text_field'], self.cf_text.default)
|
|
|
- self.assertEqual(cfvs['number_field'], self.cf_integer.default)
|
|
|
- self.assertEqual(cfvs['boolean_field'], self.cf_boolean.default)
|
|
|
- self.assertEqual(str(cfvs['date_field']), self.cf_date.default)
|
|
|
- self.assertEqual(cfvs['url_field'], self.cf_url.default)
|
|
|
- self.assertEqual(cfvs['choice_field'].pk, self.cf_select_choice1.pk)
|
|
|
+ self.assertEqual(site.custom_field_data['text_field'], self.cf_text.default)
|
|
|
+ self.assertEqual(site.custom_field_data['number_field'], self.cf_integer.default)
|
|
|
+ self.assertEqual(site.custom_field_data['boolean_field'], self.cf_boolean.default)
|
|
|
+ self.assertEqual(str(site.custom_field_data['date_field']), self.cf_date.default)
|
|
|
+ self.assertEqual(site.custom_field_data['url_field'], self.cf_url.default)
|
|
|
+ self.assertEqual(site.custom_field_data['choice_field'], self.cf_select.default)
|
|
|
|
|
|
def test_create_multiple_objects_with_values(self):
|
|
|
"""
|
|
|
@@ -352,7 +326,7 @@ class CustomFieldAPITest(APITestCase):
|
|
|
'boolean_field': True,
|
|
|
'date_field': '2020-01-02',
|
|
|
'url_field': 'http://example.com/2',
|
|
|
- 'choice_field': self.cf_select_choice2.pk,
|
|
|
+ 'choice_field': 'Bar',
|
|
|
}
|
|
|
data = (
|
|
|
{
|
|
|
@@ -391,24 +365,20 @@ class CustomFieldAPITest(APITestCase):
|
|
|
|
|
|
# Validate database data
|
|
|
site = Site.objects.get(pk=response.data[i]['id'])
|
|
|
- cfvs = {
|
|
|
- cfv.field.name: cfv.value for cfv in site.custom_field_values.all()
|
|
|
- }
|
|
|
- self.assertEqual(cfvs['text_field'], custom_field_data['text_field'])
|
|
|
- self.assertEqual(cfvs['number_field'], custom_field_data['number_field'])
|
|
|
- self.assertEqual(cfvs['boolean_field'], custom_field_data['boolean_field'])
|
|
|
- self.assertEqual(str(cfvs['date_field']), custom_field_data['date_field'])
|
|
|
- self.assertEqual(cfvs['url_field'], custom_field_data['url_field'])
|
|
|
- self.assertEqual(cfvs['choice_field'].pk, custom_field_data['choice_field'])
|
|
|
+ self.assertEqual(site.custom_field_data['text_field'], custom_field_data['text_field'])
|
|
|
+ self.assertEqual(site.custom_field_data['number_field'], custom_field_data['number_field'])
|
|
|
+ self.assertEqual(site.custom_field_data['boolean_field'], custom_field_data['boolean_field'])
|
|
|
+ self.assertEqual(str(site.custom_field_data['date_field']), custom_field_data['date_field'])
|
|
|
+ self.assertEqual(site.custom_field_data['url_field'], custom_field_data['url_field'])
|
|
|
+ self.assertEqual(site.custom_field_data['choice_field'], custom_field_data['choice_field'])
|
|
|
|
|
|
def test_update_single_object_with_values(self):
|
|
|
"""
|
|
|
Update an object with existing custom field values. Ensure that only the updated custom field values are
|
|
|
modified.
|
|
|
"""
|
|
|
- site2_original_cfvs = {
|
|
|
- cfv.field.name: cfv.value for cfv in self.sites[1].custom_field_values.all()
|
|
|
- }
|
|
|
+ site = self.sites[1]
|
|
|
+ original_cfvs = {**site.custom_field_data}
|
|
|
data = {
|
|
|
'custom_fields': {
|
|
|
'text_field': 'ABCD',
|
|
|
@@ -423,55 +393,21 @@ class CustomFieldAPITest(APITestCase):
|
|
|
|
|
|
# Validate response data
|
|
|
response_cf = response.data['custom_fields']
|
|
|
- data_cf = data['custom_fields']
|
|
|
- self.assertEqual(response_cf['text_field'], data_cf['text_field'])
|
|
|
- self.assertEqual(response_cf['number_field'], data_cf['number_field'])
|
|
|
- # TODO: Non-updated fields are missing from the response data
|
|
|
- # self.assertEqual(response_cf['boolean_field'], site2_original_cfvs['boolean_field'])
|
|
|
- # self.assertEqual(response_cf['date_field'], site2_original_cfvs['date_field'])
|
|
|
- # self.assertEqual(response_cf['url_field'], site2_original_cfvs['url_field'])
|
|
|
- # self.assertEqual(response_cf['choice_field']['label'], site2_original_cfvs['choice_field'].value)
|
|
|
+ self.assertEqual(response_cf['text_field'], data['custom_fields']['text_field'])
|
|
|
+ self.assertEqual(response_cf['number_field'], data['custom_fields']['number_field'])
|
|
|
+ self.assertEqual(response_cf['boolean_field'], original_cfvs['boolean_field'])
|
|
|
+ self.assertEqual(response_cf['date_field'], original_cfvs['date_field'])
|
|
|
+ self.assertEqual(response_cf['url_field'], original_cfvs['url_field'])
|
|
|
+ self.assertEqual(response_cf['choice_field'], original_cfvs['choice_field'])
|
|
|
|
|
|
# Validate database data
|
|
|
- site2_updated_cfvs = {
|
|
|
- cfv.field.name: cfv.value for cfv in self.sites[1].custom_field_values.all()
|
|
|
- }
|
|
|
- self.assertEqual(site2_updated_cfvs['text_field'], data_cf['text_field'])
|
|
|
- self.assertEqual(site2_updated_cfvs['number_field'], data_cf['number_field'])
|
|
|
- self.assertEqual(site2_updated_cfvs['boolean_field'], site2_original_cfvs['boolean_field'])
|
|
|
- self.assertEqual(site2_updated_cfvs['date_field'], site2_original_cfvs['date_field'])
|
|
|
- self.assertEqual(site2_updated_cfvs['url_field'], site2_original_cfvs['url_field'])
|
|
|
- self.assertEqual(site2_updated_cfvs['choice_field'], site2_original_cfvs['choice_field'])
|
|
|
-
|
|
|
-
|
|
|
-class CustomFieldChoiceAPITest(APITestCase):
|
|
|
- def setUp(self):
|
|
|
- super().setUp()
|
|
|
-
|
|
|
- vm_content_type = ContentType.objects.get_for_model(VirtualMachine)
|
|
|
-
|
|
|
- self.cf_1 = CustomField.objects.create(name="cf_1", type=CustomFieldTypeChoices.TYPE_SELECT)
|
|
|
- self.cf_2 = CustomField.objects.create(name="cf_2", type=CustomFieldTypeChoices.TYPE_SELECT)
|
|
|
-
|
|
|
- self.cf_choice_1 = CustomFieldChoice.objects.create(field=self.cf_1, value="cf_field_1", weight=100)
|
|
|
- self.cf_choice_2 = CustomFieldChoice.objects.create(field=self.cf_1, value="cf_field_2", weight=50)
|
|
|
- self.cf_choice_3 = CustomFieldChoice.objects.create(field=self.cf_2, value="cf_field_3", weight=10)
|
|
|
-
|
|
|
- def test_list_cfc(self):
|
|
|
- url = reverse('extras-api:custom-field-choice-list')
|
|
|
- response = self.client.get(url, **self.header)
|
|
|
-
|
|
|
- self.assertEqual(len(response.data), 2)
|
|
|
- self.assertEqual(len(response.data[self.cf_1.name]), 2)
|
|
|
- self.assertEqual(len(response.data[self.cf_2.name]), 1)
|
|
|
-
|
|
|
- self.assertTrue(self.cf_choice_1.value in response.data[self.cf_1.name])
|
|
|
- self.assertTrue(self.cf_choice_2.value in response.data[self.cf_1.name])
|
|
|
- self.assertTrue(self.cf_choice_3.value in response.data[self.cf_2.name])
|
|
|
-
|
|
|
- self.assertEqual(self.cf_choice_1.pk, response.data[self.cf_1.name][self.cf_choice_1.value])
|
|
|
- self.assertEqual(self.cf_choice_2.pk, response.data[self.cf_1.name][self.cf_choice_2.value])
|
|
|
- self.assertEqual(self.cf_choice_3.pk, response.data[self.cf_2.name][self.cf_choice_3.value])
|
|
|
+ site.refresh_from_db()
|
|
|
+ self.assertEqual(site.custom_field_data['text_field'], data['custom_fields']['text_field'])
|
|
|
+ self.assertEqual(site.custom_field_data['number_field'], data['custom_fields']['number_field'])
|
|
|
+ self.assertEqual(site.custom_field_data['boolean_field'], original_cfvs['boolean_field'])
|
|
|
+ self.assertEqual(site.custom_field_data['date_field'], original_cfvs['date_field'])
|
|
|
+ self.assertEqual(site.custom_field_data['url_field'], original_cfvs['url_field'])
|
|
|
+ self.assertEqual(site.custom_field_data['choice_field'], original_cfvs['choice_field'])
|
|
|
|
|
|
|
|
|
class CustomFieldImportTest(TestCase):
|
|
|
@@ -489,18 +425,12 @@ class CustomFieldImportTest(TestCase):
|
|
|
CustomField(name='boolean', type=CustomFieldTypeChoices.TYPE_BOOLEAN),
|
|
|
CustomField(name='date', type=CustomFieldTypeChoices.TYPE_DATE),
|
|
|
CustomField(name='url', type=CustomFieldTypeChoices.TYPE_URL),
|
|
|
- CustomField(name='select', type=CustomFieldTypeChoices.TYPE_SELECT),
|
|
|
+ CustomField(name='select', type=CustomFieldTypeChoices.TYPE_SELECT, choices=['Choice A', 'Choice B', 'Choice C']),
|
|
|
)
|
|
|
for cf in custom_fields:
|
|
|
cf.save()
|
|
|
cf.obj_type.set([ContentType.objects.get_for_model(Site)])
|
|
|
|
|
|
- CustomFieldChoice.objects.bulk_create((
|
|
|
- CustomFieldChoice(field=custom_fields[5], value='Choice A'),
|
|
|
- CustomFieldChoice(field=custom_fields[5], value='Choice B'),
|
|
|
- CustomFieldChoice(field=custom_fields[5], value='Choice C'),
|
|
|
- ))
|
|
|
-
|
|
|
def test_import(self):
|
|
|
"""
|
|
|
Import a Site in CSV format, including a value for each CustomField.
|
|
|
@@ -517,34 +447,28 @@ class CustomFieldImportTest(TestCase):
|
|
|
self.assertEqual(response.status_code, 200)
|
|
|
|
|
|
# Validate data for site 1
|
|
|
- custom_field_values = {
|
|
|
- cf.name: value for cf, value in Site.objects.get(name='Site 1').get_custom_fields().items()
|
|
|
- }
|
|
|
- self.assertEqual(len(custom_field_values), 6)
|
|
|
- self.assertEqual(custom_field_values['text'], 'ABC')
|
|
|
- self.assertEqual(custom_field_values['integer'], 123)
|
|
|
- self.assertEqual(custom_field_values['boolean'], True)
|
|
|
- self.assertEqual(custom_field_values['date'], date(2020, 1, 1))
|
|
|
- self.assertEqual(custom_field_values['url'], 'http://example.com/1')
|
|
|
- self.assertEqual(custom_field_values['select'].value, 'Choice A')
|
|
|
+ site1 = Site.objects.get(name='Site 1')
|
|
|
+ self.assertEqual(len(site1.custom_field_data), 6)
|
|
|
+ self.assertEqual(site1.custom_field_data['text'], 'ABC')
|
|
|
+ self.assertEqual(site1.custom_field_data['integer'], 123)
|
|
|
+ self.assertEqual(site1.custom_field_data['boolean'], True)
|
|
|
+ self.assertEqual(site1.custom_field_data['date'], '2020-01-01')
|
|
|
+ self.assertEqual(site1.custom_field_data['url'], 'http://example.com/1')
|
|
|
+ self.assertEqual(site1.custom_field_data['select'], 'Choice A')
|
|
|
|
|
|
# Validate data for site 2
|
|
|
- custom_field_values = {
|
|
|
- cf.name: value for cf, value in Site.objects.get(name='Site 2').get_custom_fields().items()
|
|
|
- }
|
|
|
- self.assertEqual(len(custom_field_values), 6)
|
|
|
- self.assertEqual(custom_field_values['text'], 'DEF')
|
|
|
- self.assertEqual(custom_field_values['integer'], 456)
|
|
|
- self.assertEqual(custom_field_values['boolean'], False)
|
|
|
- self.assertEqual(custom_field_values['date'], date(2020, 1, 2))
|
|
|
- self.assertEqual(custom_field_values['url'], 'http://example.com/2')
|
|
|
- self.assertEqual(custom_field_values['select'].value, 'Choice B')
|
|
|
-
|
|
|
- # No CustomFieldValues should be created for site 3
|
|
|
- obj_type = ContentType.objects.get_for_model(Site)
|
|
|
+ site2 = Site.objects.get(name='Site 2')
|
|
|
+ self.assertEqual(len(site2.custom_field_data), 6)
|
|
|
+ self.assertEqual(site2.custom_field_data['text'], 'DEF')
|
|
|
+ self.assertEqual(site2.custom_field_data['integer'], 456)
|
|
|
+ self.assertEqual(site2.custom_field_data['boolean'], False)
|
|
|
+ self.assertEqual(site2.custom_field_data['date'], '2020-01-02')
|
|
|
+ self.assertEqual(site2.custom_field_data['url'], 'http://example.com/2')
|
|
|
+ self.assertEqual(site2.custom_field_data['select'], 'Choice B')
|
|
|
+
|
|
|
+ # No custom field data should be set for site 3
|
|
|
site3 = Site.objects.get(name='Site 3')
|
|
|
- self.assertFalse(CustomFieldValue.objects.filter(obj_type=obj_type, obj_id=site3.pk).exists())
|
|
|
- self.assertEqual(CustomFieldValue.objects.count(), 12) # Sanity check
|
|
|
+ self.assertFalse(any(site3.custom_field_data.values()))
|
|
|
|
|
|
def test_import_missing_required(self):
|
|
|
"""
|