@typespec/http-specs 0.1.0-alpha.9 → 0.1.0-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.
Files changed (224) hide show
  1. package/CHANGELOG.md +241 -3
  2. package/README.md +11 -3
  3. package/dist/specs/authentication/noauth/union/mockapi.d.ts +3 -0
  4. package/dist/specs/authentication/noauth/union/mockapi.d.ts.map +1 -0
  5. package/dist/specs/authentication/noauth/union/mockapi.js +25 -0
  6. package/dist/specs/authentication/noauth/union/mockapi.js.map +1 -0
  7. package/dist/specs/documentation/mockapi.d.ts +3 -0
  8. package/dist/specs/documentation/mockapi.d.ts.map +1 -0
  9. package/dist/specs/documentation/mockapi.js +40 -0
  10. package/dist/specs/documentation/mockapi.js.map +1 -0
  11. package/dist/specs/encode/array/mockapi.d.ts +3 -0
  12. package/dist/specs/encode/array/mockapi.d.ts.map +1 -0
  13. package/dist/specs/encode/array/mockapi.js +33 -0
  14. package/dist/specs/encode/array/mockapi.js.map +1 -0
  15. package/dist/specs/encode/bytes/mockapi.js +16 -24
  16. package/dist/specs/encode/bytes/mockapi.js.map +1 -1
  17. package/dist/specs/encode/datetime/mockapi.js +2 -2
  18. package/dist/specs/encode/datetime/mockapi.js.map +1 -1
  19. package/dist/specs/encode/duration/mockapi.d.ts.map +1 -1
  20. package/dist/specs/encode/duration/mockapi.js +110 -3
  21. package/dist/specs/encode/duration/mockapi.js.map +1 -1
  22. package/dist/specs/encode/numeric/mockapi.js +2 -2
  23. package/dist/specs/encode/numeric/mockapi.js.map +1 -1
  24. package/dist/specs/helper.d.ts +2 -2
  25. package/dist/specs/helper.d.ts.map +1 -1
  26. package/dist/specs/parameters/basic/mockapi.d.ts.map +1 -1
  27. package/dist/specs/parameters/basic/mockapi.js +3 -3
  28. package/dist/specs/parameters/basic/mockapi.js.map +1 -1
  29. package/dist/specs/parameters/body-optionality/mockapi.d.ts.map +1 -1
  30. package/dist/specs/parameters/body-optionality/mockapi.js +14 -4
  31. package/dist/specs/parameters/body-optionality/mockapi.js.map +1 -1
  32. package/dist/specs/parameters/collection-format/mockapi.js +4 -15
  33. package/dist/specs/parameters/collection-format/mockapi.js.map +1 -1
  34. package/dist/specs/parameters/path/mockapi.d.ts +3 -0
  35. package/dist/specs/parameters/path/mockapi.d.ts.map +1 -0
  36. package/dist/specs/parameters/path/mockapi.js +29 -0
  37. package/dist/specs/parameters/path/mockapi.js.map +1 -0
  38. package/dist/specs/parameters/query/mockapi.d.ts +3 -0
  39. package/dist/specs/parameters/query/mockapi.d.ts.map +1 -0
  40. package/dist/specs/parameters/query/mockapi.js +14 -0
  41. package/dist/specs/parameters/query/mockapi.js.map +1 -0
  42. package/dist/specs/parameters/spread/mockapi.d.ts.map +1 -1
  43. package/dist/specs/parameters/spread/mockapi.js +19 -19
  44. package/dist/specs/parameters/spread/mockapi.js.map +1 -1
  45. package/dist/specs/payload/json-merge-patch/mockapi.js +4 -4
  46. package/dist/specs/payload/json-merge-patch/mockapi.js.map +1 -1
  47. package/dist/specs/payload/media-type/mockapi.js +2 -2
  48. package/dist/specs/payload/media-type/mockapi.js.map +1 -1
  49. package/dist/specs/payload/multipart/mockapi.d.ts.map +1 -1
  50. package/dist/specs/payload/multipart/mockapi.js +189 -60
  51. package/dist/specs/payload/multipart/mockapi.js.map +1 -1
  52. package/dist/specs/payload/pageable/mockapi.d.ts.map +1 -1
  53. package/dist/specs/payload/pageable/mockapi.js +594 -14
  54. package/dist/specs/payload/pageable/mockapi.js.map +1 -1
  55. package/dist/specs/payload/xml/mockapi.d.ts +3 -0
  56. package/dist/specs/payload/xml/mockapi.d.ts.map +1 -1
  57. package/dist/specs/payload/xml/mockapi.js +35 -5
  58. package/dist/specs/payload/xml/mockapi.js.map +1 -1
  59. package/dist/specs/response/status-code-range/mockapi.d.ts.map +1 -1
  60. package/dist/specs/response/status-code-range/mockapi.js +5 -9
  61. package/dist/specs/response/status-code-range/mockapi.js.map +1 -1
  62. package/dist/specs/routes/mockapi.js +16 -16
  63. package/dist/specs/routes/mockapi.js.map +1 -1
  64. package/dist/specs/serialization/encoded-name/json/mockapi.js +1 -1
  65. package/dist/specs/serialization/encoded-name/json/mockapi.js.map +1 -1
  66. package/dist/specs/server/versions/not-versioned/mockapi.js +1 -1
  67. package/dist/specs/server/versions/not-versioned/mockapi.js.map +1 -1
  68. package/dist/specs/server/versions/versioned/mockapi.js +8 -12
  69. package/dist/specs/server/versions/versioned/mockapi.js.map +1 -1
  70. package/dist/specs/special-words/mockapi.d.ts.map +1 -1
  71. package/dist/specs/special-words/mockapi.js +59 -6
  72. package/dist/specs/special-words/mockapi.js.map +1 -1
  73. package/dist/specs/streaming/jsonl/mockapi.d.ts +3 -0
  74. package/dist/specs/streaming/jsonl/mockapi.d.ts.map +1 -0
  75. package/dist/specs/streaming/jsonl/mockapi.js +30 -0
  76. package/dist/specs/streaming/jsonl/mockapi.js.map +1 -0
  77. package/dist/specs/type/array/mockapi.js +1 -1
  78. package/dist/specs/type/array/mockapi.js.map +1 -1
  79. package/dist/specs/type/dictionary/mockapi.js +1 -1
  80. package/dist/specs/type/dictionary/mockapi.js.map +1 -1
  81. package/dist/specs/type/enum/extensible/mockapi.js +1 -1
  82. package/dist/specs/type/enum/extensible/mockapi.js.map +1 -1
  83. package/dist/specs/type/enum/fixed/mockapi.js +2 -2
  84. package/dist/specs/type/enum/fixed/mockapi.js.map +1 -1
  85. package/dist/specs/type/file/mockapi.d.ts +3 -0
  86. package/dist/specs/type/file/mockapi.d.ts.map +1 -0
  87. package/dist/specs/type/file/mockapi.js +187 -0
  88. package/dist/specs/type/file/mockapi.js.map +1 -0
  89. package/dist/specs/type/model/empty/mockapi.js +2 -2
  90. package/dist/specs/type/model/empty/mockapi.js.map +1 -1
  91. package/dist/specs/type/model/inheritance/enum-discriminator/mockapi.js +1 -1
  92. package/dist/specs/type/model/inheritance/enum-discriminator/mockapi.js.map +1 -1
  93. package/dist/specs/type/model/inheritance/nested-discriminator/mockapi.js +2 -2
  94. package/dist/specs/type/model/inheritance/nested-discriminator/mockapi.js.map +1 -1
  95. package/dist/specs/type/model/inheritance/not-discriminated/mockapi.js +2 -2
  96. package/dist/specs/type/model/inheritance/not-discriminated/mockapi.js.map +1 -1
  97. package/dist/specs/type/model/inheritance/recursive/mockapi.js +1 -1
  98. package/dist/specs/type/model/inheritance/recursive/mockapi.js.map +1 -1
  99. package/dist/specs/type/model/inheritance/single-discriminator/mockapi.js +2 -2
  100. package/dist/specs/type/model/inheritance/single-discriminator/mockapi.js.map +1 -1
  101. package/dist/specs/type/model/usage/mockapi.js +4 -4
  102. package/dist/specs/type/model/usage/mockapi.js.map +1 -1
  103. package/dist/specs/type/model/visibility/mockapi.js +9 -10
  104. package/dist/specs/type/model/visibility/mockapi.js.map +1 -1
  105. package/dist/specs/type/property/additional-properties/mockapi.js +9 -6
  106. package/dist/specs/type/property/additional-properties/mockapi.js.map +1 -1
  107. package/dist/specs/type/property/nullable/mockapi.js +2 -6
  108. package/dist/specs/type/property/nullable/mockapi.js.map +1 -1
  109. package/dist/specs/type/property/optionality/mockapi.js +1 -1
  110. package/dist/specs/type/property/optionality/mockapi.js.map +1 -1
  111. package/dist/specs/type/property/value-types/mockapi.js +3 -3
  112. package/dist/specs/type/property/value-types/mockapi.js.map +1 -1
  113. package/dist/specs/type/scalar/mockapi.js +9 -9
  114. package/dist/specs/type/scalar/mockapi.js.map +1 -1
  115. package/dist/specs/type/union/discriminated/mockapi.d.ts +3 -0
  116. package/dist/specs/type/union/discriminated/mockapi.d.ts.map +1 -0
  117. package/dist/specs/type/union/discriminated/mockapi.js +212 -0
  118. package/dist/specs/type/union/discriminated/mockapi.js.map +1 -0
  119. package/dist/specs/type/union/mockapi.js +2 -2
  120. package/dist/specs/type/union/mockapi.js.map +1 -1
  121. package/dist/specs/versioning/added/mockapi.js +6 -6
  122. package/dist/specs/versioning/added/mockapi.js.map +1 -1
  123. package/dist/specs/versioning/madeOptional/mockapi.js +2 -2
  124. package/dist/specs/versioning/madeOptional/mockapi.js.map +1 -1
  125. package/dist/specs/versioning/removed/mockapi.js +11 -11
  126. package/dist/specs/versioning/removed/mockapi.js.map +1 -1
  127. package/dist/specs/versioning/renamedFrom/mockapi.js +5 -5
  128. package/dist/specs/versioning/renamedFrom/mockapi.js.map +1 -1
  129. package/dist/specs/versioning/returnTypeChangedFrom/mockapi.js +1 -1
  130. package/dist/specs/versioning/returnTypeChangedFrom/mockapi.js.map +1 -1
  131. package/dist/specs/versioning/typeChangedFrom/mockapi.js +3 -3
  132. package/dist/specs/versioning/typeChangedFrom/mockapi.js.map +1 -1
  133. package/manifest.json +11200 -0
  134. package/package.json +30 -19
  135. package/smoke/petstore/main.tsp +96 -0
  136. package/smoke/todoapp/main.tsp +293 -0
  137. package/spec-summary.md +1745 -121
  138. package/specs/authentication/noauth/union/main.tsp +30 -0
  139. package/specs/authentication/noauth/union/mockapi.ts +27 -0
  140. package/specs/documentation/main.tsp +158 -0
  141. package/specs/documentation/mockapi.ts +59 -0
  142. package/specs/encode/array/main.tsp +339 -0
  143. package/specs/encode/array/mockapi.ts +83 -0
  144. package/specs/encode/bytes/main.tsp +29 -20
  145. package/specs/encode/bytes/mockapi.ts +13 -31
  146. package/specs/encode/datetime/main.tsp +2 -7
  147. package/specs/encode/datetime/mockapi.ts +2 -2
  148. package/specs/encode/duration/main.tsp +420 -7
  149. package/specs/encode/duration/mockapi.ts +216 -2
  150. package/specs/encode/numeric/mockapi.ts +2 -2
  151. package/specs/parameters/basic/mockapi.ts +3 -3
  152. package/specs/parameters/body-optionality/main.tsp +2 -0
  153. package/specs/parameters/body-optionality/mockapi.ts +24 -4
  154. package/specs/parameters/collection-format/main.tsp +5 -25
  155. package/specs/parameters/collection-format/mockapi.ts +4 -16
  156. package/specs/parameters/path/main.tsp +48 -0
  157. package/specs/parameters/path/mockapi.ts +34 -0
  158. package/specs/parameters/query/main.tsp +22 -0
  159. package/specs/parameters/query/mockapi.ts +15 -0
  160. package/specs/parameters/spread/mockapi.ts +19 -19
  161. package/specs/payload/json-merge-patch/main.tsp +2 -2
  162. package/specs/payload/json-merge-patch/mockapi.ts +4 -4
  163. package/specs/payload/media-type/mockapi.ts +2 -2
  164. package/specs/payload/multipart/main.tsp +230 -32
  165. package/specs/payload/multipart/mockapi.ts +200 -59
  166. package/specs/payload/pageable/main.tsp +601 -0
  167. package/specs/payload/pageable/mockapi.ts +656 -14
  168. package/specs/payload/xml/main.tsp +89 -0
  169. package/specs/payload/xml/mockapi.ts +44 -5
  170. package/specs/response/status-code-range/main.tsp +2 -2
  171. package/specs/response/status-code-range/mockapi.ts +5 -9
  172. package/specs/routes/main.tsp +29 -29
  173. package/specs/routes/mockapi.ts +16 -16
  174. package/specs/serialization/encoded-name/json/main.tsp +1 -1
  175. package/specs/serialization/encoded-name/json/mockapi.ts +1 -1
  176. package/specs/server/endpoint/not-defined/main.tsp +1 -3
  177. package/specs/server/path/multiple/main.tsp +3 -5
  178. package/specs/server/versions/not-versioned/mockapi.ts +1 -1
  179. package/specs/server/versions/versioned/main.tsp +1 -1
  180. package/specs/server/versions/versioned/mockapi.ts +6 -12
  181. package/specs/special-headers/conditional-request/main.tsp +1 -1
  182. package/specs/special-headers/repeatability/main.tsp +2 -2
  183. package/specs/special-words/main.tsp +118 -6
  184. package/specs/special-words/mockapi.ts +62 -6
  185. package/specs/streaming/jsonl/main.tsp +33 -0
  186. package/specs/streaming/jsonl/mockapi.ts +32 -0
  187. package/specs/type/array/mockapi.ts +1 -1
  188. package/specs/type/dictionary/mockapi.ts +1 -1
  189. package/specs/type/enum/extensible/main.tsp +18 -2
  190. package/specs/type/enum/extensible/mockapi.ts +1 -1
  191. package/specs/type/enum/fixed/main.tsp +15 -3
  192. package/specs/type/enum/fixed/mockapi.ts +2 -2
  193. package/specs/type/file/main.tsp +109 -0
  194. package/specs/type/file/mockapi.ts +200 -0
  195. package/specs/type/model/empty/mockapi.ts +2 -2
  196. package/specs/type/model/inheritance/enum-discriminator/mockapi.ts +1 -1
  197. package/specs/type/model/inheritance/nested-discriminator/mockapi.ts +2 -2
  198. package/specs/type/model/inheritance/not-discriminated/mockapi.ts +2 -2
  199. package/specs/type/model/inheritance/recursive/mockapi.ts +1 -1
  200. package/specs/type/model/inheritance/single-discriminator/mockapi.ts +2 -2
  201. package/specs/type/model/usage/mockapi.ts +4 -4
  202. package/specs/type/model/visibility/main.tsp +9 -17
  203. package/specs/type/model/visibility/mockapi.ts +9 -10
  204. package/specs/type/property/additional-properties/main.tsp +17 -17
  205. package/specs/type/property/additional-properties/mockapi.ts +10 -10
  206. package/specs/type/property/nullable/mockapi.ts +7 -8
  207. package/specs/type/property/optionality/mockapi.ts +1 -1
  208. package/specs/type/property/value-types/mockapi.ts +3 -3
  209. package/specs/type/scalar/main.tsp +58 -9
  210. package/specs/type/scalar/mockapi.ts +9 -9
  211. package/specs/type/union/discriminated/main.tsp +251 -0
  212. package/specs/type/union/discriminated/mockapi.ts +230 -0
  213. package/specs/type/union/mockapi.ts +2 -2
  214. package/specs/versioning/added/mockapi.ts +6 -6
  215. package/specs/versioning/madeOptional/mockapi.ts +2 -2
  216. package/specs/versioning/removed/main.tsp +5 -5
  217. package/specs/versioning/removed/mockapi.ts +11 -11
  218. package/specs/versioning/renamedFrom/mockapi.ts +5 -5
  219. package/specs/versioning/returnTypeChangedFrom/main.tsp +17 -2
  220. package/specs/versioning/returnTypeChangedFrom/mockapi.ts +1 -1
  221. package/specs/versioning/typeChangedFrom/mockapi.ts +3 -3
  222. package/temp/.tsbuildinfo +1 -1
  223. package/tsconfig.build.json +0 -4
  224. package/tspconfig.yaml +0 -2
@@ -82,6 +82,50 @@ model ModelWithEncodedNames {
82
82
  @encodedName("application/xml", "PossibleColors") colors: string[];
83
83
  }
84
84
 
85
+ @doc("Status values for the model with enum.")
86
+ union Status {
87
+ string,
88
+
89
+ @doc("Pending status.")
90
+ pending: "pending",
91
+
92
+ @doc("Success status.")
93
+ success: "success",
94
+
95
+ @doc("Error status.")
96
+ error: "error",
97
+ }
98
+
99
+ @doc("Contains a single property with an enum value.")
100
+ model ModelWithEnum {
101
+ status: Status;
102
+ }
103
+
104
+ @doc("Contains datetime properties with different encodings.")
105
+ model ModelWithDatetime {
106
+ @encode(DateTimeKnownEncoding.rfc3339)
107
+ @doc("DateTime value with rfc3339 encoding.")
108
+ rfc3339: utcDateTime;
109
+
110
+ @encode(DateTimeKnownEncoding.rfc7231)
111
+ @doc("DateTime value with rfc7231 encoding.")
112
+ rfc7231: utcDateTime;
113
+ }
114
+
115
+ @doc("An error response body in XML format.")
116
+ @error
117
+ model XmlError {
118
+ @statusCode _: 400;
119
+ @header("content-type") contentType: "application/xml";
120
+ @body body: XmlErrorBody;
121
+ }
122
+
123
+ @doc("The body of an XML error response.")
124
+ model XmlErrorBody {
125
+ message: string;
126
+ code: int32;
127
+ }
128
+
85
129
  @doc("Template for XML operations")
86
130
  interface XmlOperations<TModel, TDoc extends valueof string> {
87
131
  @scenario
@@ -300,3 +344,48 @@ interface ModelWithEncodedNamesValue
300
344
  </ModelWithEncodedNamesSrc>
301
345
  """
302
346
  > {}
347
+
348
+ @doc("Operations for the ModelWithEnum type.")
349
+ @route("/modelWithEnum")
350
+ interface ModelWithEnumValue
351
+ extends XmlOperations<
352
+ ModelWithEnum,
353
+ """
354
+ <ModelWithEnum>
355
+ <status>success</status>
356
+ </ModelWithEnum>
357
+ """
358
+ > {}
359
+
360
+ @doc("Operations for the ModelWithDatetime type.")
361
+ @route("/modelWithDatetime")
362
+ interface ModelWithDatetimeValue
363
+ extends XmlOperations<
364
+ ModelWithDatetime,
365
+ """
366
+ <ModelWithDatetime>
367
+ <rfc3339>2022-08-26T18:38:00.000Z</rfc3339>
368
+ <rfc7231>Fri, 26 Aug 2022 14:38:00 GMT</rfc7231>
369
+ </ModelWithDatetime>
370
+ """
371
+ > {}
372
+
373
+ @doc("Operations that return an error response in XML format.")
374
+ @route("/error")
375
+ interface XmlErrorValue {
376
+ @scenario
377
+ @scenarioDoc("""
378
+ Expected error response body:
379
+ ```xml
380
+ <XmlErrorBody>
381
+ <message>Something went wrong</message>
382
+ <code>400</code>
383
+ </XmlErrorBody>
384
+ ```
385
+ """)
386
+ @get
387
+ get(): {
388
+ @header("content-type") contentType: "application/xml";
389
+ @body body: SimpleModel;
390
+ } | XmlError;
391
+ }
@@ -1,4 +1,4 @@
1
- import { MockRequest, passOnSuccess, ScenarioMockApi, xml } from "@typespec/spec-api";
1
+ import { MockRequest, passOnCode, passOnSuccess, ScenarioMockApi, xml } from "@typespec/spec-api";
2
2
 
3
3
  export const Scenarios: Record<string, ScenarioMockApi> = {};
4
4
 
@@ -123,6 +123,19 @@ export const modelWithEncodedNames = `
123
123
  </ModelWithEncodedNamesSrc>
124
124
  `;
125
125
 
126
+ export const modelWithEnum = `
127
+ <ModelWithEnum>
128
+ <status>success</status>
129
+ </ModelWithEnum>
130
+ `;
131
+
132
+ export const modelWithDatetime = `
133
+ <ModelWithDatetime>
134
+ <rfc3339>2022-08-26T18:38:00.000Z</rfc3339>
135
+ <rfc7231>Fri, 26 Aug 2022 14:38:00 GMT</rfc7231>
136
+ </ModelWithDatetime>
137
+ `;
138
+
126
139
  function createServerTests(uri: string, data?: any) {
127
140
  return {
128
141
  get: passOnSuccess({
@@ -139,10 +152,7 @@ function createServerTests(uri: string, data?: any) {
139
152
  uri,
140
153
  method: "put",
141
154
  request: {
142
- body: data,
143
- headers: {
144
- "content-type": "application/xml",
145
- },
155
+ body: xml(data),
146
156
  },
147
157
  handler: (req: MockRequest) => {
148
158
  req.expect.containsHeader("content-type", "application/xml");
@@ -236,3 +246,32 @@ const Payload_Xml_ModelWithEncodedNames = createServerTests(
236
246
  );
237
247
  Scenarios.Payload_Xml_ModelWithEncodedNamesValue_get = Payload_Xml_ModelWithEncodedNames.get;
238
248
  Scenarios.Payload_Xml_ModelWithEncodedNamesValue_put = Payload_Xml_ModelWithEncodedNames.put;
249
+
250
+ const Payload_Xml_ModelWithEnum = createServerTests("/payload/xml/modelWithEnum", modelWithEnum);
251
+ Scenarios.Payload_Xml_ModelWithEnumValue_get = Payload_Xml_ModelWithEnum.get;
252
+ Scenarios.Payload_Xml_ModelWithEnumValue_put = Payload_Xml_ModelWithEnum.put;
253
+
254
+ const Payload_Xml_ModelWithDatetime = createServerTests(
255
+ "/payload/xml/modelWithDatetime",
256
+ modelWithDatetime,
257
+ );
258
+ Scenarios.Payload_Xml_ModelWithDatetimeValue_get = Payload_Xml_ModelWithDatetime.get;
259
+ Scenarios.Payload_Xml_ModelWithDatetimeValue_put = Payload_Xml_ModelWithDatetime.put;
260
+
261
+ export const xmlError = `
262
+ <XmlErrorBody>
263
+ <message>Something went wrong</message>
264
+ <code>400</code>
265
+ </XmlErrorBody>
266
+ `;
267
+
268
+ Scenarios.Payload_Xml_XmlErrorValue_get = passOnCode(400, {
269
+ uri: "/payload/xml/error",
270
+ method: "get",
271
+ request: {},
272
+ response: {
273
+ status: 400,
274
+ body: xml(xmlError),
275
+ },
276
+ kind: "MockApiDefinition",
277
+ });
@@ -26,7 +26,7 @@ namespace Response.StatusCodeRange;
26
26
  """)
27
27
  @route("/error-response-status-code-in-range")
28
28
  @get
29
- op errorResponseStatusCodeInRange(): 204 | ErrorInRange | DefaultError;
29
+ op errorResponseStatusCodeInRange(): NoContentResponse | ErrorInRange | DefaultError;
30
30
 
31
31
  @scenario
32
32
  @scenarioDoc("""
@@ -44,7 +44,7 @@ op errorResponseStatusCodeInRange(): 204 | ErrorInRange | DefaultError;
44
44
  """)
45
45
  @route("/error-response-status-code-404")
46
46
  @get
47
- op errorResponseStatusCode404(): 204 | NotFoundError | Standard4XXError;
47
+ op errorResponseStatusCode404(): NoContentResponse | NotFoundError | Standard4XXError;
48
48
 
49
49
  @error
50
50
  model NotFoundError {
@@ -1,13 +1,11 @@
1
- import { json, passOnSuccess, ScenarioMockApi } from "@typespec/spec-api";
1
+ import { json, passOnCode, ScenarioMockApi } from "@typespec/spec-api";
2
2
 
3
3
  export const Scenarios: Record<string, ScenarioMockApi> = {};
4
4
 
5
- Scenarios.Response_StatusCodeRange_errorResponseStatusCodeInRange = passOnSuccess({
5
+ Scenarios.Response_StatusCodeRange_errorResponseStatusCodeInRange = passOnCode(494, {
6
6
  uri: "/response/status-code-range/error-response-status-code-in-range",
7
7
  method: "get",
8
- request: {
9
- status: 494,
10
- },
8
+ request: {},
11
9
  response: {
12
10
  status: 494,
13
11
  body: json({
@@ -18,12 +16,10 @@ Scenarios.Response_StatusCodeRange_errorResponseStatusCodeInRange = passOnSucces
18
16
  kind: "MockApiDefinition",
19
17
  });
20
18
 
21
- Scenarios.Response_StatusCodeRange_errorResponseStatusCode404 = passOnSuccess({
19
+ Scenarios.Response_StatusCodeRange_errorResponseStatusCode404 = passOnCode(404, {
22
20
  uri: "/response/status-code-range/error-response-status-code-404",
23
21
  method: "get",
24
- request: {
25
- status: 404,
26
- },
22
+ request: {},
27
23
  response: {
28
24
  status: 404,
29
25
  body: json({
@@ -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,b
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,1,b,2
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.b
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&param=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&param=a,b
433
433
  """)
434
434
  @route("array?fixed=true{&param}")
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&param=a,1,b,2
442
442
  """)
443
443
  @route("record?fixed=true{&param}")
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&param=a&param=b
463
463
  """)
464
464
  @route("array?fixed=true{&param*}")
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{&param*}")
474
- op record(param: Record<int32>): void;
474
+ op `record`(param: Record<int32>): void;
475
475
  }
476
476
  }
477
477
  }
@@ -21,7 +21,7 @@ function createTests(uri: string) {
21
21
  uri: url.pathname,
22
22
  method: "get",
23
23
  request: {
24
- params: Object.fromEntries(queryMap),
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/standard/primitivea",
73
+ "/routes/path/simple/explode/primitivea",
74
74
  );
75
75
  Scenarios.Routes_PathParameters_SimpleExpansion_Explode_array = createTests(
76
- "/routes/path/simple/standard/arraya,b",
76
+ "/routes/path/simple/explode/arraya,b",
77
77
  );
78
78
  Scenarios.Routes_PathParameters_SimpleExpansion_Explode_record = createTests(
79
- "/routes/path/simple/standard/recorda=1,b=2",
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/standard/primitive/a",
91
+ "/routes/path/path/explode/primitive/a",
92
92
  );
93
93
  Scenarios.Routes_PathParameters_PathExpansion_Explode_array = createTests(
94
- "/routes/path/path/standard/array/a/b",
94
+ "/routes/path/path/explode/array/a/b",
95
95
  );
96
96
  Scenarios.Routes_PathParameters_PathExpansion_Explode_record = createTests(
97
- "/routes/path/path/standard/record/a=1/b=2",
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/standard/primitive.a",
109
+ "/routes/path/label/explode/primitive.a",
110
110
  );
111
111
  Scenarios.Routes_PathParameters_LabelExpansion_Explode_array = createTests(
112
- "/routes/path/label/standard/array.a.b",
112
+ "/routes/path/label/explode/array.a.b",
113
113
  );
114
114
  Scenarios.Routes_PathParameters_LabelExpansion_Explode_record = createTests(
115
- "/routes/path/label/standard/record.a=1.b=2",
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/standard/primitive;a",
127
+ "/routes/path/matrix/explode/primitive;param=a",
128
128
  );
129
129
  Scenarios.Routes_PathParameters_MatrixExpansion_Explode_array = createTests(
130
- "/routes/path/matrix/standard/array;a;b",
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/standard/record;a=1;b=2",
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");
@@ -4,7 +4,7 @@ import "@typespec/spector";
4
4
  using Http;
5
5
  using Spector;
6
6
 
7
- @doc("Projection")
7
+ @doc("Encoded names")
8
8
  @scenarioService("/serialization/encoded-name/json")
9
9
  namespace Serialization.EncodedName.Json;
10
10
 
@@ -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 TypeSpec.Versioning;
8
- using TypeSpec.Rest;
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.",
@@ -40,7 +40,7 @@ Scenarios.Server_Versions_NotVersioned_withQueryApiVersion = passOnSuccess({
40
40
  uri: "/server/versions/not-versioned/with-query-api-version",
41
41
  method: "head",
42
42
  request: {
43
- params: {
43
+ query: {
44
44
  "api-version": "v1.0",
45
45
  },
46
46
  },
@@ -4,7 +4,7 @@ import "@typespec/versioning";
4
4
 
5
5
  using Http;
6
6
  using Spector;
7
- using TypeSpec.Versioning;
7
+ using Versioning;
8
8
 
9
9
  /**
10
10
  * Illustrates versioned server.
@@ -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, requestData: any, serverData: string) {
34
+ function createAPIVersionTests(uri: string, version: string) {
35
35
  return passOnSuccess({
36
36
  uri,
37
37
  method: "head",
38
- request: requestData,
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 TypeSpec.Versioning;
7
+ using Versioning;
8
8
 
9
9
  @doc("Illustrates conditional request headers")
10
10
  @scenarioService("/special-headers/conditional-request")