@typespec/http-specs 0.1.0-alpha.3-dev.6 → 0.1.0-alpha.30-dev.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +238 -0
- package/README.md +11 -3
- package/dist/specs/documentation/mockapi.d.ts.map +1 -0
- package/dist/specs/documentation/mockapi.js +38 -0
- package/dist/specs/documentation/mockapi.js.map +1 -0
- package/dist/specs/encode/array/mockapi.d.ts +3 -0
- package/dist/specs/encode/array/mockapi.d.ts.map +1 -0
- package/dist/specs/encode/array/mockapi.js +25 -0
- package/dist/specs/encode/array/mockapi.js.map +1 -0
- package/dist/specs/encode/bytes/mockapi.js +16 -24
- package/dist/specs/encode/bytes/mockapi.js.map +1 -1
- package/dist/specs/encode/datetime/mockapi.js +2 -2
- package/dist/specs/encode/datetime/mockapi.js.map +1 -1
- package/dist/specs/encode/duration/mockapi.js +74 -2
- package/dist/specs/encode/duration/mockapi.js.map +1 -1
- package/dist/specs/encode/numeric/mockapi.js +2 -2
- package/dist/specs/encode/numeric/mockapi.js.map +1 -1
- package/dist/specs/helper.d.ts +2 -2
- package/dist/specs/helper.d.ts.map +1 -1
- package/dist/specs/parameters/basic/mockapi.d.ts.map +1 -1
- package/dist/specs/parameters/basic/mockapi.js +3 -3
- package/dist/specs/parameters/basic/mockapi.js.map +1 -1
- package/dist/specs/parameters/body-optionality/mockapi.d.ts.map +1 -1
- package/dist/specs/parameters/body-optionality/mockapi.js +14 -4
- package/dist/specs/parameters/body-optionality/mockapi.js.map +1 -1
- package/dist/specs/parameters/collection-format/mockapi.js +4 -15
- package/dist/specs/parameters/collection-format/mockapi.js.map +1 -1
- package/dist/specs/parameters/path/mockapi.d.ts +3 -0
- package/dist/specs/parameters/path/mockapi.d.ts.map +1 -0
- package/dist/specs/parameters/path/mockapi.js +29 -0
- package/dist/specs/parameters/path/mockapi.js.map +1 -0
- package/dist/specs/parameters/spread/mockapi.d.ts.map +1 -1
- package/dist/specs/parameters/spread/mockapi.js +19 -19
- package/dist/specs/parameters/spread/mockapi.js.map +1 -1
- package/dist/specs/payload/json-merge-patch/mockapi.js +4 -4
- package/dist/specs/payload/json-merge-patch/mockapi.js.map +1 -1
- package/dist/specs/payload/media-type/mockapi.js +2 -2
- package/dist/specs/payload/media-type/mockapi.js.map +1 -1
- package/dist/specs/payload/multipart/mockapi.d.ts.map +1 -1
- package/dist/specs/payload/multipart/mockapi.js +42 -60
- package/dist/specs/payload/multipart/mockapi.js.map +1 -1
- package/dist/specs/payload/pageable/mockapi.d.ts.map +1 -1
- package/dist/specs/payload/pageable/mockapi.js +425 -18
- package/dist/specs/payload/pageable/mockapi.js.map +1 -1
- package/dist/specs/payload/xml/mockapi.js +1 -4
- package/dist/specs/payload/xml/mockapi.js.map +1 -1
- package/dist/specs/response/status-code-range/mockapi.d.ts +3 -0
- package/dist/specs/response/status-code-range/mockapi.d.ts.map +1 -0
- package/dist/specs/response/status-code-range/mockapi.js +29 -0
- package/dist/specs/response/status-code-range/mockapi.js.map +1 -0
- package/dist/specs/routes/mockapi.js +25 -25
- package/dist/specs/routes/mockapi.js.map +1 -1
- package/dist/specs/serialization/encoded-name/json/mockapi.js +1 -1
- package/dist/specs/serialization/encoded-name/json/mockapi.js.map +1 -1
- package/dist/specs/server/versions/not-versioned/mockapi.js +1 -1
- package/dist/specs/server/versions/not-versioned/mockapi.js.map +1 -1
- package/dist/specs/server/versions/versioned/mockapi.js +8 -12
- package/dist/specs/server/versions/versioned/mockapi.js.map +1 -1
- package/dist/specs/special-words/mockapi.d.ts.map +1 -1
- package/dist/specs/special-words/mockapi.js +28 -6
- package/dist/specs/special-words/mockapi.js.map +1 -1
- package/dist/specs/streaming/jsonl/mockapi.d.ts +3 -0
- package/dist/specs/streaming/jsonl/mockapi.d.ts.map +1 -0
- package/dist/specs/streaming/jsonl/mockapi.js +30 -0
- package/dist/specs/streaming/jsonl/mockapi.js.map +1 -0
- package/dist/specs/type/array/mockapi.js +1 -1
- package/dist/specs/type/array/mockapi.js.map +1 -1
- package/dist/specs/type/dictionary/mockapi.js +1 -1
- package/dist/specs/type/dictionary/mockapi.js.map +1 -1
- package/dist/specs/type/enum/extensible/mockapi.js +1 -1
- package/dist/specs/type/enum/extensible/mockapi.js.map +1 -1
- package/dist/specs/type/enum/fixed/mockapi.js +2 -2
- package/dist/specs/type/enum/fixed/mockapi.js.map +1 -1
- package/dist/specs/type/model/empty/mockapi.js +2 -2
- package/dist/specs/type/model/empty/mockapi.js.map +1 -1
- package/dist/specs/type/model/inheritance/enum-discriminator/mockapi.js +1 -1
- package/dist/specs/type/model/inheritance/enum-discriminator/mockapi.js.map +1 -1
- package/dist/specs/type/model/inheritance/nested-discriminator/mockapi.js +2 -2
- package/dist/specs/type/model/inheritance/nested-discriminator/mockapi.js.map +1 -1
- package/dist/specs/type/model/inheritance/not-discriminated/mockapi.js +2 -2
- package/dist/specs/type/model/inheritance/not-discriminated/mockapi.js.map +1 -1
- package/dist/specs/type/model/inheritance/recursive/mockapi.js +1 -1
- package/dist/specs/type/model/inheritance/recursive/mockapi.js.map +1 -1
- package/dist/specs/type/model/inheritance/single-discriminator/mockapi.js +2 -2
- package/dist/specs/type/model/inheritance/single-discriminator/mockapi.js.map +1 -1
- package/dist/specs/type/model/usage/mockapi.js +4 -4
- package/dist/specs/type/model/usage/mockapi.js.map +1 -1
- package/dist/specs/type/model/visibility/mockapi.js +9 -10
- package/dist/specs/type/model/visibility/mockapi.js.map +1 -1
- package/dist/specs/type/property/additional-properties/mockapi.js +9 -6
- package/dist/specs/type/property/additional-properties/mockapi.js.map +1 -1
- package/dist/specs/type/property/nullable/mockapi.js +2 -6
- package/dist/specs/type/property/nullable/mockapi.js.map +1 -1
- package/dist/specs/type/property/optionality/mockapi.js +1 -1
- package/dist/specs/type/property/optionality/mockapi.js.map +1 -1
- package/dist/specs/type/property/value-types/mockapi.js +3 -3
- package/dist/specs/type/property/value-types/mockapi.js.map +1 -1
- package/dist/specs/type/scalar/mockapi.js +9 -9
- package/dist/specs/type/scalar/mockapi.js.map +1 -1
- package/dist/specs/type/union/discriminated/mockapi.d.ts +3 -0
- package/dist/specs/type/union/discriminated/mockapi.d.ts.map +1 -0
- package/dist/specs/type/union/discriminated/mockapi.js +212 -0
- package/dist/specs/type/union/discriminated/mockapi.js.map +1 -0
- package/dist/specs/type/union/mockapi.js +2 -2
- package/dist/specs/type/union/mockapi.js.map +1 -1
- package/dist/specs/versioning/added/mockapi.js +6 -6
- package/dist/specs/versioning/added/mockapi.js.map +1 -1
- package/dist/specs/versioning/madeOptional/mockapi.js +2 -2
- package/dist/specs/versioning/madeOptional/mockapi.js.map +1 -1
- package/dist/specs/versioning/removed/mockapi.js +46 -2
- package/dist/specs/versioning/removed/mockapi.js.map +1 -1
- package/dist/specs/versioning/renamedFrom/mockapi.js +5 -5
- package/dist/specs/versioning/renamedFrom/mockapi.js.map +1 -1
- package/dist/specs/versioning/returnTypeChangedFrom/mockapi.js +1 -1
- package/dist/specs/versioning/returnTypeChangedFrom/mockapi.js.map +1 -1
- package/dist/specs/versioning/typeChangedFrom/mockapi.js +3 -3
- package/dist/specs/versioning/typeChangedFrom/mockapi.js.map +1 -1
- package/package.json +32 -19
- package/smoke/petstore/main.tsp +96 -0
- package/smoke/todoapp/main.tsp +293 -0
- package/spec-summary.md +1289 -265
- package/specs/documentation/main.tsp +158 -0
- package/specs/documentation/mockapi.ts +57 -0
- package/specs/encode/array/main.tsp +112 -0
- package/specs/encode/array/mockapi.ts +43 -0
- package/specs/encode/bytes/main.tsp +29 -20
- package/specs/encode/bytes/mockapi.ts +13 -31
- package/specs/encode/datetime/main.tsp +2 -7
- package/specs/encode/datetime/mockapi.ts +2 -2
- package/specs/encode/duration/main.tsp +420 -7
- package/specs/encode/duration/mockapi.ts +174 -2
- package/specs/encode/numeric/mockapi.ts +2 -2
- package/specs/parameters/basic/mockapi.ts +3 -3
- package/specs/parameters/body-optionality/main.tsp +2 -0
- package/specs/parameters/body-optionality/mockapi.ts +24 -4
- package/specs/parameters/collection-format/main.tsp +5 -25
- package/specs/parameters/collection-format/mockapi.ts +4 -16
- package/specs/parameters/path/main.tsp +48 -0
- package/specs/parameters/path/mockapi.ts +34 -0
- package/specs/parameters/spread/mockapi.ts +19 -19
- package/specs/payload/json-merge-patch/main.tsp +2 -2
- package/specs/payload/json-merge-patch/mockapi.ts +4 -4
- package/specs/payload/media-type/mockapi.ts +2 -2
- package/specs/payload/multipart/main.tsp +34 -32
- package/specs/payload/multipart/mockapi.ts +42 -59
- package/specs/payload/pageable/main.tsp +462 -7
- package/specs/payload/pageable/mockapi.ts +478 -18
- package/specs/payload/xml/mockapi.ts +1 -4
- package/specs/response/status-code-range/main.tsp +82 -0
- package/specs/response/status-code-range/mockapi.ts +31 -0
- package/specs/routes/main.tsp +48 -48
- package/specs/routes/mockapi.ts +25 -25
- package/specs/serialization/encoded-name/json/main.tsp +1 -1
- package/specs/serialization/encoded-name/json/mockapi.ts +1 -1
- package/specs/server/endpoint/not-defined/main.tsp +1 -3
- package/specs/server/path/multiple/main.tsp +3 -5
- package/specs/server/versions/not-versioned/mockapi.ts +1 -1
- package/specs/server/versions/versioned/main.tsp +1 -1
- package/specs/server/versions/versioned/mockapi.ts +6 -12
- package/specs/special-headers/conditional-request/main.tsp +1 -1
- package/specs/special-headers/repeatability/main.tsp +2 -2
- package/specs/special-words/main.tsp +44 -6
- package/specs/special-words/mockapi.ts +29 -6
- package/specs/streaming/jsonl/main.tsp +33 -0
- package/specs/streaming/jsonl/mockapi.ts +32 -0
- package/specs/type/array/mockapi.ts +1 -1
- package/specs/type/dictionary/mockapi.ts +1 -1
- package/specs/type/enum/extensible/main.tsp +18 -2
- package/specs/type/enum/extensible/mockapi.ts +1 -1
- package/specs/type/enum/fixed/main.tsp +15 -3
- package/specs/type/enum/fixed/mockapi.ts +2 -2
- package/specs/type/model/empty/mockapi.ts +2 -2
- package/specs/type/model/inheritance/enum-discriminator/mockapi.ts +1 -1
- package/specs/type/model/inheritance/nested-discriminator/mockapi.ts +2 -2
- package/specs/type/model/inheritance/not-discriminated/mockapi.ts +2 -2
- package/specs/type/model/inheritance/recursive/mockapi.ts +1 -1
- package/specs/type/model/inheritance/single-discriminator/mockapi.ts +2 -2
- package/specs/type/model/usage/mockapi.ts +4 -4
- package/specs/type/model/visibility/main.tsp +15 -23
- package/specs/type/model/visibility/mockapi.ts +9 -10
- package/specs/type/property/additional-properties/main.tsp +17 -17
- package/specs/type/property/additional-properties/mockapi.ts +10 -10
- package/specs/type/property/nullable/mockapi.ts +7 -8
- package/specs/type/property/optionality/mockapi.ts +1 -1
- package/specs/type/property/value-types/mockapi.ts +3 -3
- package/specs/type/scalar/main.tsp +58 -9
- package/specs/type/scalar/mockapi.ts +9 -9
- package/specs/type/union/discriminated/main.tsp +251 -0
- package/specs/type/union/discriminated/mockapi.ts +230 -0
- package/specs/type/union/mockapi.ts +2 -2
- package/specs/versioning/added/mockapi.ts +6 -6
- package/specs/versioning/madeOptional/mockapi.ts +2 -2
- package/specs/versioning/removed/main.tsp +65 -3
- package/specs/versioning/removed/mockapi.ts +49 -2
- package/specs/versioning/renamedFrom/mockapi.ts +5 -5
- package/specs/versioning/returnTypeChangedFrom/main.tsp +17 -2
- package/specs/versioning/returnTypeChangedFrom/mockapi.ts +1 -1
- package/specs/versioning/typeChangedFrom/mockapi.ts +3 -3
- package/temp/.tsbuildinfo +1 -1
- package/tspconfig.yaml +0 -2
- package/dist/specs/type/model/templated/mockapi.d.ts.map +0 -1
- package/dist/specs/type/model/templated/mockapi.js +0 -63
- package/dist/specs/type/model/templated/mockapi.js.map +0 -1
- package/specs/type/model/templated/main.tsp +0 -130
- package/specs/type/model/templated/mockapi.ts +0 -66
- /package/dist/specs/{type/model/templated → documentation}/mockapi.d.ts +0 -0
package/specs/routes/main.tsp
CHANGED
|
@@ -87,7 +87,7 @@ namespace PathParameters {
|
|
|
87
87
|
@scenarioDoc("""
|
|
88
88
|
Test simple expansion with explode: false when passed a primitive value.
|
|
89
89
|
Param value: "a"
|
|
90
|
-
Expected path: /routes/simple/standard/primitivea
|
|
90
|
+
Expected path: /routes/path/simple/standard/primitivea
|
|
91
91
|
""")
|
|
92
92
|
@route("primitive{param}")
|
|
93
93
|
op primitive(param: string): void;
|
|
@@ -96,19 +96,19 @@ namespace PathParameters {
|
|
|
96
96
|
@scenarioDoc("""
|
|
97
97
|
Test simple expansion with explode: false when passed an array value.
|
|
98
98
|
Param value: ["a","b"]
|
|
99
|
-
Expected path: /routes/simple/standard/arraya,b
|
|
99
|
+
Expected path: /routes/path/simple/standard/arraya,b
|
|
100
100
|
""")
|
|
101
101
|
@route("array{param}")
|
|
102
|
-
op array(param: string[]): void;
|
|
102
|
+
op `array`(param: string[]): void;
|
|
103
103
|
|
|
104
104
|
@scenario
|
|
105
105
|
@scenarioDoc("""
|
|
106
106
|
Test simple expansion with explode: false when passed a record value.
|
|
107
107
|
Param value: {a: 1, b: 2}
|
|
108
|
-
Expected path: /routes/simple/standard/recorda,1,b,2
|
|
108
|
+
Expected path: /routes/path/simple/standard/recorda,1,b,2
|
|
109
109
|
""")
|
|
110
110
|
@route("record{param}")
|
|
111
|
-
op record(param: Record<int32>): void;
|
|
111
|
+
op `record`(param: Record<int32>): void;
|
|
112
112
|
}
|
|
113
113
|
|
|
114
114
|
@route("explode")
|
|
@@ -117,7 +117,7 @@ namespace PathParameters {
|
|
|
117
117
|
@scenarioDoc("""
|
|
118
118
|
Test simple expansion with explode: true when passed a primitive value.
|
|
119
119
|
Param value: "a"
|
|
120
|
-
Expected path: /routes/simple/explode/primitivea
|
|
120
|
+
Expected path: /routes/path/simple/explode/primitivea
|
|
121
121
|
""")
|
|
122
122
|
@route("primitive{param*}")
|
|
123
123
|
op primitive(param: string): void;
|
|
@@ -126,19 +126,19 @@ namespace PathParameters {
|
|
|
126
126
|
@scenarioDoc("""
|
|
127
127
|
Test simple expansion with explode: true when passed an array value.
|
|
128
128
|
Param value: ["a","b"]
|
|
129
|
-
Expected path: /routes/simple/explode/arraya.b
|
|
129
|
+
Expected path: /routes/path/simple/explode/arraya.b
|
|
130
130
|
""")
|
|
131
131
|
@route("array{param*}")
|
|
132
|
-
op array(param: string[]): void;
|
|
132
|
+
op `array`(param: string[]): void;
|
|
133
133
|
|
|
134
134
|
@scenario
|
|
135
135
|
@scenarioDoc("""
|
|
136
136
|
Test simple expansion with explode: true when passed a record value.
|
|
137
137
|
Param value: {a: 1, b: 2}
|
|
138
|
-
Expected path: /routes/simple/explode/recorda=1,b=2
|
|
138
|
+
Expected path: /routes/path/simple/explode/recorda=1,b=2
|
|
139
139
|
""")
|
|
140
140
|
@route("record{param*}")
|
|
141
|
-
op record(param: Record<int32>): void;
|
|
141
|
+
op `record`(param: Record<int32>): void;
|
|
142
142
|
}
|
|
143
143
|
}
|
|
144
144
|
|
|
@@ -150,7 +150,7 @@ namespace PathParameters {
|
|
|
150
150
|
@scenarioDoc("""
|
|
151
151
|
Test path expansion with explode: false when passed a primitive value.
|
|
152
152
|
Param value: "a"
|
|
153
|
-
Expected path: /routes/path/standard/primitive/a
|
|
153
|
+
Expected path: /routes/path/path/standard/primitive/a
|
|
154
154
|
""")
|
|
155
155
|
@route("primitive{/param}")
|
|
156
156
|
op primitive(param: string): void;
|
|
@@ -159,19 +159,19 @@ namespace PathParameters {
|
|
|
159
159
|
@scenarioDoc("""
|
|
160
160
|
Test path expansion with explode: false when passed an array value.
|
|
161
161
|
Param value: ["a","b"]
|
|
162
|
-
Expected path: /routes/path/standard/array/a,b
|
|
162
|
+
Expected path: /routes/path/path/standard/array/a,b
|
|
163
163
|
""")
|
|
164
164
|
@route("array{/param}")
|
|
165
|
-
op array(param: string[]): void;
|
|
165
|
+
op `array`(param: string[]): void;
|
|
166
166
|
|
|
167
167
|
@scenario
|
|
168
168
|
@scenarioDoc("""
|
|
169
169
|
Test path expansion with explode: false when passed a record value.
|
|
170
170
|
Param value: {a: 1, b: 2}
|
|
171
|
-
Expected path: /routes/path/standard/record/a,1,b,2
|
|
171
|
+
Expected path: /routes/path/path/standard/record/a,1,b,2
|
|
172
172
|
""")
|
|
173
173
|
@route("record{/param}")
|
|
174
|
-
op record(param: Record<int32>): void;
|
|
174
|
+
op `record`(param: Record<int32>): void;
|
|
175
175
|
}
|
|
176
176
|
|
|
177
177
|
@route("explode")
|
|
@@ -180,7 +180,7 @@ namespace PathParameters {
|
|
|
180
180
|
@scenarioDoc("""
|
|
181
181
|
Test path expansion with explode: true when passed a primitive value.
|
|
182
182
|
Param value: "a"
|
|
183
|
-
Expected path: /routes/path/explode/primitive/a
|
|
183
|
+
Expected path: /routes/path/path/explode/primitive/a
|
|
184
184
|
""")
|
|
185
185
|
@route("primitive{/param*}")
|
|
186
186
|
op primitive(param: string): void;
|
|
@@ -189,19 +189,19 @@ namespace PathParameters {
|
|
|
189
189
|
@scenarioDoc("""
|
|
190
190
|
Test path expansion with explode: true when passed an array value.
|
|
191
191
|
Param value: ["a","b"]
|
|
192
|
-
Expected path: /routes/path/explode/array/a/b
|
|
192
|
+
Expected path: /routes/path/path/explode/array/a/b
|
|
193
193
|
""")
|
|
194
194
|
@route("array{/param*}")
|
|
195
|
-
op array(param: string[]): void;
|
|
195
|
+
op `array`(param: string[]): void;
|
|
196
196
|
|
|
197
197
|
@scenario
|
|
198
198
|
@scenarioDoc("""
|
|
199
199
|
Test path expansion with explode: true when passed a record value.
|
|
200
200
|
Param value: {a: 1, b: 2}
|
|
201
|
-
Expected path: /routes/path/explode/record/a=1/b=2
|
|
201
|
+
Expected path: /routes/path/path/explode/record/a=1/b=2
|
|
202
202
|
""")
|
|
203
203
|
@route("record{/param*}")
|
|
204
|
-
op record(param: Record<int32>): void;
|
|
204
|
+
op `record`(param: Record<int32>): void;
|
|
205
205
|
}
|
|
206
206
|
}
|
|
207
207
|
|
|
@@ -213,7 +213,7 @@ namespace PathParameters {
|
|
|
213
213
|
@scenarioDoc("""
|
|
214
214
|
Test label expansion with explode: false when passed a primitive value.
|
|
215
215
|
Param value: "a"
|
|
216
|
-
Expected path: /routes/label/standard/primitive.a
|
|
216
|
+
Expected path: /routes/path/label/standard/primitive.a
|
|
217
217
|
""")
|
|
218
218
|
@route("primitive{.param}")
|
|
219
219
|
op primitive(param: string): void;
|
|
@@ -222,19 +222,19 @@ namespace PathParameters {
|
|
|
222
222
|
@scenarioDoc("""
|
|
223
223
|
Test label expansion with explode: false when passed an array value.
|
|
224
224
|
Param value: ["a","b"]
|
|
225
|
-
Expected path: /routes/label/standard/array.a,b
|
|
225
|
+
Expected path: /routes/path/label/standard/array.a,b
|
|
226
226
|
""")
|
|
227
227
|
@route("array{.param}")
|
|
228
|
-
op array(param: string[]): void;
|
|
228
|
+
op `array`(param: string[]): void;
|
|
229
229
|
|
|
230
230
|
@scenario
|
|
231
231
|
@scenarioDoc("""
|
|
232
232
|
Test label expansion with explode: false when passed a record value.
|
|
233
233
|
Param value: {a: 1, b: 2}
|
|
234
|
-
Expected path: /routes/label/standard/record.a,1,b,2
|
|
234
|
+
Expected path: /routes/path/label/standard/record.a,1,b,2
|
|
235
235
|
""")
|
|
236
236
|
@route("record{.param}")
|
|
237
|
-
op record(param: Record<int32>): void;
|
|
237
|
+
op `record`(param: Record<int32>): void;
|
|
238
238
|
}
|
|
239
239
|
|
|
240
240
|
@route("explode")
|
|
@@ -243,7 +243,7 @@ namespace PathParameters {
|
|
|
243
243
|
@scenarioDoc("""
|
|
244
244
|
Test label expansion with explode: true when passed a primitive value.
|
|
245
245
|
Param value: "a"
|
|
246
|
-
Expected path: /routes/label/explode/primitive.a
|
|
246
|
+
Expected path: /routes/path/label/explode/primitive.a
|
|
247
247
|
""")
|
|
248
248
|
@route("primitive{.param*}")
|
|
249
249
|
op primitive(param: string): void;
|
|
@@ -252,19 +252,19 @@ namespace PathParameters {
|
|
|
252
252
|
@scenarioDoc("""
|
|
253
253
|
Test label expansion with explode: true when passed an array value.
|
|
254
254
|
Param value: ["a","b"]
|
|
255
|
-
Expected path: /routes/label/explode/array.a.b
|
|
255
|
+
Expected path: /routes/path/label/explode/array.a.b
|
|
256
256
|
""")
|
|
257
257
|
@route("array{.param*}")
|
|
258
|
-
op array(param: string[]): void;
|
|
258
|
+
op `array`(param: string[]): void;
|
|
259
259
|
|
|
260
260
|
@scenario
|
|
261
261
|
@scenarioDoc("""
|
|
262
262
|
Test label expansion with explode: true when passed a record value.
|
|
263
263
|
Param value: {a: 1, b: 2}
|
|
264
|
-
Expected path: /routes/label/explode/record.a=1.b=2
|
|
264
|
+
Expected path: /routes/path/label/explode/record.a=1.b=2
|
|
265
265
|
""")
|
|
266
266
|
@route("record{.param*}")
|
|
267
|
-
op record(param: Record<int32>): void;
|
|
267
|
+
op `record`(param: Record<int32>): void;
|
|
268
268
|
}
|
|
269
269
|
}
|
|
270
270
|
|
|
@@ -276,7 +276,7 @@ namespace PathParameters {
|
|
|
276
276
|
@scenarioDoc("""
|
|
277
277
|
Test matrix expansion with explode: false when passed a primitive value.
|
|
278
278
|
Param value: "a"
|
|
279
|
-
Expected path: /routes/matrix/standard/primitive;a
|
|
279
|
+
Expected path: /routes/path/matrix/standard/primitive;param=a
|
|
280
280
|
""")
|
|
281
281
|
@route("primitive{;param}")
|
|
282
282
|
op primitive(param: string): void;
|
|
@@ -285,19 +285,19 @@ namespace PathParameters {
|
|
|
285
285
|
@scenarioDoc("""
|
|
286
286
|
Test matrix expansion with explode: false when passed an array value.
|
|
287
287
|
Param value: ["a","b"]
|
|
288
|
-
Expected path: /routes/matrix/standard/array;a
|
|
288
|
+
Expected path: /routes/path/matrix/standard/array;param=a;param=b
|
|
289
289
|
""")
|
|
290
290
|
@route("array{;param}")
|
|
291
|
-
op array(param: string[]): void;
|
|
291
|
+
op `array`(param: string[]): void;
|
|
292
292
|
|
|
293
293
|
@scenario
|
|
294
294
|
@scenarioDoc("""
|
|
295
295
|
Test matrix expansion with explode: false when passed a record value.
|
|
296
296
|
Param value: {a: 1, b: 2}
|
|
297
|
-
Expected path: /routes/matrix/standard/record;a
|
|
297
|
+
Expected path: /routes/path/matrix/standard/record;a=1;b=2
|
|
298
298
|
""")
|
|
299
299
|
@route("record{;param}")
|
|
300
|
-
op record(param: Record<int32>): void;
|
|
300
|
+
op `record`(param: Record<int32>): void;
|
|
301
301
|
}
|
|
302
302
|
|
|
303
303
|
@route("explode")
|
|
@@ -306,7 +306,7 @@ namespace PathParameters {
|
|
|
306
306
|
@scenarioDoc("""
|
|
307
307
|
Test matrix expansion with explode: true when passed a primitive value.
|
|
308
308
|
Param value: "a"
|
|
309
|
-
Expected path: /routes/matrix/explode/primitive;a
|
|
309
|
+
Expected path: /routes/path/matrix/explode/primitive;param=a
|
|
310
310
|
""")
|
|
311
311
|
@route("primitive{;param*}")
|
|
312
312
|
op primitive(param: string): void;
|
|
@@ -315,19 +315,19 @@ namespace PathParameters {
|
|
|
315
315
|
@scenarioDoc("""
|
|
316
316
|
Test matrix expansion with explode: true when passed an array value.
|
|
317
317
|
Param value: ["a","b"]
|
|
318
|
-
Expected path: /routes/matrix/explode/array;a
|
|
318
|
+
Expected path: /routes/path/matrix/explode/array;param=a;param=b
|
|
319
319
|
""")
|
|
320
320
|
@route("array{;param*}")
|
|
321
|
-
op array(param: string[]): void;
|
|
321
|
+
op `array`(param: string[]): void;
|
|
322
322
|
|
|
323
323
|
@scenario
|
|
324
324
|
@scenarioDoc("""
|
|
325
325
|
Test matrix expansion with explode: true when passed a record value.
|
|
326
326
|
Param value: {a: 1, b: 2}
|
|
327
|
-
Expected path: /routes/matrix/explode/record;a=1;b=2
|
|
327
|
+
Expected path: /routes/path/matrix/explode/record;a=1;b=2
|
|
328
328
|
""")
|
|
329
329
|
@route("record{;param*}")
|
|
330
|
-
op record(param: Record<int32>): void;
|
|
330
|
+
op `record`(param: Record<int32>): void;
|
|
331
331
|
}
|
|
332
332
|
}
|
|
333
333
|
}
|
|
@@ -369,7 +369,7 @@ namespace QueryParameters {
|
|
|
369
369
|
Expected path: /routes/query/query-expansion/standard/array?param=a,b
|
|
370
370
|
""")
|
|
371
371
|
@route("array{?param}")
|
|
372
|
-
op array(param: string[]): void;
|
|
372
|
+
op `array`(param: string[]): void;
|
|
373
373
|
|
|
374
374
|
@scenario
|
|
375
375
|
@scenarioDoc("""
|
|
@@ -378,7 +378,7 @@ namespace QueryParameters {
|
|
|
378
378
|
Expected path: /routes/query/query-expansion/standard/record?param=a,1,b,2
|
|
379
379
|
""")
|
|
380
380
|
@route("record{?param}")
|
|
381
|
-
op record(param: Record<int32>): void;
|
|
381
|
+
op `record`(param: Record<int32>): void;
|
|
382
382
|
}
|
|
383
383
|
|
|
384
384
|
@route("explode")
|
|
@@ -399,7 +399,7 @@ namespace QueryParameters {
|
|
|
399
399
|
Expected path: /routes/query/query-expansion/explode/array?param=a¶m=b
|
|
400
400
|
""")
|
|
401
401
|
@route("array{?param*}")
|
|
402
|
-
op array(param: string[]): void;
|
|
402
|
+
op `array`(param: string[]): void;
|
|
403
403
|
|
|
404
404
|
@scenario
|
|
405
405
|
@scenarioDoc("""
|
|
@@ -408,7 +408,7 @@ namespace QueryParameters {
|
|
|
408
408
|
Expected path: /routes/query/query-expansion/explode/record?a=1&b=2
|
|
409
409
|
""")
|
|
410
410
|
@route("record{?param*}")
|
|
411
|
-
op record(param: Record<int32>): void;
|
|
411
|
+
op `record`(param: Record<int32>): void;
|
|
412
412
|
}
|
|
413
413
|
}
|
|
414
414
|
|
|
@@ -432,7 +432,7 @@ namespace QueryParameters {
|
|
|
432
432
|
Expected path: /routes/query/query-continuation/standard/array?fixed=true¶m=a,b
|
|
433
433
|
""")
|
|
434
434
|
@route("array?fixed=true{¶m}")
|
|
435
|
-
op array(param: string[]): void;
|
|
435
|
+
op `array`(param: string[]): void;
|
|
436
436
|
|
|
437
437
|
@scenario
|
|
438
438
|
@scenarioDoc("""
|
|
@@ -441,7 +441,7 @@ namespace QueryParameters {
|
|
|
441
441
|
Expected path: /routes/query/query-continuation/standard/record?fixed=true¶m=a,1,b,2
|
|
442
442
|
""")
|
|
443
443
|
@route("record?fixed=true{¶m}")
|
|
444
|
-
op record(param: Record<int32>): void;
|
|
444
|
+
op `record`(param: Record<int32>): void;
|
|
445
445
|
}
|
|
446
446
|
|
|
447
447
|
@route("explode")
|
|
@@ -462,7 +462,7 @@ namespace QueryParameters {
|
|
|
462
462
|
Expected path: /routes/query/query-continuation/explode/array?fixed=true¶m=a¶m=b
|
|
463
463
|
""")
|
|
464
464
|
@route("array?fixed=true{¶m*}")
|
|
465
|
-
op array(param: string[]): void;
|
|
465
|
+
op `array`(param: string[]): void;
|
|
466
466
|
|
|
467
467
|
@scenario
|
|
468
468
|
@scenarioDoc("""
|
|
@@ -471,7 +471,7 @@ namespace QueryParameters {
|
|
|
471
471
|
Expected path: /routes/query/query-continuation/explode/record?fixed=true&a=1&b=2
|
|
472
472
|
""")
|
|
473
473
|
@route("record?fixed=true{¶m*}")
|
|
474
|
-
op record(param: Record<int32>): void;
|
|
474
|
+
op `record`(param: Record<int32>): void;
|
|
475
475
|
}
|
|
476
476
|
}
|
|
477
477
|
}
|
package/specs/routes/mockapi.ts
CHANGED
|
@@ -21,7 +21,7 @@ function createTests(uri: string) {
|
|
|
21
21
|
uri: url.pathname,
|
|
22
22
|
method: "get",
|
|
23
23
|
request: {
|
|
24
|
-
|
|
24
|
+
query: Object.fromEntries(queryMap),
|
|
25
25
|
},
|
|
26
26
|
response: {
|
|
27
27
|
status: 204,
|
|
@@ -61,76 +61,76 @@ Scenarios.Routes_PathParameters_ReservedExpansion_annotation = createTests(
|
|
|
61
61
|
"/routes/path/reserved-expansion/annotation/foo/bar%20baz",
|
|
62
62
|
);
|
|
63
63
|
Scenarios.Routes_PathParameters_SimpleExpansion_Standard_primitive = createTests(
|
|
64
|
-
"/routes/simple/standard/primitivea",
|
|
64
|
+
"/routes/path/simple/standard/primitivea",
|
|
65
65
|
);
|
|
66
66
|
Scenarios.Routes_PathParameters_SimpleExpansion_Standard_array = createTests(
|
|
67
|
-
"/routes/simple/standard/arraya,b",
|
|
67
|
+
"/routes/path/simple/standard/arraya,b",
|
|
68
68
|
);
|
|
69
69
|
Scenarios.Routes_PathParameters_SimpleExpansion_Standard_record = createTests(
|
|
70
|
-
"/routes/simple/standard/recorda,1,b,2",
|
|
70
|
+
"/routes/path/simple/standard/recorda,1,b,2",
|
|
71
71
|
);
|
|
72
72
|
Scenarios.Routes_PathParameters_SimpleExpansion_Explode_primitive = createTests(
|
|
73
|
-
"/routes/simple/
|
|
73
|
+
"/routes/path/simple/explode/primitivea",
|
|
74
74
|
);
|
|
75
75
|
Scenarios.Routes_PathParameters_SimpleExpansion_Explode_array = createTests(
|
|
76
|
-
"/routes/simple/
|
|
76
|
+
"/routes/path/simple/explode/arraya,b",
|
|
77
77
|
);
|
|
78
78
|
Scenarios.Routes_PathParameters_SimpleExpansion_Explode_record = createTests(
|
|
79
|
-
"/routes/simple/
|
|
79
|
+
"/routes/path/simple/explode/recorda=1,b=2",
|
|
80
80
|
);
|
|
81
81
|
Scenarios.Routes_PathParameters_PathExpansion_Standard_primitive = createTests(
|
|
82
|
-
"/routes/path/standard/primitive/a",
|
|
82
|
+
"/routes/path/path/standard/primitive/a",
|
|
83
83
|
);
|
|
84
84
|
Scenarios.Routes_PathParameters_PathExpansion_Standard_array = createTests(
|
|
85
|
-
"/routes/path/standard/array/a,b",
|
|
85
|
+
"/routes/path/path/standard/array/a,b",
|
|
86
86
|
);
|
|
87
87
|
Scenarios.Routes_PathParameters_PathExpansion_Standard_record = createTests(
|
|
88
|
-
"/routes/path/standard/record/a,1,b,2",
|
|
88
|
+
"/routes/path/path/standard/record/a,1,b,2",
|
|
89
89
|
);
|
|
90
90
|
Scenarios.Routes_PathParameters_PathExpansion_Explode_primitive = createTests(
|
|
91
|
-
"/routes/path/
|
|
91
|
+
"/routes/path/path/explode/primitive/a",
|
|
92
92
|
);
|
|
93
93
|
Scenarios.Routes_PathParameters_PathExpansion_Explode_array = createTests(
|
|
94
|
-
"/routes/path/
|
|
94
|
+
"/routes/path/path/explode/array/a/b",
|
|
95
95
|
);
|
|
96
96
|
Scenarios.Routes_PathParameters_PathExpansion_Explode_record = createTests(
|
|
97
|
-
"/routes/path/
|
|
97
|
+
"/routes/path/path/explode/record/a=1/b=2",
|
|
98
98
|
);
|
|
99
99
|
Scenarios.Routes_PathParameters_LabelExpansion_Standard_primitive = createTests(
|
|
100
|
-
"/routes/label/standard/primitive.a",
|
|
100
|
+
"/routes/path/label/standard/primitive.a",
|
|
101
101
|
);
|
|
102
102
|
Scenarios.Routes_PathParameters_LabelExpansion_Standard_array = createTests(
|
|
103
|
-
"/routes/label/standard/array.a,b",
|
|
103
|
+
"/routes/path/label/standard/array.a,b",
|
|
104
104
|
);
|
|
105
105
|
Scenarios.Routes_PathParameters_LabelExpansion_Standard_record = createTests(
|
|
106
|
-
"/routes/label/standard/record.a,1,b,2",
|
|
106
|
+
"/routes/path/label/standard/record.a,1,b,2",
|
|
107
107
|
);
|
|
108
108
|
Scenarios.Routes_PathParameters_LabelExpansion_Explode_primitive = createTests(
|
|
109
|
-
"/routes/label/
|
|
109
|
+
"/routes/path/label/explode/primitive.a",
|
|
110
110
|
);
|
|
111
111
|
Scenarios.Routes_PathParameters_LabelExpansion_Explode_array = createTests(
|
|
112
|
-
"/routes/label/
|
|
112
|
+
"/routes/path/label/explode/array.a.b",
|
|
113
113
|
);
|
|
114
114
|
Scenarios.Routes_PathParameters_LabelExpansion_Explode_record = createTests(
|
|
115
|
-
"/routes/label/
|
|
115
|
+
"/routes/path/label/explode/record.a=1.b=2",
|
|
116
116
|
);
|
|
117
117
|
Scenarios.Routes_PathParameters_MatrixExpansion_Standard_primitive = createTests(
|
|
118
|
-
"/routes/matrix/standard/primitive;a",
|
|
118
|
+
"/routes/path/matrix/standard/primitive;param=a",
|
|
119
119
|
);
|
|
120
120
|
Scenarios.Routes_PathParameters_MatrixExpansion_Standard_array = createTests(
|
|
121
|
-
"/routes/matrix/standard/array;a,b",
|
|
121
|
+
"/routes/path/matrix/standard/array;param=a,b",
|
|
122
122
|
);
|
|
123
123
|
Scenarios.Routes_PathParameters_MatrixExpansion_Standard_record = createTests(
|
|
124
|
-
"/routes/matrix/standard/record;a,1,b,2",
|
|
124
|
+
"/routes/path/matrix/standard/record;param=a,1,b,2",
|
|
125
125
|
);
|
|
126
126
|
Scenarios.Routes_PathParameters_MatrixExpansion_Explode_primitive = createTests(
|
|
127
|
-
"/routes/matrix/
|
|
127
|
+
"/routes/path/matrix/explode/primitive;param=a",
|
|
128
128
|
);
|
|
129
129
|
Scenarios.Routes_PathParameters_MatrixExpansion_Explode_array = createTests(
|
|
130
|
-
"/routes/matrix/
|
|
130
|
+
"/routes/path/matrix/explode/array;param=a;param=b",
|
|
131
131
|
);
|
|
132
132
|
Scenarios.Routes_PathParameters_MatrixExpansion_Explode_record = createTests(
|
|
133
|
-
"/routes/matrix/
|
|
133
|
+
"/routes/path/matrix/explode/record;a=1;b=2",
|
|
134
134
|
);
|
|
135
135
|
Scenarios.Routes_QueryParameters_templateOnly = createTests("/routes/query/template-only?param=a");
|
|
136
136
|
Scenarios.Routes_QueryParameters_explicit = createTests("/routes/query/explicit?param=a");
|
|
@@ -5,7 +5,7 @@ export const Scenarios: Record<string, ScenarioMockApi> = {};
|
|
|
5
5
|
Scenarios.Serialization_EncodedName_Json_Property_send = passOnSuccess({
|
|
6
6
|
uri: "/serialization/encoded-name/json/property",
|
|
7
7
|
method: "post",
|
|
8
|
-
request: { body: { wireName: true } },
|
|
8
|
+
request: { body: json({ wireName: true }) },
|
|
9
9
|
response: { status: 204 },
|
|
10
10
|
kind: "MockApiDefinition",
|
|
11
11
|
});
|
|
@@ -8,9 +8,7 @@ using Spector;
|
|
|
8
8
|
* Illustrates server doesn't define endpoint. Client should automatically add an endpoint to let user pass in.
|
|
9
9
|
*/
|
|
10
10
|
@route("/server/endpoint/not-defined")
|
|
11
|
-
@service({
|
|
12
|
-
title: "Testserver without any endpoint",
|
|
13
|
-
})
|
|
11
|
+
@service(#{ title: "Testserver without any endpoint" })
|
|
14
12
|
namespace Server.Endpoint.NotDefined;
|
|
15
13
|
|
|
16
14
|
@scenario
|
|
@@ -4,13 +4,11 @@ import "@typespec/versioning";
|
|
|
4
4
|
|
|
5
5
|
using Http;
|
|
6
6
|
using Spector;
|
|
7
|
-
using
|
|
8
|
-
using
|
|
7
|
+
using Versioning;
|
|
8
|
+
using Rest;
|
|
9
9
|
|
|
10
10
|
@versioned(Versions)
|
|
11
|
-
@service({
|
|
12
|
-
title: "ServerPathMultiple",
|
|
13
|
-
})
|
|
11
|
+
@service(#{ title: "ServerPathMultiple" })
|
|
14
12
|
@server(
|
|
15
13
|
"{endpoint}/server/path/multiple/{apiVersion}",
|
|
16
14
|
"Test server with path parameters.",
|
|
@@ -31,11 +31,15 @@ Scenarios.Server_Versions_Versioned_withPathApiVersion = createServerTests(
|
|
|
31
31
|
"/server/versions/versioned/with-path-api-version/2022-12-01-preview",
|
|
32
32
|
);
|
|
33
33
|
|
|
34
|
-
function createAPIVersionTests(uri: string,
|
|
34
|
+
function createAPIVersionTests(uri: string, version: string) {
|
|
35
35
|
return passOnSuccess({
|
|
36
36
|
uri,
|
|
37
37
|
method: "head",
|
|
38
|
-
request:
|
|
38
|
+
request: {
|
|
39
|
+
query: {
|
|
40
|
+
"api-version": version,
|
|
41
|
+
},
|
|
42
|
+
},
|
|
39
43
|
response: {
|
|
40
44
|
status: 200,
|
|
41
45
|
},
|
|
@@ -45,20 +49,10 @@ function createAPIVersionTests(uri: string, requestData: any, serverData: string
|
|
|
45
49
|
|
|
46
50
|
Scenarios.Server_Versions_Versioned_withQueryOldApiVersion = createAPIVersionTests(
|
|
47
51
|
"/server/versions/versioned/with-query-old-api-version",
|
|
48
|
-
{
|
|
49
|
-
params: {
|
|
50
|
-
"api-version": "2021-01-01-preview",
|
|
51
|
-
},
|
|
52
|
-
},
|
|
53
52
|
"2021-01-01-preview",
|
|
54
53
|
);
|
|
55
54
|
|
|
56
55
|
Scenarios.Server_Versions_Versioned_withQueryApiVersion = createAPIVersionTests(
|
|
57
56
|
"/server/versions/versioned/with-query-api-version",
|
|
58
|
-
{
|
|
59
|
-
params: {
|
|
60
|
-
"api-version": "2022-12-01-preview",
|
|
61
|
-
},
|
|
62
|
-
},
|
|
63
57
|
"2022-12-01-preview",
|
|
64
58
|
);
|
|
@@ -4,7 +4,7 @@ import "@typespec/spector";
|
|
|
4
4
|
|
|
5
5
|
using Http;
|
|
6
6
|
using Spector;
|
|
7
|
-
using
|
|
7
|
+
using Versioning;
|
|
8
8
|
|
|
9
9
|
@doc("Illustrates OASIS repeatability headers")
|
|
10
10
|
@scenarioService("/special-headers/repeatability")
|
|
@@ -15,7 +15,7 @@ model RepeatableResponse {
|
|
|
15
15
|
@statusCode
|
|
16
16
|
statusCode: 204;
|
|
17
17
|
|
|
18
|
-
@visibility(
|
|
18
|
+
@visibility(Lifecycle.Read)
|
|
19
19
|
@header("Repeatability-Result")
|
|
20
20
|
@doc("Indicates whether the repeatable request was accepted or rejected.")
|
|
21
21
|
repeatabilityResult?: "accepted" | "rejected";
|