-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathcomponents.feature
103 lines (99 loc) · 2.86 KB
/
components.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
# https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.0.0.md#componentsObject
Feature: Components section
# NOTE: the components/schemas section is tested in the model.feature file
Scenario: a response defined in the components section
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",
"$ref": "#/components/responses/responseOne"
}
}
}
}
},
"components": {
"responses": {
"responseOne": {
"description": "description",
"content": {
"application/json": {
"schema": { "$ref": "#/components/schemas/ObjectResponse" }
}
}
}
},
"schemas": {
"ObjectResponse": {
"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 ObjectResponse
And the response should have a property id with value 56
And the response should have a property value with value foo
Scenario: a parameter defined in the components section
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/getThings": {
"get": {
"operationId": "getThings",
"parameters": [
{
"name": "value",
"in": "query",
"schema": { "type": "string" }
},
{
"$ref": "#/components/parameters/limitParam"
}
],
"responses": {
"200": {
"description": "description",
"content": {
"application/json": {
"schema": { "type": "string" }
}
}
}
}
}
}
},
"components": {
"parameters": {
"limitParam": {
"name": "limit",
"in": "query",
"schema" : { "type": "integer" }
}
}
}
}
"""
When calling the method getThings with parameters "cats,2"
Then the requested URL should be https://example.com/api/v3/test/getThings?value=cats&limit=2