@typespec/http-specs 0.1.0-alpha.9 → 0.1.0-dev.1
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 +260 -3
- package/README.md +11 -3
- package/dist/specs/authentication/noauth/union/mockapi.d.ts +3 -0
- package/dist/specs/authentication/noauth/union/mockapi.d.ts.map +1 -0
- package/dist/specs/authentication/noauth/union/mockapi.js +25 -0
- package/dist/specs/authentication/noauth/union/mockapi.js.map +1 -0
- package/dist/specs/documentation/mockapi.d.ts +3 -0
- package/dist/specs/documentation/mockapi.d.ts.map +1 -0
- package/dist/specs/documentation/mockapi.js +40 -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 +33 -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.d.ts.map +1 -1
- package/dist/specs/encode/duration/mockapi.js +115 -3
- 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/query/mockapi.d.ts +3 -0
- package/dist/specs/parameters/query/mockapi.d.ts.map +1 -0
- package/dist/specs/parameters/query/mockapi.js +14 -0
- package/dist/specs/parameters/query/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 +196 -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 +626 -14
- package/dist/specs/payload/pageable/mockapi.js.map +1 -1
- package/dist/specs/payload/xml/mockapi.d.ts +19 -5
- package/dist/specs/payload/xml/mockapi.d.ts.map +1 -1
- package/dist/specs/payload/xml/mockapi.js +311 -55
- package/dist/specs/payload/xml/mockapi.js.map +1 -1
- package/dist/specs/response/status-code-range/mockapi.d.ts.map +1 -1
- package/dist/specs/response/status-code-range/mockapi.js +5 -9
- package/dist/specs/response/status-code-range/mockapi.js.map +1 -1
- package/dist/specs/routes/mockapi.js +16 -16
- 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 +59 -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/file/mockapi.d.ts +3 -0
- package/dist/specs/type/file/mockapi.d.ts.map +1 -0
- package/dist/specs/type/file/mockapi.js +187 -0
- package/dist/specs/type/file/mockapi.js.map +1 -0
- 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 +11 -11
- 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/manifest.json +11545 -0
- package/package.json +31 -20
- package/smoke/petstore/main.tsp +96 -0
- package/smoke/todoapp/main.tsp +293 -0
- package/spec-summary.md +2137 -121
- package/specs/authentication/noauth/union/main.tsp +30 -0
- package/specs/authentication/noauth/union/mockapi.ts +27 -0
- package/specs/documentation/main.tsp +158 -0
- package/specs/documentation/mockapi.ts +59 -0
- package/specs/encode/array/main.tsp +339 -0
- package/specs/encode/array/mockapi.ts +83 -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 +221 -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/query/main.tsp +22 -0
- package/specs/parameters/query/mockapi.ts +15 -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 +230 -32
- package/specs/payload/multipart/mockapi.ts +207 -59
- package/specs/payload/pageable/main.tsp +648 -0
- package/specs/payload/pageable/mockapi.ts +691 -14
- package/specs/payload/xml/main.tsp +532 -132
- package/specs/payload/xml/mockapi.ts +402 -67
- package/specs/response/status-code-range/main.tsp +2 -2
- package/specs/response/status-code-range/mockapi.ts +5 -9
- package/specs/routes/main.tsp +29 -29
- package/specs/routes/mockapi.ts +16 -16
- 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 +124 -6
- package/specs/special-words/mockapi.ts +62 -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/file/main.tsp +109 -0
- package/specs/type/file/mockapi.ts +200 -0
- 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 +9 -17
- 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 +5 -5
- package/specs/versioning/removed/mockapi.ts +11 -11
- 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/tsconfig.build.json +0 -4
- package/tspconfig.yaml +0 -2
package/specs/routes/main.tsp
CHANGED
|
@@ -99,7 +99,7 @@ namespace PathParameters {
|
|
|
99
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("""
|
|
@@ -108,7 +108,7 @@ namespace PathParameters {
|
|
|
108
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")
|
|
@@ -129,7 +129,7 @@ namespace PathParameters {
|
|
|
129
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("""
|
|
@@ -138,7 +138,7 @@ namespace PathParameters {
|
|
|
138
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
|
|
|
@@ -162,7 +162,7 @@ namespace PathParameters {
|
|
|
162
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("""
|
|
@@ -171,7 +171,7 @@ namespace PathParameters {
|
|
|
171
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")
|
|
@@ -192,7 +192,7 @@ namespace PathParameters {
|
|
|
192
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("""
|
|
@@ -201,7 +201,7 @@ namespace PathParameters {
|
|
|
201
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
|
|
|
@@ -225,7 +225,7 @@ namespace PathParameters {
|
|
|
225
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("""
|
|
@@ -234,7 +234,7 @@ namespace PathParameters {
|
|
|
234
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")
|
|
@@ -255,7 +255,7 @@ namespace PathParameters {
|
|
|
255
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("""
|
|
@@ -264,7 +264,7 @@ namespace PathParameters {
|
|
|
264
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/path/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/path/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/path/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/path/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,10 +315,10 @@ 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/path/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("""
|
|
@@ -327,7 +327,7 @@ namespace PathParameters {
|
|
|
327
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,
|
|
@@ -70,13 +70,13 @@ Scenarios.Routes_PathParameters_SimpleExpansion_Standard_record = createTests(
|
|
|
70
70
|
"/routes/path/simple/standard/recorda,1,b,2",
|
|
71
71
|
);
|
|
72
72
|
Scenarios.Routes_PathParameters_SimpleExpansion_Explode_primitive = createTests(
|
|
73
|
-
"/routes/path/simple/
|
|
73
|
+
"/routes/path/simple/explode/primitivea",
|
|
74
74
|
);
|
|
75
75
|
Scenarios.Routes_PathParameters_SimpleExpansion_Explode_array = createTests(
|
|
76
|
-
"/routes/path/simple/
|
|
76
|
+
"/routes/path/simple/explode/arraya,b",
|
|
77
77
|
);
|
|
78
78
|
Scenarios.Routes_PathParameters_SimpleExpansion_Explode_record = createTests(
|
|
79
|
-
"/routes/path/simple/
|
|
79
|
+
"/routes/path/simple/explode/recorda=1,b=2",
|
|
80
80
|
);
|
|
81
81
|
Scenarios.Routes_PathParameters_PathExpansion_Standard_primitive = createTests(
|
|
82
82
|
"/routes/path/path/standard/primitive/a",
|
|
@@ -88,13 +88,13 @@ Scenarios.Routes_PathParameters_PathExpansion_Standard_record = createTests(
|
|
|
88
88
|
"/routes/path/path/standard/record/a,1,b,2",
|
|
89
89
|
);
|
|
90
90
|
Scenarios.Routes_PathParameters_PathExpansion_Explode_primitive = createTests(
|
|
91
|
-
"/routes/path/path/
|
|
91
|
+
"/routes/path/path/explode/primitive/a",
|
|
92
92
|
);
|
|
93
93
|
Scenarios.Routes_PathParameters_PathExpansion_Explode_array = createTests(
|
|
94
|
-
"/routes/path/path/
|
|
94
|
+
"/routes/path/path/explode/array/a/b",
|
|
95
95
|
);
|
|
96
96
|
Scenarios.Routes_PathParameters_PathExpansion_Explode_record = createTests(
|
|
97
|
-
"/routes/path/path/
|
|
97
|
+
"/routes/path/path/explode/record/a=1/b=2",
|
|
98
98
|
);
|
|
99
99
|
Scenarios.Routes_PathParameters_LabelExpansion_Standard_primitive = createTests(
|
|
100
100
|
"/routes/path/label/standard/primitive.a",
|
|
@@ -106,31 +106,31 @@ Scenarios.Routes_PathParameters_LabelExpansion_Standard_record = createTests(
|
|
|
106
106
|
"/routes/path/label/standard/record.a,1,b,2",
|
|
107
107
|
);
|
|
108
108
|
Scenarios.Routes_PathParameters_LabelExpansion_Explode_primitive = createTests(
|
|
109
|
-
"/routes/path/label/
|
|
109
|
+
"/routes/path/label/explode/primitive.a",
|
|
110
110
|
);
|
|
111
111
|
Scenarios.Routes_PathParameters_LabelExpansion_Explode_array = createTests(
|
|
112
|
-
"/routes/path/label/
|
|
112
|
+
"/routes/path/label/explode/array.a.b",
|
|
113
113
|
);
|
|
114
114
|
Scenarios.Routes_PathParameters_LabelExpansion_Explode_record = createTests(
|
|
115
|
-
"/routes/path/label/
|
|
115
|
+
"/routes/path/label/explode/record.a=1.b=2",
|
|
116
116
|
);
|
|
117
117
|
Scenarios.Routes_PathParameters_MatrixExpansion_Standard_primitive = createTests(
|
|
118
|
-
"/routes/path/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/path/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/path/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/path/matrix/
|
|
127
|
+
"/routes/path/matrix/explode/primitive;param=a",
|
|
128
128
|
);
|
|
129
129
|
Scenarios.Routes_PathParameters_MatrixExpansion_Explode_array = createTests(
|
|
130
|
-
"/routes/path/matrix/
|
|
130
|
+
"/routes/path/matrix/explode/array;param=a;param=b",
|
|
131
131
|
);
|
|
132
132
|
Scenarios.Routes_PathParameters_MatrixExpansion_Explode_record = createTests(
|
|
133
|
-
"/routes/path/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";
|
|
@@ -34,6 +34,7 @@ using Spector;
|
|
|
34
34
|
* in
|
|
35
35
|
* is
|
|
36
36
|
* lambda
|
|
37
|
+
* list
|
|
37
38
|
* not
|
|
38
39
|
* or
|
|
39
40
|
* pass
|
|
@@ -56,7 +57,7 @@ interface Operations {
|
|
|
56
57
|
@opNameScenario("and") and(): void;
|
|
57
58
|
@opNameScenario("as") as(): void;
|
|
58
59
|
@opNameScenario("assert") assert(): void;
|
|
59
|
-
@opNameScenario("async") async(): void;
|
|
60
|
+
@opNameScenario("async") `async`(): void;
|
|
60
61
|
@opNameScenario("await") await(): void;
|
|
61
62
|
@opNameScenario("break") break(): void;
|
|
62
63
|
@opNameScenario("class") class(): void;
|
|
@@ -84,7 +85,7 @@ interface Operations {
|
|
|
84
85
|
@opNameScenario("return") `return`(): void;
|
|
85
86
|
@opNameScenario("try") try(): void;
|
|
86
87
|
@opNameScenario("while") while(): void;
|
|
87
|
-
@opNameScenario("with") with(): void;
|
|
88
|
+
@opNameScenario("with") `with`(): void;
|
|
88
89
|
@opNameScenario("yield") yield(): void;
|
|
89
90
|
}
|
|
90
91
|
|
|
@@ -144,7 +145,7 @@ namespace Models {
|
|
|
144
145
|
model and is Base;
|
|
145
146
|
model as is Base;
|
|
146
147
|
model assert is Base;
|
|
147
|
-
model async is Base;
|
|
148
|
+
model `async` is Base;
|
|
148
149
|
model await is Base;
|
|
149
150
|
model break is Base;
|
|
150
151
|
model class is Base;
|
|
@@ -172,13 +173,13 @@ namespace Models {
|
|
|
172
173
|
model `return` is Base;
|
|
173
174
|
model try is Base;
|
|
174
175
|
model while is Base;
|
|
175
|
-
model with is Base;
|
|
176
|
+
model `with` is Base;
|
|
176
177
|
model yield is Base;
|
|
177
178
|
|
|
178
179
|
@modelNameScenario("and") op withAnd(@body body: and): void;
|
|
179
180
|
@modelNameScenario("as") op withAs(@body body: as): void;
|
|
180
181
|
@modelNameScenario("assert") op withAssert(@body body: assert): void;
|
|
181
|
-
@modelNameScenario("async") op withAsync(@body body: async): void;
|
|
182
|
+
@modelNameScenario("async") op withAsync(@body body: `async`): void;
|
|
182
183
|
@modelNameScenario("await") op withAwait(@body body: await): void;
|
|
183
184
|
@modelNameScenario("break") op withBreak(@body body: break): void;
|
|
184
185
|
@modelNameScenario("class") op withClass(@body body: class): void;
|
|
@@ -206,7 +207,7 @@ namespace Models {
|
|
|
206
207
|
@modelNameScenario("return") op withReturn(@body body: `return`): void;
|
|
207
208
|
@modelNameScenario("try") op withTry(@body body: try): void;
|
|
208
209
|
@modelNameScenario("while") op withWhile(@body body: while): void;
|
|
209
|
-
@modelNameScenario("with") op withWith(@body body: with): void;
|
|
210
|
+
@modelNameScenario("with") op withWith(@body body: `with`): void;
|
|
210
211
|
@modelNameScenario("yield") op withYield(@body body: yield): void;
|
|
211
212
|
}
|
|
212
213
|
|
|
@@ -231,4 +232,121 @@ namespace ModelProperties {
|
|
|
231
232
|
""")
|
|
232
233
|
@route("same-as-model")
|
|
233
234
|
op sameAsModel(@body body: SameAsModel): void;
|
|
235
|
+
|
|
236
|
+
// Python dict method names that could conflict
|
|
237
|
+
model DictMethods {
|
|
238
|
+
keys: string;
|
|
239
|
+
items: string;
|
|
240
|
+
values: string;
|
|
241
|
+
popitem: string;
|
|
242
|
+
clear: string;
|
|
243
|
+
update: string;
|
|
244
|
+
setdefault: string;
|
|
245
|
+
pop: string;
|
|
246
|
+
get: string;
|
|
247
|
+
copy: string;
|
|
248
|
+
}
|
|
249
|
+
|
|
250
|
+
@scenario
|
|
251
|
+
@scenarioDoc("""
|
|
252
|
+
Verify that model properties can use names that are Python dict methods. These names (keys, items, values, etc.) may conflict with Python's dict class methods.
|
|
253
|
+
|
|
254
|
+
Send
|
|
255
|
+
|
|
256
|
+
```json
|
|
257
|
+
{
|
|
258
|
+
"keys": "ok",
|
|
259
|
+
"items": "ok",
|
|
260
|
+
"values": "ok",
|
|
261
|
+
"popitem": "ok",
|
|
262
|
+
"clear": "ok",
|
|
263
|
+
"update": "ok",
|
|
264
|
+
"setdefault": "ok",
|
|
265
|
+
"pop": "ok",
|
|
266
|
+
"get": "ok",
|
|
267
|
+
"copy": "ok"
|
|
268
|
+
}
|
|
269
|
+
```
|
|
270
|
+
""")
|
|
271
|
+
@route("dict-methods")
|
|
272
|
+
op dictMethods(@body body: DictMethods): void;
|
|
273
|
+
|
|
274
|
+
// Test for model property named "list" which is a reserved word in many languages
|
|
275
|
+
model ModelWithList {
|
|
276
|
+
list: string;
|
|
277
|
+
}
|
|
278
|
+
|
|
279
|
+
@scenario
|
|
280
|
+
@scenarioDoc("""
|
|
281
|
+
Verify that a property can be named "list", which is a reserved word in many languages like Python.
|
|
282
|
+
|
|
283
|
+
Send
|
|
284
|
+
|
|
285
|
+
```json
|
|
286
|
+
{"list": "ok"}
|
|
287
|
+
```
|
|
288
|
+
""")
|
|
289
|
+
@route("list")
|
|
290
|
+
op withList(@body body: ModelWithList): void;
|
|
291
|
+
}
|
|
292
|
+
|
|
293
|
+
/**
|
|
294
|
+
* Verify enum member names that are special words.
|
|
295
|
+
*/
|
|
296
|
+
@route("/extensible-strings")
|
|
297
|
+
namespace ExtensibleStrings {
|
|
298
|
+
/**
|
|
299
|
+
* Verify enum member names that are special words using extensible enum (union).
|
|
300
|
+
*/
|
|
301
|
+
union ExtensibleString {
|
|
302
|
+
string,
|
|
303
|
+
and: "and",
|
|
304
|
+
as: "as",
|
|
305
|
+
assert: "assert",
|
|
306
|
+
async: "async",
|
|
307
|
+
await: "await",
|
|
308
|
+
break: "break",
|
|
309
|
+
class: "class",
|
|
310
|
+
constructor: "constructor",
|
|
311
|
+
continue: "continue",
|
|
312
|
+
def: "def",
|
|
313
|
+
del: "del",
|
|
314
|
+
elif: "elif",
|
|
315
|
+
`else`: "else",
|
|
316
|
+
except: "except",
|
|
317
|
+
exec: "exec",
|
|
318
|
+
finally: "finally",
|
|
319
|
+
for: "for",
|
|
320
|
+
from: "from",
|
|
321
|
+
global: "global",
|
|
322
|
+
`if`: "if",
|
|
323
|
+
`import`: "import",
|
|
324
|
+
in: "in",
|
|
325
|
+
`is`: "is",
|
|
326
|
+
lambda: "lambda",
|
|
327
|
+
not: "not",
|
|
328
|
+
or: "or",
|
|
329
|
+
pass: "pass",
|
|
330
|
+
raise: "raise",
|
|
331
|
+
`return`: "return",
|
|
332
|
+
try: "try",
|
|
333
|
+
while: "while",
|
|
334
|
+
with: "with",
|
|
335
|
+
yield: "yield",
|
|
336
|
+
}
|
|
337
|
+
|
|
338
|
+
@scenario
|
|
339
|
+
@scenarioDoc("""
|
|
340
|
+
Verify that enum members with special word names can be sent and received properly.
|
|
341
|
+
Send 'class' and expect the same value back.
|
|
342
|
+
""")
|
|
343
|
+
@put
|
|
344
|
+
@route("/string")
|
|
345
|
+
op putExtensibleStringValue(
|
|
346
|
+
@header contentType: "application/json",
|
|
347
|
+
@body body: ExtensibleString,
|
|
348
|
+
): {
|
|
349
|
+
@header contentType: "application/json";
|
|
350
|
+
@body body: ExtensibleString;
|
|
351
|
+
};
|
|
234
352
|
}
|