test(config_management): Serializer Unit Test Suite re-written to pytest for model ConfigGroup

ref: #908 #905
This commit is contained in:
2025-07-30 08:26:06 +09:30
parent bb93b4ebed
commit 98891be181
2 changed files with 179 additions and 126 deletions

View File

@ -1,126 +0,0 @@
import pytest
from django.test import TestCase
from rest_framework.exceptions import ValidationError
from access.models.tenant import Tenant as Organization
from centurion.tests.abstract.mock_view import MockView, User
from config_management.serializers.config_group import ConfigGroups, ConfigGroupModelSerializer
class ConfigGroupsValidationAPI(
TestCase,
):
model = ConfigGroups
@classmethod
def setUpTestData(self):
"""Setup Test
1. Create an org
2. Create an item
"""
organization = Organization.objects.create(name='test_org')
self.user = User.objects.create_user(username="test_user_view", password="password")
self.mock_view = MockView( user = self.user )
self.organization = organization
self.item_no_parent = self.model.objects.create(
organization=organization,
name = 'random title',
config = { 'config_key': 'a value' }
)
self.item_has_parent = self.model.objects.create(
organization=organization,
name = 'random title two',
parent = self.item_no_parent
)
def test_serializer_validation_no_name(self):
"""Serializer Validation Check
Ensure that if creating and no name is provided a validation error occurs
"""
with pytest.raises(ValidationError) as err:
serializer = ConfigGroupModelSerializer(
context = {
'request': self.mock_view.request,
'view': self.mock_view,
},
data={
"organization": self.organization.id,
})
serializer.is_valid(raise_exception = True)
assert err.value.get_codes()['name'][0] == 'required'
def test_serializer_validation_update_existing_parnet_not_self(self):
"""Serializer Validation Check
Ensure that if an existing item is assigned itself as it's parent group
it raises a validation error
"""
with pytest.raises(ValidationError) as err:
serializer = ConfigGroupModelSerializer(
self.item_has_parent,
context = {
'request': self.mock_view.request,
'view': self.mock_view,
},
data={
"parent": self.item_has_parent.id
},
partial=True,
)
serializer.is_valid(raise_exception = True)
assert err.value.get_codes()['parent'][0] == 'self_not_parent'
def test_serializer_validation_update_existing_invalid_config_key(self):
"""Serializer Validation Check
Ensure that if an existing item has it's config updated with an invalid config key
a validation exception is raised.
"""
invalid_config = self.item_no_parent.config.copy()
invalid_config.update({ 'software': 'is invalid' })
with pytest.raises(ValidationError) as err:
serializer = ConfigGroupModelSerializer(
self.item_no_parent,
context = {
'request': self.mock_view.request,
'view': self.mock_view,
},
data={
"config": invalid_config
},
partial=True,
)
serializer.is_valid(raise_exception = True)
assert err.value.get_codes()['config'][0] == 'invalid'

View File

@ -0,0 +1,179 @@
import pytest
from django.db import models
from rest_framework.exceptions import ValidationError
from api.tests.unit.test_unit_serializer import (
SerializerTestCases
)
from centurion.tests.abstract.mock_view import MockView
@pytest.mark.model_configgroups
class ConfigGroupsSerializerTestCases(
SerializerTestCases
):
pass
@pytest.fixture( scope = 'function' )
def created_model(self, django_db_blocker, model, model_kwargs):
with django_db_blocker.unblock():
kwargs_many_to_many = {}
kwargs = {}
for key, value in model_kwargs.items():
field = model._meta.get_field(key)
if isinstance(field, models.ManyToManyField):
kwargs_many_to_many.update({
key: value
})
else:
kwargs.update({
key: value
})
item = model.objects.create( **kwargs )
for key, value in kwargs_many_to_many.items():
field = getattr(item, key)
for entry in value:
field.add(entry)
yield item
item.delete()
def test_serializer_validation_no_name(self,
kwargs_api_create, model, model_serializer, request_user
):
"""Serializer Validation Check
Ensure that if creating and no name is provided a validation error occurs
"""
mock_view = MockView(
user = request_user,
model = model,
action = 'create',
)
kwargs = kwargs_api_create.copy()
del kwargs['name']
with pytest.raises(ValidationError) as err:
serializer = model_serializer['model'](
context = {
'request': mock_view.request,
'view': mock_view,
},
data = kwargs,
)
serializer.is_valid(raise_exception = True)
assert err.value.get_codes()['name'][0] == 'required'
def test_serializer_validation_update_existing_parnet_not_self(self,
created_model,
kwargs_api_create, model, model_serializer, request_user
):
"""Serializer Validation Check
Ensure that if an existing item is assigned itself as it's parent group
it raises a validation error
"""
mock_view = MockView(
user = request_user,
model = model,
action = 'create',
)
kwargs = kwargs_api_create.copy()
kwargs['parent'] = created_model.id
with pytest.raises(ValidationError) as err:
serializer = model_serializer['model'](
created_model,
context = {
'request': mock_view.request,
'view': mock_view,
},
data = kwargs,
partial=True,
)
serializer.is_valid(raise_exception = True)
assert err.value.get_codes()['parent'][0] == 'self_not_parent'
def test_serializer_validation_update_existing_invalid_config_key(self,
created_model,
model, model_serializer, request_user
):
"""Serializer Validation Check
Ensure that if an existing item has it's config updated with an invalid config key
a validation exception is raised.
"""
mock_view = MockView(
user = request_user,
model = model,
action = 'create',
)
with pytest.raises(ValidationError) as err:
serializer = model_serializer['model'](
created_model,
context = {
'request': mock_view.request,
'view': mock_view,
},
data={
"config": {'software': 'is invalid'}
},
partial=True,
)
serializer.is_valid(raise_exception = True)
assert err.value.get_codes()['config'][0] == 'invalid'
class ConfigGroupsSerializerInheritedCases(
ConfigGroupsSerializerTestCases
):
pass
@pytest.mark.module_config_management
class ConfigGroupsSerializerPyTest(
ConfigGroupsSerializerTestCases
):
pass