-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathobjects.feature
125 lines (122 loc) · 3.71 KB
/
objects.feature
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
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
Feature: Handles inlin / anonymous objects, i.e. those that are not defined in the components/schemas section
# NOTE: The purpose of this test case is to ensure the generator creates the 'inlines' objects. This
# test doesn't validate the various encoding rules
Scenario: Creates inline model objects from parameters
Given an API with the following specification
"""
{
"openapi":"3.0.2",
"info" : {"title": "test", "version": "0.0.0"},
"servers": [{ "url": "https://example.com/api/v3" }],
"paths": {
"/test": {
"get": {
"operationId": "getTest",
"parameters": [
{
"name": "test",
"in": "query",
"schema": {
"type": "object",
"properties": {
"value": { "type": "string" }
}
}
}
],
"responses": {
"200": {
"description": "description",
"content": {
"application/json": {
"schema": { "type": "string" }
}
}
}
}
}
}
}
}
"""
When calling the method getTest with object {"value":"test test"}
Then the requested URL should be https://example.com/api/v3/test?value=test+test
Scenario: Creates inline objects for request bodies
Given an API with the following specification
"""
{
"openapi":"3.0.2",
"info" : {"title": "test", "version": "0.0.0"},
"servers": [{ "url": "https://example.com/api/v3" }],
"paths": {
"/test/testBody": {
"post": {
"operationId": "testBody",
"requestBody": {
"content": {
"application/json": {
"schema": {
"type": "object",
"properties": {
"value": { "type": "string" }
}
}
}
}
},
"responses": {
"200": {
"description": "description",
"content": {
"application/json": {
"schema": { "type": "string" }
}
}
}
}
}
}
}
}
"""
When calling the method testBody with object {"value":"test"}
Then the requested URL should be https://example.com/api/v3/test/testBody
And the request should have a body with value {"value":"test"}
Scenario: Creates inline objects for responses
Given an API with the following specification
"""
{
"openapi":"3.0.2",
"info" : {"title": "test", "version": "0.0.0"},
"paths": {
"/test/get": {
"get": {
"operationId": "getResponse",
"responses": {
"200": {
"description": "description",
"content": {
"application/json": {
"schema": {
"type": "object",
"properties": {
"id": { "type": "integer" },
"value": { "type": "string" }
}
}
}
}
}
}
}
}
}
}
"""
When calling the method getResponse and the server responds with
"""
{ "id": 56, "value": "foo" }
"""
Then the response should be of type InlineObject1
And the response should have a property id with value 56
And the response should have a property value with value foo