This repository was archived by the owner on Jan 11, 2021. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 598
Expand file tree
/
Copy pathtest_openapi_renderer.py
More file actions
104 lines (81 loc) · 3.58 KB
/
test_openapi_renderer.py
File metadata and controls
104 lines (81 loc) · 3.58 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
import coreapi
from coreapi.compat import force_bytes
from django.test import TestCase
import simplejson as json
from rest_framework_swagger import renderers
from ..compat.mock import MagicMock, patch
class TestOpenAPICodec(TestCase):
def setUp(self):
self.sut = renderers.OpenAPICodec().encode
def test_encode_without_document_instance_raises_assertion_error(self):
"""
Given that the data is not a CoreAPI Document instance,
an assertion error should be raised.
"""
with self.assertRaises(TypeError) as cx:
data = MagicMock()
self.sut(data)
expected = 'Expected a `coreapi.Document` instance'
self.assertEqual(expected, str(cx.exception))
def test_encode_generates_swagger_object_when_given_valid_document(self):
expected = {'fizz': 'buzz'}
with patch(
'rest_framework_swagger.renderers.generate_swagger_object',
return_value={'fizz': 'buzz'}
):
result = self.sut(coreapi.Document())
self.assertEqual(force_bytes(json.dumps(expected)), result)
def test_encode_adds_extra_data_provided_to_swagger_object(self):
expected = {'foo': 'bar'}
with patch(
'rest_framework_swagger.renderers.generate_swagger_object',
return_value={}
):
result = self.sut(coreapi.Document(), **expected)
self.assertEqual(force_bytes(json.dumps(expected)), result)
class TestOpenAPIRenderer(TestCase):
def setUp(self):
self.sut = renderers.OpenAPIRenderer()
def test_media_type(self):
self.assertEqual(
'application/openapi+json',
self.sut.media_type
)
def test_charset(self):
self.assertIsNone(self.sut.charset)
def test_format(self):
self.assertEqual('openapi', self.sut.format)
@patch('rest_framework_swagger.renderers.OpenAPICodec.encode')
def test_render_encodes_customizations(self, encode_mock):
data = coreapi.Document()
renderer_context = {
'request': MagicMock(),
'response': MagicMock(status_code=200)
}
with patch.object(self.sut, 'get_customizations') as mock:
self.sut.render(data, renderer_context=renderer_context)
encode_mock.assert_called_once_with(data, **mock.return_value)
def test_render_if_response_is_not_200(self):
"""
Given the response returned in the renderer_context has a status
code other than 200, the data should be dumped.
"""
data = {'error': 'fizz buzz'}
renderer_context = {'response': MagicMock(status_code=403)}
result = self.sut.render(data, renderer_context=renderer_context)
expected = renderers.JSONRenderer().render(data)
self.assertEqual(expected, result)
class TestGetCustomizations(TestCase):
def setUp(self):
self.sut = renderers.OpenAPIRenderer().get_customizations
settings_patcher = patch('rest_framework_swagger.renderers.settings')
self.swagger_settings = settings_patcher.start()
self.addCleanup(settings_patcher.stop)
def test_security_definitions_included_when_defined(self):
self.swagger_settings.SECURITY_DEFINITIONS = {'foo': 'bar'}
sut = self.sut()
self.assertIn('securityDefinitions', sut)
self.assertEqual(sut['securityDefinitions'], self.swagger_settings.SECURITY_DEFINITIONS)
def test_security_definitions_not_present_when_none(self):
self.swagger_settings.SECURITY_DEFINITIONS = None
self.assertNotIn('securityDefinitions', self.sut())