@redocly/openapi-core 1.0.0-beta.99 → 1.0.0-rc.2

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 (382) hide show
  1. package/README.md +6 -6
  2. package/lib/benchmark/benches/lint-with-top-level-rule-report.bench.js +0 -1
  3. package/lib/benchmark/benches/recommended-oas3.bench.js +1 -1
  4. package/lib/benchmark/benches/resolve-with-no-external.bench.js +1 -1
  5. package/lib/benchmark/utils.d.ts +2 -2
  6. package/lib/benchmark/utils.js +2 -2
  7. package/lib/bundle.d.ts +10 -15
  8. package/lib/bundle.js +32 -12
  9. package/lib/config/all.d.ts +2 -2
  10. package/lib/config/all.js +16 -6
  11. package/lib/config/builtIn.d.ts +2 -2
  12. package/lib/config/builtIn.js +2 -2
  13. package/lib/config/config-resolvers.d.ts +5 -5
  14. package/lib/config/config-resolvers.js +121 -66
  15. package/lib/config/config.d.ts +12 -18
  16. package/lib/config/config.js +42 -26
  17. package/lib/config/load.d.ts +16 -3
  18. package/lib/config/load.js +36 -14
  19. package/lib/config/minimal.d.ts +2 -2
  20. package/lib/config/minimal.js +10 -6
  21. package/lib/config/recommended.d.ts +2 -2
  22. package/lib/config/recommended.js +10 -6
  23. package/lib/config/rules.d.ts +7 -4
  24. package/lib/config/rules.js +5 -4
  25. package/lib/config/types.d.ts +72 -23
  26. package/lib/config/types.js +13 -0
  27. package/lib/config/utils.d.ts +6 -5
  28. package/lib/config/utils.js +110 -32
  29. package/lib/decorators/common/filters/filter-helper.d.ts +3 -0
  30. package/lib/decorators/common/filters/filter-helper.js +67 -0
  31. package/lib/decorators/common/filters/filter-in.d.ts +2 -0
  32. package/lib/decorators/common/filters/filter-in.js +17 -0
  33. package/lib/decorators/common/filters/filter-out.d.ts +2 -0
  34. package/lib/decorators/common/filters/filter-out.js +17 -0
  35. package/lib/decorators/common/info-override.d.ts +2 -0
  36. package/lib/decorators/common/info-override.js +28 -0
  37. package/lib/decorators/common/media-type-examples-override.d.ts +2 -0
  38. package/lib/decorators/common/media-type-examples-override.js +53 -0
  39. package/lib/decorators/common/registry-dependencies.js +2 -2
  40. package/lib/decorators/common/remove-x-internal.js +2 -2
  41. package/lib/decorators/oas2/index.d.ts +3 -0
  42. package/lib/decorators/oas2/index.js +7 -1
  43. package/lib/decorators/oas3/index.d.ts +4 -0
  44. package/lib/decorators/oas3/index.js +9 -1
  45. package/lib/env.d.ts +3 -0
  46. package/lib/env.js +8 -0
  47. package/lib/format/codeframes.js +16 -10
  48. package/lib/format/format.d.ts +1 -1
  49. package/lib/format/format.js +64 -32
  50. package/lib/index.d.ts +6 -6
  51. package/lib/index.js +7 -2
  52. package/lib/js-yaml/index.js +2 -6
  53. package/lib/lint.d.ts +4 -2
  54. package/lib/lint.js +36 -11
  55. package/lib/logger.d.ts +10 -0
  56. package/lib/logger.js +31 -0
  57. package/lib/output.d.ts +3 -0
  58. package/lib/output.js +9 -0
  59. package/lib/redocly/index.js +10 -9
  60. package/lib/redocly/registry-api-types.d.ts +28 -28
  61. package/lib/redocly/registry-api.d.ts +3 -3
  62. package/lib/redocly/registry-api.js +10 -2
  63. package/lib/ref-utils.d.ts +1 -0
  64. package/lib/ref-utils.js +7 -2
  65. package/lib/resolve.d.ts +1 -1
  66. package/lib/resolve.js +33 -3
  67. package/lib/rules/ajv.d.ts +2 -2
  68. package/lib/rules/ajv.js +12 -12
  69. package/lib/rules/common/assertions/asserts.d.ts +29 -4
  70. package/lib/rules/common/assertions/asserts.js +227 -97
  71. package/lib/rules/common/assertions/index.d.ts +27 -2
  72. package/lib/rules/common/assertions/index.js +9 -37
  73. package/lib/rules/common/assertions/utils.d.ts +16 -8
  74. package/lib/rules/common/assertions/utils.js +160 -76
  75. package/lib/rules/common/info-license-url.d.ts +1 -1
  76. package/lib/rules/common/info-license-url.js +5 -10
  77. package/lib/rules/common/info-license.d.ts +2 -0
  78. package/lib/rules/common/info-license.js +17 -0
  79. package/lib/rules/common/no-ambiguous-paths.js +1 -1
  80. package/lib/rules/common/no-enum-type-mismatch.js +1 -3
  81. package/lib/rules/common/no-identical-paths.js +4 -4
  82. package/lib/rules/common/no-invalid-parameter-examples.js +3 -3
  83. package/lib/rules/common/no-invalid-schema-examples.js +3 -3
  84. package/lib/rules/common/operation-2xx-response.js +15 -9
  85. package/lib/rules/common/operation-4xx-response.js +15 -9
  86. package/lib/rules/common/operation-operationId.js +2 -2
  87. package/lib/rules/common/operation-tag-defined.js +1 -1
  88. package/lib/rules/common/path-not-include-query.js +2 -2
  89. package/lib/rules/common/path-params-defined.js +7 -2
  90. package/lib/rules/common/paths-kebab-case.js +4 -1
  91. package/lib/rules/common/required-string-property-missing-min-length.d.ts +2 -0
  92. package/lib/rules/common/required-string-property-missing-min-length.js +37 -0
  93. package/lib/rules/common/response-contains-header.js +2 -2
  94. package/lib/rules/common/scalar-property-missing-example.js +2 -1
  95. package/lib/rules/common/security-defined.d.ts +2 -0
  96. package/lib/rules/common/{operation-security-defined.js → security-defined.js} +25 -6
  97. package/lib/rules/common/spec-strict-refs.d.ts +2 -0
  98. package/lib/rules/common/spec-strict-refs.js +30 -0
  99. package/lib/rules/common/spec.js +41 -18
  100. package/lib/rules/common/tags-alphabetical.js +1 -1
  101. package/lib/rules/oas2/index.d.ts +3 -2
  102. package/lib/rules/oas2/index.js +10 -8
  103. package/lib/rules/oas2/remove-unused-components.js +6 -6
  104. package/lib/rules/oas2/request-mime-type.d.ts +1 -1
  105. package/lib/rules/oas2/request-mime-type.js +1 -1
  106. package/lib/rules/oas2/response-mime-type.d.ts +1 -1
  107. package/lib/rules/oas2/response-mime-type.js +1 -1
  108. package/lib/rules/oas3/component-name-unique.d.ts +2 -0
  109. package/lib/rules/oas3/component-name-unique.js +124 -0
  110. package/lib/rules/oas3/index.js +18 -10
  111. package/lib/rules/oas3/no-empty-servers.js +2 -2
  112. package/lib/rules/oas3/no-invalid-media-type-examples.js +2 -2
  113. package/lib/rules/oas3/no-server-variables-empty-enum.d.ts +2 -0
  114. package/lib/rules/oas3/{no-servers-empty-enum.js → no-server-variables-empty-enum.js} +5 -5
  115. package/lib/rules/oas3/no-unused-components.js +2 -2
  116. package/lib/rules/oas3/operation-4xx-problem-details-rfc7807.d.ts +5 -0
  117. package/lib/rules/oas3/operation-4xx-problem-details-rfc7807.js +36 -0
  118. package/lib/rules/oas3/remove-unused-components.js +6 -6
  119. package/lib/rules/oas3/request-mime-type.d.ts +1 -1
  120. package/lib/rules/oas3/request-mime-type.js +1 -1
  121. package/lib/rules/oas3/response-mime-type.d.ts +1 -1
  122. package/lib/rules/oas3/response-mime-type.js +1 -1
  123. package/lib/rules/oas3/spec-components-invalid-map-name.d.ts +2 -0
  124. package/lib/rules/oas3/spec-components-invalid-map-name.js +62 -0
  125. package/lib/rules/other/stats.d.ts +2 -2
  126. package/lib/rules/other/stats.js +45 -16
  127. package/lib/rules/utils.d.ts +5 -2
  128. package/lib/rules/utils.js +54 -6
  129. package/lib/types/config-external-schemas.d.ts +2193 -0
  130. package/lib/types/config-external-schemas.js +805 -0
  131. package/lib/types/index.d.ts +3 -2
  132. package/lib/types/index.js +9 -1
  133. package/lib/types/oas2.js +91 -15
  134. package/lib/types/oas3.js +125 -46
  135. package/lib/types/oas3_1.js +23 -19
  136. package/lib/types/redocly-yaml.js +406 -60
  137. package/lib/utils.d.ts +15 -4
  138. package/lib/utils.js +72 -8
  139. package/lib/visitors.d.ts +20 -16
  140. package/lib/visitors.js +28 -3
  141. package/lib/walk.d.ts +11 -19
  142. package/lib/walk.js +74 -53
  143. package/package.json +5 -6
  144. package/__tests__/utils.ts +0 -86
  145. package/lib/rules/common/info-description.d.ts +0 -2
  146. package/lib/rules/common/info-description.js +0 -12
  147. package/lib/rules/common/license-url.d.ts +0 -2
  148. package/lib/rules/common/license-url.js +0 -12
  149. package/lib/rules/common/operation-security-defined.d.ts +0 -2
  150. package/lib/rules/oas3/no-servers-empty-enum.d.ts +0 -2
  151. package/src/__tests__/__snapshots__/bundle.test.ts.snap +0 -255
  152. package/src/__tests__/bundle.test.ts +0 -156
  153. package/src/__tests__/codeframes.test.ts +0 -531
  154. package/src/__tests__/fixtures/extension.js +0 -24
  155. package/src/__tests__/fixtures/refs/definitions.yaml +0 -3
  156. package/src/__tests__/fixtures/refs/examples.yaml +0 -8
  157. package/src/__tests__/fixtures/refs/external-request-body.yaml +0 -13
  158. package/src/__tests__/fixtures/refs/externalref.yaml +0 -35
  159. package/src/__tests__/fixtures/refs/hosted.yaml +0 -35
  160. package/src/__tests__/fixtures/refs/openapi-with-external-refs-conflicting-names.yaml +0 -21
  161. package/src/__tests__/fixtures/refs/openapi-with-external-refs.yaml +0 -33
  162. package/src/__tests__/fixtures/refs/openapi-with-url-refs.yaml +0 -18
  163. package/src/__tests__/fixtures/refs/param-b.yaml +0 -1
  164. package/src/__tests__/fixtures/refs/param-c.yaml +0 -1
  165. package/src/__tests__/fixtures/refs/rename.yaml +0 -1
  166. package/src/__tests__/fixtures/refs/requestBody.yaml +0 -9
  167. package/src/__tests__/fixtures/refs/schema-a.yaml +0 -1
  168. package/src/__tests__/fixtures/refs/simple.yaml +0 -1
  169. package/src/__tests__/fixtures/refs/vendor.schema.yaml +0 -20
  170. package/src/__tests__/fixtures/resolve/External.yaml +0 -10
  171. package/src/__tests__/fixtures/resolve/External2.yaml +0 -4
  172. package/src/__tests__/fixtures/resolve/description.md +0 -3
  173. package/src/__tests__/fixtures/resolve/externalInfo.yaml +0 -4
  174. package/src/__tests__/fixtures/resolve/externalLicense.yaml +0 -1
  175. package/src/__tests__/fixtures/resolve/openapi-with-back.yaml +0 -13
  176. package/src/__tests__/fixtures/resolve/openapi-with-md-description.yaml +0 -5
  177. package/src/__tests__/fixtures/resolve/openapi.yaml +0 -28
  178. package/src/__tests__/fixtures/resolve/schemas/type-a.yaml +0 -10
  179. package/src/__tests__/fixtures/resolve/schemas/type-b.yaml +0 -6
  180. package/src/__tests__/fixtures/resolve/transitive/a.yaml +0 -1
  181. package/src/__tests__/fixtures/resolve/transitive/components.yaml +0 -5
  182. package/src/__tests__/fixtures/resolve/transitive/schemas.yaml +0 -3
  183. package/src/__tests__/js-yaml.test.ts +0 -71
  184. package/src/__tests__/lint.test.ts +0 -195
  185. package/src/__tests__/login.test.ts +0 -17
  186. package/src/__tests__/normalizeVisitors.test.ts +0 -151
  187. package/src/__tests__/ref-utils.test.ts +0 -120
  188. package/src/__tests__/resolve-http.test.ts +0 -77
  189. package/src/__tests__/resolve.test.ts +0 -405
  190. package/src/__tests__/utils.test.ts +0 -85
  191. package/src/__tests__/walk.test.ts +0 -1485
  192. package/src/benchmark/benches/lint-with-many-rules.bench.ts +0 -35
  193. package/src/benchmark/benches/lint-with-nested-rule.bench.ts +0 -39
  194. package/src/benchmark/benches/lint-with-no-rules.bench.ts +0 -20
  195. package/src/benchmark/benches/lint-with-top-level-rule-report.bench.ts +0 -36
  196. package/src/benchmark/benches/lint-with-top-level-rule.bench.ts +0 -32
  197. package/src/benchmark/benches/rebilly.yaml +0 -32267
  198. package/src/benchmark/benches/recommended-oas3.bench.ts +0 -22
  199. package/src/benchmark/benches/resolve-with-no-external.bench.ts +0 -23
  200. package/src/benchmark/benchmark.js +0 -307
  201. package/src/benchmark/colors.js +0 -29
  202. package/src/benchmark/fork.js +0 -83
  203. package/src/benchmark/utils.ts +0 -36
  204. package/src/bundle.ts +0 -386
  205. package/src/config/__tests__/__snapshots__/config-resolvers.test.ts.snap +0 -157
  206. package/src/config/__tests__/config-resolvers.test.ts +0 -429
  207. package/src/config/__tests__/config.test.ts +0 -244
  208. package/src/config/__tests__/fixtures/plugin-config.yaml +0 -3
  209. package/src/config/__tests__/fixtures/plugin.js +0 -56
  210. package/src/config/__tests__/fixtures/resolve-config/api/nested-config.yaml +0 -12
  211. package/src/config/__tests__/fixtures/resolve-config/api/plugin.js +0 -67
  212. package/src/config/__tests__/fixtures/resolve-config/local-config-with-circular.yaml +0 -8
  213. package/src/config/__tests__/fixtures/resolve-config/local-config-with-file.yaml +0 -19
  214. package/src/config/__tests__/fixtures/resolve-config/local-config.yaml +0 -10
  215. package/src/config/__tests__/fixtures/resolve-config/plugin.js +0 -66
  216. package/src/config/__tests__/fixtures/resolve-remote-configs/nested-remote-config.yaml +0 -4
  217. package/src/config/__tests__/fixtures/resolve-remote-configs/remote-config.yaml +0 -5
  218. package/src/config/__tests__/load.test.ts +0 -83
  219. package/src/config/__tests__/resolve-plugins.test.ts +0 -27
  220. package/src/config/all.ts +0 -66
  221. package/src/config/builtIn.ts +0 -37
  222. package/src/config/config-resolvers.ts +0 -359
  223. package/src/config/config.ts +0 -312
  224. package/src/config/index.ts +0 -7
  225. package/src/config/load.ts +0 -84
  226. package/src/config/minimal.ts +0 -58
  227. package/src/config/recommended.ts +0 -58
  228. package/src/config/rules.ts +0 -46
  229. package/src/config/types.ts +0 -168
  230. package/src/config/utils.ts +0 -208
  231. package/src/decorators/__tests__/remove-x-internal.test.ts +0 -316
  232. package/src/decorators/common/info-description-override.ts +0 -24
  233. package/src/decorators/common/operation-description-override.ts +0 -30
  234. package/src/decorators/common/registry-dependencies.ts +0 -25
  235. package/src/decorators/common/remove-x-internal.ts +0 -59
  236. package/src/decorators/common/tag-description-override.ts +0 -25
  237. package/src/decorators/oas2/index.ts +0 -14
  238. package/src/decorators/oas3/index.ts +0 -14
  239. package/src/format/codeframes.ts +0 -210
  240. package/src/format/format.ts +0 -339
  241. package/src/index.ts +0 -68
  242. package/src/js-yaml/index.ts +0 -18
  243. package/src/lint.ts +0 -125
  244. package/src/oas-types.ts +0 -62
  245. package/src/redocly/__tests__/redocly-client.test.ts +0 -140
  246. package/src/redocly/index.ts +0 -182
  247. package/src/redocly/redocly-client-types.ts +0 -10
  248. package/src/redocly/registry-api-types.ts +0 -32
  249. package/src/redocly/registry-api.ts +0 -134
  250. package/src/ref-utils.ts +0 -80
  251. package/src/resolve.ts +0 -378
  252. package/src/rules/__tests__/fixtures/invalid-yaml.yaml +0 -1
  253. package/src/rules/__tests__/fixtures/ref.yaml +0 -1
  254. package/src/rules/__tests__/no-unresolved-refs.test.ts +0 -168
  255. package/src/rules/ajv.ts +0 -103
  256. package/src/rules/common/__tests__/info-description.test.ts +0 -102
  257. package/src/rules/common/__tests__/info-license.test.ts +0 -62
  258. package/src/rules/common/__tests__/license-url.test.ts +0 -63
  259. package/src/rules/common/__tests__/no-ambiguous-paths.test.ts +0 -96
  260. package/src/rules/common/__tests__/no-enum-type-mismatch.test.ts +0 -209
  261. package/src/rules/common/__tests__/no-identical-paths.test.ts +0 -58
  262. package/src/rules/common/__tests__/no-path-trailing-slash.test.ts +0 -85
  263. package/src/rules/common/__tests__/operation-2xx-response.test.ts +0 -91
  264. package/src/rules/common/__tests__/operation-4xx-response.test.ts +0 -107
  265. package/src/rules/common/__tests__/operation-operationId-unique.test.ts +0 -76
  266. package/src/rules/common/__tests__/operation-operationId-url-safe.test.ts +0 -45
  267. package/src/rules/common/__tests__/operation-parameters-unique.test.ts +0 -167
  268. package/src/rules/common/__tests__/operation-security-defined.test.ts +0 -69
  269. package/src/rules/common/__tests__/operation-singular-tag.test.ts +0 -72
  270. package/src/rules/common/__tests__/path-http-verbs-order.test.ts +0 -95
  271. package/src/rules/common/__tests__/path-not-include-query.test.ts +0 -64
  272. package/src/rules/common/__tests__/path-params-defined.test.ts +0 -133
  273. package/src/rules/common/__tests__/paths-kebab-case.test.ts +0 -108
  274. package/src/rules/common/__tests__/scalar-property-missing-example.test.ts +0 -207
  275. package/src/rules/common/__tests__/spec.test.ts +0 -62
  276. package/src/rules/common/__tests__/tag-description.test.ts +0 -65
  277. package/src/rules/common/__tests__/tags-alphabetical.test.ts +0 -64
  278. package/src/rules/common/assertions/__tests__/asserts.test.ts +0 -231
  279. package/src/rules/common/assertions/__tests__/index.test.ts +0 -65
  280. package/src/rules/common/assertions/__tests__/utils.test.ts +0 -89
  281. package/src/rules/common/assertions/asserts.ts +0 -137
  282. package/src/rules/common/assertions/index.ts +0 -75
  283. package/src/rules/common/assertions/utils.ts +0 -167
  284. package/src/rules/common/info-contact.ts +0 -15
  285. package/src/rules/common/info-description.ts +0 -10
  286. package/src/rules/common/info-license-url.ts +0 -15
  287. package/src/rules/common/license-url.ts +0 -10
  288. package/src/rules/common/no-ambiguous-paths.ts +0 -50
  289. package/src/rules/common/no-enum-type-mismatch.ts +0 -49
  290. package/src/rules/common/no-http-verbs-in-paths.ts +0 -36
  291. package/src/rules/common/no-identical-paths.ts +0 -24
  292. package/src/rules/common/no-invalid-parameter-examples.ts +0 -36
  293. package/src/rules/common/no-invalid-schema-examples.ts +0 -27
  294. package/src/rules/common/no-path-trailing-slash.ts +0 -15
  295. package/src/rules/common/operation-2xx-response.ts +0 -16
  296. package/src/rules/common/operation-4xx-response.ts +0 -17
  297. package/src/rules/common/operation-description.ts +0 -13
  298. package/src/rules/common/operation-operationId-unique.ts +0 -21
  299. package/src/rules/common/operation-operationId-url-safe.ts +0 -19
  300. package/src/rules/common/operation-operationId.ts +0 -17
  301. package/src/rules/common/operation-parameters-unique.ts +0 -48
  302. package/src/rules/common/operation-security-defined.ts +0 -45
  303. package/src/rules/common/operation-singular-tag.ts +0 -17
  304. package/src/rules/common/operation-summary.ts +0 -13
  305. package/src/rules/common/operation-tag-defined.ts +0 -26
  306. package/src/rules/common/parameter-description.ts +0 -22
  307. package/src/rules/common/path-declaration-must-exist.ts +0 -15
  308. package/src/rules/common/path-excludes-patterns.ts +0 -23
  309. package/src/rules/common/path-http-verbs-order.ts +0 -30
  310. package/src/rules/common/path-not-include-query.ts +0 -17
  311. package/src/rules/common/path-params-defined.ts +0 -58
  312. package/src/rules/common/path-segment-plural.ts +0 -31
  313. package/src/rules/common/paths-kebab-case.ts +0 -16
  314. package/src/rules/common/response-contains-header.ts +0 -30
  315. package/src/rules/common/scalar-property-missing-example.ts +0 -55
  316. package/src/rules/common/spec.ts +0 -143
  317. package/src/rules/common/tag-description.ts +0 -10
  318. package/src/rules/common/tags-alphabetical.ts +0 -20
  319. package/src/rules/no-unresolved-refs.ts +0 -51
  320. package/src/rules/oas2/__tests__/boolean-parameter-prefixes.test.ts +0 -110
  321. package/src/rules/oas2/__tests__/response-contains-header.test.ts +0 -174
  322. package/src/rules/oas2/__tests__/response-contains-property.test.ts +0 -155
  323. package/src/rules/oas2/__tests__/spec/fixtures/description.md +0 -1
  324. package/src/rules/oas2/__tests__/spec/info.test.ts +0 -355
  325. package/src/rules/oas2/__tests__/spec/operation.test.ts +0 -123
  326. package/src/rules/oas2/__tests__/spec/paths.test.ts +0 -245
  327. package/src/rules/oas2/__tests__/spec/referenceableScalars.test.ts +0 -31
  328. package/src/rules/oas2/__tests__/spec/utils.ts +0 -32
  329. package/src/rules/oas2/boolean-parameter-prefixes.ts +0 -26
  330. package/src/rules/oas2/index.ts +0 -89
  331. package/src/rules/oas2/remove-unused-components.ts +0 -76
  332. package/src/rules/oas2/request-mime-type.ts +0 -17
  333. package/src/rules/oas2/response-contains-property.ts +0 -36
  334. package/src/rules/oas2/response-mime-type.ts +0 -17
  335. package/src/rules/oas3/__tests__/boolean-parameter-prefixes.test.ts +0 -111
  336. package/src/rules/oas3/__tests__/fixtures/common.yaml +0 -11
  337. package/src/rules/oas3/__tests__/no-empty-enum-servers.com.test.ts +0 -205
  338. package/src/rules/oas3/__tests__/no-example-value-and-externalValue.test.ts +0 -65
  339. package/src/rules/oas3/__tests__/no-invalid-media-type-examples.test.ts +0 -392
  340. package/src/rules/oas3/__tests__/no-server-example.com.test.ts +0 -60
  341. package/src/rules/oas3/__tests__/no-server-trailing-slash.test.ts +0 -79
  342. package/src/rules/oas3/__tests__/no-unused-components.test.ts +0 -131
  343. package/src/rules/oas3/__tests__/response-contains-header.test.ts +0 -273
  344. package/src/rules/oas3/__tests__/response-contains-property.test.ts +0 -403
  345. package/src/rules/oas3/__tests__/spec/callbacks.test.ts +0 -41
  346. package/src/rules/oas3/__tests__/spec/fixtures/description.md +0 -1
  347. package/src/rules/oas3/__tests__/spec/info.test.ts +0 -391
  348. package/src/rules/oas3/__tests__/spec/operation.test.ts +0 -253
  349. package/src/rules/oas3/__tests__/spec/paths.test.ts +0 -284
  350. package/src/rules/oas3/__tests__/spec/referenceableScalars.test.ts +0 -77
  351. package/src/rules/oas3/__tests__/spec/servers.test.ts +0 -499
  352. package/src/rules/oas3/__tests__/spec/spec.test.ts +0 -288
  353. package/src/rules/oas3/__tests__/spec/utils.ts +0 -32
  354. package/src/rules/oas3/boolean-parameter-prefixes.ts +0 -28
  355. package/src/rules/oas3/index.ts +0 -105
  356. package/src/rules/oas3/no-empty-servers.ts +0 -22
  357. package/src/rules/oas3/no-example-value-and-externalValue.ts +0 -14
  358. package/src/rules/oas3/no-invalid-media-type-examples.ts +0 -41
  359. package/src/rules/oas3/no-server-example.com.ts +0 -14
  360. package/src/rules/oas3/no-server-trailing-slash.ts +0 -15
  361. package/src/rules/oas3/no-servers-empty-enum.ts +0 -67
  362. package/src/rules/oas3/no-undefined-server-variable.ts +0 -30
  363. package/src/rules/oas3/no-unused-components.ts +0 -75
  364. package/src/rules/oas3/remove-unused-components.ts +0 -84
  365. package/src/rules/oas3/request-mime-type.ts +0 -31
  366. package/src/rules/oas3/response-contains-property.ts +0 -38
  367. package/src/rules/oas3/response-mime-type.ts +0 -31
  368. package/src/rules/other/stats.ts +0 -44
  369. package/src/rules/utils.ts +0 -123
  370. package/src/types/index.ts +0 -138
  371. package/src/types/oas2.ts +0 -397
  372. package/src/types/oas3.ts +0 -515
  373. package/src/types/oas3_1.ts +0 -253
  374. package/src/types/redocly-yaml.ts +0 -647
  375. package/src/typings/common.ts +0 -9
  376. package/src/typings/openapi.ts +0 -298
  377. package/src/typings/swagger.ts +0 -236
  378. package/src/utils.ts +0 -193
  379. package/src/visitors.ts +0 -448
  380. package/src/walk.ts +0 -416
  381. package/tsconfig.json +0 -8
  382. package/tsconfig.tsbuildinfo +0 -1
@@ -1,120 +0,0 @@
1
- import outdent from 'outdent';
2
- import { parseYamlToDocument } from '../../__tests__/utils';
3
- import { parseRef, refBaseName } from '../ref-utils';
4
- import { lintDocument } from '../lint';
5
- import { LintConfig } from '../config';
6
- import { BaseResolver } from '../resolve';
7
-
8
- describe('ref-utils', () => {
9
- it(`should unescape refs with '/'`, () => {
10
- const reference = 'somefile.yaml#/components/schemas/scope~1domain-schema';
11
- expect(parseRef(reference)).toMatchInlineSnapshot(`
12
- Object {
13
- "pointer": Array [
14
- "components",
15
- "schemas",
16
- "scope/domain-schema",
17
- ],
18
- "uri": "somefile.yaml",
19
- }
20
- `);
21
- });
22
-
23
- it(`should unescape refs with '~'`, () => {
24
- const reference = 'somefile.yaml#/components/schemas/complex~0name';
25
- expect(parseRef(reference)).toMatchInlineSnapshot(`
26
- Object {
27
- "pointer": Array [
28
- "components",
29
- "schemas",
30
- "complex~name",
31
- ],
32
- "uri": "somefile.yaml",
33
- }
34
- `);
35
- });
36
-
37
- it(`should unescape complex urlencoded paths`, () => {
38
- const referene = 'somefile.yaml#/components/schemas/scope%2Fcomplex~name';
39
- expect(parseRef(referene)).toMatchInlineSnapshot(`
40
- Object {
41
- "pointer": Array [
42
- "components",
43
- "schemas",
44
- "scope/complex~name",
45
- ],
46
- "uri": "somefile.yaml",
47
- }
48
- `);
49
- });
50
-
51
- it(`should validate definition with urlencoded paths`, async () => {
52
- const document = parseYamlToDocument(
53
- outdent`
54
- openapi: "3.0.0"
55
- info:
56
- version: 1.0.0
57
- title: Swagger Petstore
58
- description: Test definition
59
- license:
60
- name: MIT
61
- url: https://opensource.org/licenses/MIT
62
- servers:
63
- - url: http://petstore.swagger.io/v1
64
- paths:
65
- /pet:
66
- get:
67
- summary: List all pets
68
- operationId: listPets
69
- responses:
70
- '200':
71
- description: A paged array of pets
72
- content:
73
- application/json:
74
- schema:
75
- $ref: "#/components/schemas/scope%3A%7Banimals~1Pet%7D"
76
- components:
77
- schemas:
78
- scope:{animals/Pet}:
79
- type: object
80
- properties:
81
- id:
82
- type: integer
83
- format: int64
84
- name:
85
- type: string
86
- `,
87
- '',
88
- );
89
-
90
- const result = await lintDocument({
91
- document,
92
- externalRefResolver: new BaseResolver(),
93
- config: new LintConfig({}),
94
- });
95
-
96
- expect(result).toMatchInlineSnapshot(`Array []`);
97
- });
98
-
99
- describe('refBaseName', () => {
100
- it("returns base name for file reference", () => {
101
- expect(refBaseName("../testcase/Pet.yaml")).toStrictEqual("Pet");
102
- });
103
-
104
- it("returns base name for local file reference", () => {
105
- expect(refBaseName("Cat.json")).toStrictEqual("Cat");
106
- });
107
-
108
- it("returns base name for url reference", () => {
109
- expect(refBaseName("http://example.com/tests/crocodile.json")).toStrictEqual("crocodile");
110
- });
111
-
112
- it("returns base name for file with multiple dots in name", () => {
113
- expect(refBaseName("feline.tiger.v1.yaml")).toStrictEqual("feline.tiger.v1");
114
- });
115
-
116
- it("returns base name for file without any dots in name", () => {
117
- expect(refBaseName("abcdefg")).toStrictEqual("abcdefg");
118
- });
119
- });
120
- });
@@ -1,77 +0,0 @@
1
- import { outdent } from 'outdent';
2
-
3
- import { resolveDocument, BaseResolver } from '../resolve';
4
- import { parseYamlToDocument } from '../../__tests__/utils';
5
- import { Oas3Types } from '../types/oas3';
6
- import { normalizeTypes } from '../types';
7
-
8
- describe('Resolve http-headers', () => {
9
- it('should use matching http-headers', async () => {
10
- const rootDocument = parseYamlToDocument(
11
- outdent`
12
- openapi: 3.0.0
13
- components:
14
- schemas:
15
- A:
16
- $ref: 'https://example.com/test.yaml'
17
- B:
18
- $ref: 'https://sample.com/test.yaml'
19
- C:
20
- $ref: 'https://sample.com/test/a/test.yaml'
21
- `,
22
- 'foobar.yaml',
23
- );
24
-
25
- const fetchMock = jest.fn(() => Promise.resolve({ ok: true, text: Promise.resolve('') }));
26
-
27
- await resolveDocument({
28
- rootDocument,
29
- externalRefResolver: new BaseResolver({
30
- http: {
31
- customFetch: fetchMock,
32
- headers: [
33
- {
34
- name: 'X_TEST',
35
- matches: 'example.com/*',
36
- value: '123',
37
- },
38
- {
39
- name: 'X_TEST',
40
- matches: 'https://sample.com/test/**',
41
- value: '321',
42
- },
43
- ],
44
- },
45
- }),
46
- rootType: normalizeTypes(Oas3Types).DefinitionRoot,
47
- });
48
-
49
- expect(fetchMock).toBeCalledTimes(3);
50
- expect(fetchMock.mock.calls).toMatchInlineSnapshot(`
51
- Array [
52
- Array [
53
- "https://example.com/test.yaml",
54
- Object {
55
- "headers": Object {
56
- "X_TEST": "123",
57
- },
58
- },
59
- ],
60
- Array [
61
- "https://sample.com/test.yaml",
62
- Object {
63
- "headers": Object {},
64
- },
65
- ],
66
- Array [
67
- "https://sample.com/test/a/test.yaml",
68
- Object {
69
- "headers": Object {
70
- "X_TEST": "321",
71
- },
72
- },
73
- ],
74
- ]
75
- `);
76
- });
77
- });
@@ -1,405 +0,0 @@
1
- import { outdent } from 'outdent';
2
- import * as path from 'path';
3
-
4
- import { resolveDocument, BaseResolver, Document } from '../resolve';
5
- import { parseYamlToDocument } from '../../__tests__/utils';
6
- import { Oas3Types } from '../types/oas3';
7
- import { normalizeTypes } from '../types';
8
-
9
- describe('collect refs', () => {
10
- it('should resolve local refs', async () => {
11
- const rootDocument = parseYamlToDocument(
12
- outdent`
13
- openapi: 3.0.0
14
- info:
15
- $ref: "#/defs/info"
16
- defs:
17
- info:
18
- contact: {}
19
- license: {}
20
- `,
21
- 'foobar.yaml',
22
- );
23
-
24
- const resolvedRefs = await resolveDocument({
25
- rootDocument,
26
- externalRefResolver: new BaseResolver(),
27
- rootType: normalizeTypes(Oas3Types).DefinitionRoot,
28
- });
29
-
30
- expect(resolvedRefs).toBeDefined();
31
- expect(resolvedRefs.size).toEqual(1);
32
- expect(Array.from(resolvedRefs.keys())).toMatchInlineSnapshot(
33
- [`foobar.yaml::#/defs/info`],
34
- `
35
- Array [
36
- "foobar.yaml::#/defs/info",
37
- ]
38
- `,
39
- );
40
- expect(Array.from(resolvedRefs.values()).map((info) => info.node)).toEqual([
41
- { contact: {}, license: {} },
42
- ]);
43
- });
44
-
45
- // Or using async/await.
46
- it('should throw on self-circular refs', async () => {
47
- expect.assertions(1);
48
-
49
- const rootDocument = parseYamlToDocument(
50
- outdent`
51
- openapi: 3.0.0
52
- info:
53
- $ref: "#/info"
54
- defs:
55
- info:
56
- contact: {}
57
- license: {}
58
- `,
59
- '',
60
- );
61
-
62
- try {
63
- await resolveDocument({
64
- rootDocument,
65
- externalRefResolver: new BaseResolver(),
66
- rootType: normalizeTypes(Oas3Types).DefinitionRoot,
67
- });
68
- } catch (e) {
69
- expect(e.message).toEqual('Self-referencing circular pointer');
70
- }
71
- });
72
-
73
- it('should resolve local transitive refs', async () => {
74
- const rootDocument = parseYamlToDocument(
75
- outdent`
76
- openapi: 3.0.0
77
- info:
78
- $ref: "#/tmp/info"
79
- tmp:
80
- $ref: '#/defs'
81
- prop:
82
- $ref: '#/propTrans'
83
- propTrans:
84
- $ref: '#/propDest'
85
- propDest:
86
- type: string
87
- defs:
88
- info:
89
- contact: {}
90
- license: {}
91
- `,
92
- 'foobar.yaml',
93
- );
94
-
95
- const resolvedRefs = await resolveDocument({
96
- rootDocument,
97
- externalRefResolver: new BaseResolver(),
98
- rootType: normalizeTypes(Oas3Types).DefinitionRoot,
99
- });
100
-
101
- expect(resolvedRefs).toBeDefined();
102
- expect(resolvedRefs.size).toEqual(4);
103
- expect(Array.from(resolvedRefs.keys())).toEqual([
104
- 'foobar.yaml::#/defs',
105
- 'foobar.yaml::#/propDest',
106
- 'foobar.yaml::#/tmp/info',
107
- 'foobar.yaml::#/propTrans',
108
- ]);
109
- expect(Array.from(resolvedRefs.values()).map((info) => info.node)).toEqual([
110
- { info: { contact: {}, license: {} } },
111
- { type: 'string' },
112
- { contact: {}, license: {} },
113
- { type: 'string' },
114
- ]);
115
- });
116
-
117
- it('should throw on ref loop', async () => {
118
- const rootDocument = parseYamlToDocument(
119
- outdent`
120
- openapi: 3.0.0
121
- info:
122
- $ref: "#/loop"
123
- loop:
124
- $ref: '#/loop2'
125
- loop2:
126
- $ref: '#/info'
127
- `,
128
- 'foobar.yaml',
129
- );
130
-
131
- try {
132
- await resolveDocument({
133
- rootDocument,
134
- externalRefResolver: new BaseResolver(),
135
- rootType: normalizeTypes(Oas3Types).DefinitionRoot,
136
- });
137
- } catch (e) {
138
- expect(e.message).toEqual('Self-referencing circular pointer');
139
- }
140
- });
141
-
142
- it('should resolve external ref', async () => {
143
- const cwd = path.join(__dirname, 'fixtures/resolve');
144
- const rootDocument = parseYamlToDocument(
145
- outdent`
146
- openapi: 3.0.0
147
- info:
148
- $ref: "./externalInfo.yaml#/info"
149
- `,
150
- path.join(cwd, 'foobar.yaml'),
151
- );
152
-
153
- const resolvedRefs = await resolveDocument({
154
- rootDocument,
155
- externalRefResolver: new BaseResolver(),
156
- rootType: normalizeTypes(Oas3Types).DefinitionRoot,
157
- });
158
-
159
- expect(resolvedRefs).toBeDefined();
160
- // expect(resolvedRefs.size).toEqual(2);
161
- expect(Array.from(resolvedRefs.keys()).map((ref) => ref.substring(cwd.length + 1))).toEqual([
162
- 'foobar.yaml::./externalInfo.yaml#/info',
163
- 'externalInfo.yaml::./externalLicense.yaml',
164
- ]);
165
-
166
- expect(Array.from(resolvedRefs.values()).map((info) => info.node)).toEqual([
167
- {
168
- contact: {},
169
- license: {
170
- $ref: './externalLicense.yaml',
171
- },
172
- },
173
- {
174
- name: 'MIT',
175
- },
176
- ]);
177
- });
178
-
179
- it('should resolve back references', async () => {
180
- const cwd = path.join(__dirname, 'fixtures/resolve');
181
- const externalRefResolver = new BaseResolver();
182
- const rootDocument = await externalRefResolver.resolveDocument(
183
- null,
184
- `${cwd}/openapi-with-back.yaml`,
185
- );
186
-
187
- const resolvedRefs = await resolveDocument({
188
- rootDocument: rootDocument as Document,
189
- externalRefResolver: externalRefResolver,
190
- rootType: normalizeTypes(Oas3Types).DefinitionRoot,
191
- });
192
-
193
- expect(resolvedRefs).toBeDefined();
194
-
195
- expect(Array.from(resolvedRefs.keys()).map((ref) => ref.substring(cwd.length + 1)).sort())
196
- .toMatchInlineSnapshot(`
197
- Array [
198
- "openapi-with-back.yaml::./schemas/type-a.yaml#/",
199
- "openapi-with-back.yaml::./schemas/type-b.yaml#/",
200
- "schemas/type-a.yaml::../openapi-with-back.yaml#/components/schemas/TypeB",
201
- ]
202
- `);
203
-
204
- expect(
205
- Array.from(resolvedRefs.values())
206
- .map((val) => val.node)
207
- .sort((firstEl, secondEl) => {
208
- const getKey = (el: any): string => el?.allOf?.type || el?.type || '';
209
-
210
- return getKey(firstEl).localeCompare(getKey(secondEl));
211
- })
212
- ).toMatchInlineSnapshot(`
213
- Array [
214
- Object {
215
- "allOf": Array [
216
- Object {
217
- "properties": Object {
218
- "integration_type": Object {
219
- "$ref": "../openapi-with-back.yaml#/components/schemas/TypeB",
220
- },
221
- "name": Object {
222
- "type": "string",
223
- },
224
- },
225
- "required": Array [
226
- "name",
227
- "integration_type",
228
- ],
229
- "type": "object",
230
- },
231
- ],
232
- },
233
- Object {
234
- "enum": Array [
235
- "webhook",
236
- "api_key",
237
- "sftp",
238
- "netsuite",
239
- ],
240
- "type": "string",
241
- },
242
- Object {
243
- "enum": Array [
244
- "webhook",
245
- "api_key",
246
- "sftp",
247
- "netsuite",
248
- ],
249
- "type": "string",
250
- },
251
- ]
252
- `);
253
- });
254
-
255
- it('should resolve external refs with circular', async () => {
256
- const cwd = path.join(__dirname, 'fixtures/resolve');
257
- const externalRefResolver = new BaseResolver();
258
- const rootDocument = await externalRefResolver.resolveDocument(null, `${cwd}/openapi.yaml`);
259
-
260
- const resolvedRefs = await resolveDocument({
261
- rootDocument: rootDocument as Document,
262
- externalRefResolver: externalRefResolver,
263
- rootType: normalizeTypes(Oas3Types).DefinitionRoot,
264
- });
265
-
266
- expect(resolvedRefs).toBeDefined();
267
- expect(Array.from(resolvedRefs.keys()).map((ref) => ref.substring(cwd.length + 1)))
268
- .toMatchInlineSnapshot(`
269
- Array [
270
- "openapi.yaml::#/components/schemas/Local",
271
- "openapi.yaml::#/components/schemas/Local/properties/string",
272
- "openapi.yaml::./External.yaml#/properties/string",
273
- "openapi.yaml::./External.yaml",
274
- "External.yaml::./External2.yaml",
275
- "External2.yaml::./External.yaml#/properties",
276
- ]
277
- `);
278
-
279
- expect(Array.from(resolvedRefs.values()).map((val) => val.node)).toMatchInlineSnapshot(`
280
- Array [
281
- Object {
282
- "properties": Object {
283
- "localCircular": Object {
284
- "$ref": "#/components/schemas/Local",
285
- },
286
- "number": Object {
287
- "type": "number",
288
- },
289
- "string": Object {
290
- "type": "string",
291
- },
292
- },
293
- },
294
- Object {
295
- "type": "string",
296
- },
297
- Object {
298
- "type": "string",
299
- },
300
- Object {
301
- "properties": Object {
302
- "external": Object {
303
- "$ref": "./External2.yaml",
304
- },
305
- "number": Object {
306
- "type": "number",
307
- },
308
- "string": Object {
309
- "type": "string",
310
- },
311
- "unknown": Object {
312
- "type": "string",
313
- },
314
- },
315
- "type": "object",
316
- },
317
- Object {
318
- "properties": Object {
319
- "circularParent": Object {
320
- "$ref": "./External.yaml#/properties",
321
- },
322
- },
323
- "type": "object",
324
- },
325
- Object {
326
- "external": Object {
327
- "$ref": "./External2.yaml",
328
- },
329
- "number": Object {
330
- "type": "number",
331
- },
332
- "string": Object {
333
- "type": "string",
334
- },
335
- "unknown": Object {
336
- "type": "string",
337
- },
338
- },
339
- ]
340
- `);
341
- });
342
-
343
- it('should resolve referenceable scalars', async () => {
344
- const cwd = path.join(__dirname, 'fixtures/resolve');
345
- const externalRefResolver = new BaseResolver();
346
- const rootDocument = await externalRefResolver.resolveDocument(
347
- null,
348
- `${cwd}/openapi-with-md-description.yaml`,
349
- );
350
-
351
- expect(rootDocument).toBeDefined();
352
-
353
- // @ts-ignore
354
- Oas3Types.Info.properties.description['referenceable'] = true;
355
- const resolvedRefs = await resolveDocument({
356
- rootDocument: rootDocument as Document,
357
- externalRefResolver: externalRefResolver,
358
- rootType: normalizeTypes(Oas3Types).DefinitionRoot,
359
- });
360
-
361
- expect(resolvedRefs).toBeDefined();
362
- // expect(resolvedRefs.size).toEqual(2);
363
- expect(Array.from(resolvedRefs.keys()).map((ref) => ref.substring(cwd.length + 1)))
364
- .toMatchInlineSnapshot(`
365
- Array [
366
- "openapi-with-md-description.yaml::./description.md",
367
- ]
368
- `);
369
- expect(Array.from(resolvedRefs.values()).map((val) => val.node)).toMatchInlineSnapshot(`
370
- Array [
371
- "# Hello World
372
-
373
- Lorem ipsum",
374
- ]
375
- `);
376
- });
377
-
378
- it('should resolve external transitive ref', async () => {
379
- const cwd = path.join(__dirname, 'fixtures/resolve');
380
- const rootDocument = parseYamlToDocument(
381
- outdent`
382
- openapi: 3.0.0
383
- components:
384
- $ref: "./transitive/components.yaml#/components/schemas/a"
385
- `,
386
- path.join(cwd, 'foobar.yaml'),
387
- );
388
-
389
- const resolvedRefs = await resolveDocument({
390
- rootDocument,
391
- externalRefResolver: new BaseResolver(),
392
- rootType: normalizeTypes(Oas3Types).DefinitionRoot,
393
- });
394
-
395
- expect(resolvedRefs).toBeDefined();
396
- expect(resolvedRefs.size).toEqual(3);
397
- expect(Array.from(resolvedRefs.keys()).map((ref) => ref.substring(cwd.length + 1))).toEqual([
398
- 'transitive/components.yaml::./schemas.yaml#/schemas',
399
- 'transitive/schemas.yaml::a.yaml',
400
- 'foobar.yaml::./transitive/components.yaml#/components/schemas/a',
401
- ]);
402
-
403
- expect(Array.from(resolvedRefs.values()).pop()!.node).toEqual({ type: 'string' });
404
- });
405
- });
@@ -1,85 +0,0 @@
1
- import { pickObjectProps, omitObjectProps, slash, getMatchingStatusCodeRange } from '../utils';
2
-
3
- describe('utils', () => {
4
- const testObject = {
5
- a: 'value a',
6
- b: 'value b',
7
- c: 'value c',
8
- d: 'value d',
9
- e: 'value e',
10
- };
11
-
12
- describe('pickObjectProps', () => {
13
- it('returns correct object result', () => {
14
- expect(pickObjectProps(testObject, ['a', 'b'])).toStrictEqual({ a: 'value a', b: 'value b' });
15
- });
16
-
17
- it('returns correct object if passed non existing key', () => {
18
- expect(pickObjectProps(testObject, ['a', 'b', 'nonExisting'])).toStrictEqual({
19
- a: 'value a',
20
- b: 'value b',
21
- });
22
- });
23
-
24
- it('returns an empty object if no keys are passed', () => {
25
- expect(pickObjectProps(testObject, [])).toStrictEqual({});
26
- });
27
-
28
- it('returns an empty object if empty target obj passed', () => {
29
- expect(pickObjectProps({}, ['d', 'e'])).toStrictEqual({});
30
- });
31
- });
32
-
33
- describe('omitObjectProps', () => {
34
- it('returns correct object result', () => {
35
- expect(omitObjectProps(testObject, ['a', 'b', 'c'])).toStrictEqual({
36
- d: 'value d',
37
- e: 'value e',
38
- });
39
- });
40
-
41
- it('returns correct object if passed non existing key', () => {
42
- expect(omitObjectProps(testObject, ['a', 'b', 'c', 'nonExisting'])).toStrictEqual({
43
- d: 'value d',
44
- e: 'value e',
45
- });
46
- });
47
-
48
- it('returns full object if no keys are passed', () => {
49
- expect(omitObjectProps(testObject, [])).toStrictEqual(testObject);
50
- });
51
-
52
- it('returns an empty object if empty target obj passed', () => {
53
- expect(omitObjectProps({}, ['d', 'e'])).toStrictEqual({});
54
- });
55
- });
56
-
57
- describe('slash path', () => {
58
- it('can correctly slash path', () => {
59
- [
60
- ['foo\\bar', 'foo/bar'],
61
- ['foo/bar', 'foo/bar'],
62
- ['foo\\中文', 'foo/中文'],
63
- ['foo/中文', 'foo/中文'],
64
- ].forEach(([path, expectRes]) => {
65
- expect(slash(path)).toBe(expectRes);
66
- });
67
- });
68
-
69
- it('does not modify extended length paths', () => {
70
- const extended = '\\\\?\\some\\path';
71
- expect(slash(extended)).toBe(extended);
72
- });
73
- });
74
-
75
- describe('getMatchingStatusCodeRange', () => {
76
- it('should get the generalized form of status codes', () => {
77
- expect(getMatchingStatusCodeRange('202')).toEqual('2XX');
78
- expect(getMatchingStatusCodeRange(400)).toEqual('4XX');
79
- });
80
- it('should fail on a wrong input', () => {
81
- expect(getMatchingStatusCodeRange('2002')).toEqual('2002');
82
- expect(getMatchingStatusCodeRange(4000)).toEqual('4000');
83
- });
84
- });
85
- });