test(config_management): ViewSet Unit Test Suite re-written to pytest for model ConfigGroup
ref: #908 #905
This commit is contained in:
@ -377,6 +377,7 @@ class CommonViewSetTestCases(
|
||||
)
|
||||
|
||||
view_set.request = request
|
||||
view_set.kwargs = {}
|
||||
|
||||
yield view_set
|
||||
|
||||
|
@ -61,7 +61,8 @@ class KnowledgeBaseSerializerTestCases(
|
||||
|
||||
|
||||
def test_serializer_validation_no_title(self,
|
||||
kwargs_api_create, model, model_serializer, request_user):
|
||||
kwargs_api_create, model, model_serializer, request_user
|
||||
):
|
||||
"""Serializer Validation Check
|
||||
|
||||
Ensure that if creating and no title is provided a validation error occurs
|
||||
|
@ -17,3 +17,9 @@ def model_kwargs(request, kwargs_configgroups):
|
||||
|
||||
if hasattr(request.cls, 'kwargs_create_item'):
|
||||
del request.cls.kwargs_create_item
|
||||
|
||||
|
||||
@pytest.fixture( scope = 'class')
|
||||
def model_serializer(serializer_configgroups):
|
||||
|
||||
yield serializer_configgroups
|
||||
|
@ -0,0 +1,99 @@
|
||||
import pytest
|
||||
|
||||
from api.tests.unit.test_unit_common_viewset import ModelViewSetInheritedCases
|
||||
|
||||
from config_management.viewsets.config_group import (
|
||||
ConfigGroups,
|
||||
ViewSet,
|
||||
)
|
||||
|
||||
|
||||
|
||||
@pytest.mark.model_configgroups
|
||||
class ViewsetTestCases(
|
||||
ModelViewSetInheritedCases,
|
||||
):
|
||||
|
||||
|
||||
@pytest.fixture( scope = 'function' )
|
||||
def viewset(self):
|
||||
return ViewSet
|
||||
|
||||
|
||||
@property
|
||||
def parameterized_class_attributes(self):
|
||||
return {
|
||||
'_model_documentation': {
|
||||
'type': type(None),
|
||||
},
|
||||
'back_url': {
|
||||
'type': type(None),
|
||||
},
|
||||
'documentation': {
|
||||
'type': type(None),
|
||||
'value': None
|
||||
},
|
||||
'filterset_fields': {
|
||||
'value': [
|
||||
'organization',
|
||||
'parent'
|
||||
]
|
||||
},
|
||||
'model': {
|
||||
'value': ConfigGroups
|
||||
},
|
||||
'model_documentation': {
|
||||
'type': type(None),
|
||||
},
|
||||
'queryset': {
|
||||
'type': type(None),
|
||||
},
|
||||
'serializer_class': {
|
||||
'type': type(None),
|
||||
},
|
||||
'search_fields': {
|
||||
'value': [
|
||||
'name',
|
||||
'config'
|
||||
]
|
||||
},
|
||||
'view_description': {
|
||||
'value': 'Configuration Groups'
|
||||
},
|
||||
'view_name': {
|
||||
'type': type(None),
|
||||
},
|
||||
'view_serializer_name': {
|
||||
'type': type(None),
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
def test_view_func_get_queryset_cache_result_used(self, mocker, viewset, viewset_mock_request):
|
||||
|
||||
qs = mocker.spy(viewset_mock_request.model, 'objects')
|
||||
|
||||
viewset_mock_request.get_queryset() # Initial QuerySet fetch/filter and cache
|
||||
|
||||
assert len(qs.method_calls) == 1 # one call to .all()
|
||||
assert len(qs.mock_calls) == 3 # calls = .all(), all().filter()
|
||||
|
||||
viewset_mock_request.get_queryset() # Use Cached results, dont re-fetch QuerySet
|
||||
|
||||
assert len(qs.method_calls) == 1
|
||||
assert len(qs.mock_calls) == 3
|
||||
|
||||
|
||||
class KnowledgeBaseViewsetInheritedCases(
|
||||
ViewsetTestCases,
|
||||
):
|
||||
pass
|
||||
|
||||
|
||||
|
||||
@pytest.mark.module_config_management
|
||||
class KnowledgeBaseViewsetPyTest(
|
||||
ViewsetTestCases,
|
||||
):
|
||||
|
||||
pass
|
@ -1,42 +0,0 @@
|
||||
from django.test import Client, TestCase
|
||||
|
||||
from rest_framework.reverse import reverse
|
||||
|
||||
from api.tests.unit.test_unit_common_viewset import ModelViewSetInheritedCases
|
||||
|
||||
from config_management.viewsets.config_group import ViewSet
|
||||
|
||||
|
||||
|
||||
@pytest.mark.skip(reason = 'see #895, tests being refactored')
|
||||
class ConfigGroupsViewsetList(
|
||||
ModelViewSetInheritedCases,
|
||||
TestCase,
|
||||
):
|
||||
|
||||
viewset = ViewSet
|
||||
|
||||
route_name = 'v2:_api_configgroups'
|
||||
|
||||
|
||||
@classmethod
|
||||
def setUpTestData(self):
|
||||
"""Setup Test
|
||||
|
||||
1. make list request
|
||||
"""
|
||||
|
||||
|
||||
super().setUpTestData()
|
||||
|
||||
|
||||
client = Client()
|
||||
|
||||
url = reverse(
|
||||
self.route_name + '-list',
|
||||
kwargs = self.kwargs
|
||||
)
|
||||
|
||||
client.force_login(self.view_user)
|
||||
|
||||
self.http_options_response_list = client.options(url)
|
@ -74,7 +74,7 @@ class ViewSet( ModelViewSet ):
|
||||
|
||||
model = ConfigGroups
|
||||
|
||||
view_description = 'Information Management Knowledge Base Article(s)'
|
||||
view_description = 'Configuration Groups'
|
||||
|
||||
|
||||
def get_queryset(self):
|
||||
@ -94,7 +94,7 @@ class ViewSet( ModelViewSet ):
|
||||
else:
|
||||
|
||||
self.queryset = super().get_queryset().filter( parent = None )
|
||||
|
||||
|
||||
return self.queryset
|
||||
|
||||
|
||||
@ -105,12 +105,13 @@ class ViewSet( ModelViewSet ):
|
||||
or self.action == 'retrieve'
|
||||
):
|
||||
|
||||
self.serializer_class = globals()[str( self.model._meta.verbose_name).replace(' ' , '') + 'ViewSerializer']
|
||||
self.serializer_class = globals()[str(
|
||||
self.model._meta.verbose_name).replace(' ' , '') + 'ViewSerializer']
|
||||
|
||||
else:
|
||||
|
||||
self.serializer_class = globals()[str( self.model._meta.verbose_name).replace(' ' , '') + 'ModelSerializer']
|
||||
self.serializer_class = globals()[str(
|
||||
self.model._meta.verbose_name).replace(' ' , '') + 'ModelSerializer']
|
||||
|
||||
|
||||
return self.serializer_class
|
||||
|
||||
|
1
app/tests/fixtures/__init__.py
vendored
1
app/tests/fixtures/__init__.py
vendored
@ -77,6 +77,7 @@ from .model_company import (
|
||||
from .model_configgroup import (
|
||||
kwargs_configgroups,
|
||||
model_configgroups,
|
||||
serializer_configgroups,
|
||||
)
|
||||
|
||||
from .model_configgrouphost import (
|
||||
|
16
app/tests/fixtures/model_configgroup.py
vendored
16
app/tests/fixtures/model_configgroup.py
vendored
@ -2,6 +2,12 @@ import datetime
|
||||
import pytest
|
||||
|
||||
from config_management.models.groups import ConfigGroups
|
||||
from config_management.serializers.config_group import (
|
||||
ConfigGroupBaseSerializer,
|
||||
ConfigGroupModelSerializer,
|
||||
ConfigGroupViewSerializer,
|
||||
)
|
||||
|
||||
|
||||
|
||||
@pytest.fixture( scope = 'class')
|
||||
@ -25,3 +31,13 @@ def kwargs_configgroups(django_db_blocker,
|
||||
}
|
||||
|
||||
yield kwargs.copy()
|
||||
|
||||
|
||||
@pytest.fixture( scope = 'class')
|
||||
def serializer_configgroups():
|
||||
|
||||
yield {
|
||||
'base': ConfigGroupBaseSerializer,
|
||||
'model': ConfigGroupModelSerializer,
|
||||
'view': ConfigGroupViewSerializer
|
||||
}
|
||||
|
Reference in New Issue
Block a user