@redocly/openapi-core 1.0.0-beta.98 → 1.0.0-rc.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.
Files changed (380) 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 +12 -15
  8. package/lib/bundle.js +38 -15
  9. package/lib/config/all.d.ts +2 -2
  10. package/lib/config/all.js +17 -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 +8 -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.d.ts +2 -0
  94. package/lib/rules/common/response-contains-header.js +29 -0
  95. package/lib/rules/common/scalar-property-missing-example.d.ts +2 -0
  96. package/lib/rules/common/scalar-property-missing-example.js +42 -0
  97. package/lib/rules/common/security-defined.d.ts +2 -0
  98. package/lib/rules/common/{operation-security-defined.js → security-defined.js} +25 -6
  99. package/lib/rules/common/spec-strict-refs.d.ts +2 -0
  100. package/lib/rules/common/spec-strict-refs.js +30 -0
  101. package/lib/rules/common/spec.js +41 -18
  102. package/lib/rules/common/tags-alphabetical.js +1 -1
  103. package/lib/rules/oas2/index.d.ts +6 -2
  104. package/lib/rules/oas2/index.js +16 -8
  105. package/lib/rules/oas2/remove-unused-components.js +6 -6
  106. package/lib/rules/oas2/request-mime-type.d.ts +1 -1
  107. package/lib/rules/oas2/request-mime-type.js +1 -1
  108. package/lib/rules/oas2/response-contains-property.d.ts +2 -0
  109. package/lib/rules/oas2/response-contains-property.js +38 -0
  110. package/lib/rules/oas2/response-mime-type.d.ts +1 -1
  111. package/lib/rules/oas2/response-mime-type.js +1 -1
  112. package/lib/rules/oas3/component-name-unique.d.ts +2 -0
  113. package/lib/rules/oas3/component-name-unique.js +124 -0
  114. package/lib/rules/oas3/index.js +24 -10
  115. package/lib/rules/oas3/no-empty-servers.js +2 -2
  116. package/lib/rules/oas3/no-invalid-media-type-examples.js +2 -2
  117. package/lib/rules/oas3/no-server-variables-empty-enum.d.ts +2 -0
  118. package/lib/rules/oas3/{no-servers-empty-enum.js → no-server-variables-empty-enum.js} +5 -5
  119. package/lib/rules/oas3/no-unused-components.js +2 -2
  120. package/lib/rules/oas3/operation-4xx-problem-details-rfc7807.d.ts +5 -0
  121. package/lib/rules/oas3/operation-4xx-problem-details-rfc7807.js +36 -0
  122. package/lib/rules/oas3/remove-unused-components.js +6 -6
  123. package/lib/rules/oas3/request-mime-type.d.ts +1 -1
  124. package/lib/rules/oas3/request-mime-type.js +1 -1
  125. package/lib/rules/oas3/response-contains-property.d.ts +2 -0
  126. package/lib/rules/oas3/response-contains-property.js +40 -0
  127. package/lib/rules/oas3/response-mime-type.d.ts +1 -1
  128. package/lib/rules/oas3/response-mime-type.js +1 -1
  129. package/lib/rules/oas3/spec-components-invalid-map-name.d.ts +2 -0
  130. package/lib/rules/oas3/spec-components-invalid-map-name.js +62 -0
  131. package/lib/rules/other/stats.d.ts +2 -2
  132. package/lib/rules/other/stats.js +45 -16
  133. package/lib/rules/utils.d.ts +5 -2
  134. package/lib/rules/utils.js +54 -6
  135. package/lib/types/config-external-schemas.d.ts +2193 -0
  136. package/lib/types/config-external-schemas.js +805 -0
  137. package/lib/types/index.d.ts +3 -2
  138. package/lib/types/index.js +9 -1
  139. package/lib/types/oas2.js +91 -15
  140. package/lib/types/oas3.js +139 -49
  141. package/lib/types/oas3_1.js +32 -26
  142. package/lib/types/redocly-yaml.js +414 -58
  143. package/lib/typings/openapi.d.ts +3 -2
  144. package/lib/utils.d.ts +15 -3
  145. package/lib/utils.js +73 -7
  146. package/lib/visitors.d.ts +20 -16
  147. package/lib/visitors.js +28 -3
  148. package/lib/walk.d.ts +11 -19
  149. package/lib/walk.js +74 -53
  150. package/package.json +5 -6
  151. package/__tests__/__snapshots__/bundle.test.ts.snap +0 -229
  152. package/__tests__/bundle.test.ts +0 -132
  153. package/__tests__/codeframes.test.ts +0 -531
  154. package/__tests__/fixtures/extension.js +0 -24
  155. package/__tests__/fixtures/refs/definitions.yaml +0 -3
  156. package/__tests__/fixtures/refs/examples.yaml +0 -8
  157. package/__tests__/fixtures/refs/external-request-body.yaml +0 -13
  158. package/__tests__/fixtures/refs/externalref.yaml +0 -35
  159. package/__tests__/fixtures/refs/hosted.yaml +0 -35
  160. package/__tests__/fixtures/refs/openapi-with-external-refs-conflicting-names.yaml +0 -21
  161. package/__tests__/fixtures/refs/openapi-with-external-refs.yaml +0 -33
  162. package/__tests__/fixtures/refs/param-b.yaml +0 -1
  163. package/__tests__/fixtures/refs/param-c.yaml +0 -1
  164. package/__tests__/fixtures/refs/rename.yaml +0 -1
  165. package/__tests__/fixtures/refs/requestBody.yaml +0 -9
  166. package/__tests__/fixtures/refs/schema-a.yaml +0 -1
  167. package/__tests__/fixtures/refs/simple.yaml +0 -1
  168. package/__tests__/fixtures/refs/vendor.schema.yaml +0 -20
  169. package/__tests__/fixtures/resolve/External.yaml +0 -10
  170. package/__tests__/fixtures/resolve/External2.yaml +0 -4
  171. package/__tests__/fixtures/resolve/description.md +0 -3
  172. package/__tests__/fixtures/resolve/externalInfo.yaml +0 -4
  173. package/__tests__/fixtures/resolve/externalLicense.yaml +0 -1
  174. package/__tests__/fixtures/resolve/openapi-with-back.yaml +0 -13
  175. package/__tests__/fixtures/resolve/openapi-with-md-description.yaml +0 -5
  176. package/__tests__/fixtures/resolve/openapi.yaml +0 -28
  177. package/__tests__/fixtures/resolve/schemas/type-a.yaml +0 -10
  178. package/__tests__/fixtures/resolve/schemas/type-b.yaml +0 -6
  179. package/__tests__/fixtures/resolve/transitive/a.yaml +0 -1
  180. package/__tests__/fixtures/resolve/transitive/components.yaml +0 -5
  181. package/__tests__/fixtures/resolve/transitive/schemas.yaml +0 -3
  182. package/__tests__/lint.test.ts +0 -17
  183. package/__tests__/login.test.ts +0 -17
  184. package/__tests__/normalizeVisitors.test.ts +0 -151
  185. package/__tests__/ref-utils.test.ts +0 -120
  186. package/__tests__/resolve-http.test.ts +0 -77
  187. package/__tests__/resolve.test.ts +0 -405
  188. package/__tests__/utils.ts +0 -86
  189. package/__tests__/walk.test.ts +0 -1485
  190. package/lib/rules/common/info-description.d.ts +0 -2
  191. package/lib/rules/common/info-description.js +0 -12
  192. package/lib/rules/common/license-url.d.ts +0 -2
  193. package/lib/rules/common/license-url.js +0 -12
  194. package/lib/rules/common/operation-security-defined.d.ts +0 -2
  195. package/lib/rules/oas3/no-servers-empty-enum.d.ts +0 -2
  196. package/src/__tests__/js-yaml.test.ts +0 -71
  197. package/src/__tests__/lint.test.ts +0 -182
  198. package/src/__tests__/utils.test.ts +0 -74
  199. package/src/benchmark/benches/lint-with-many-rules.bench.ts +0 -35
  200. package/src/benchmark/benches/lint-with-nested-rule.bench.ts +0 -39
  201. package/src/benchmark/benches/lint-with-no-rules.bench.ts +0 -20
  202. package/src/benchmark/benches/lint-with-top-level-rule-report.bench.ts +0 -36
  203. package/src/benchmark/benches/lint-with-top-level-rule.bench.ts +0 -32
  204. package/src/benchmark/benches/rebilly.yaml +0 -32267
  205. package/src/benchmark/benches/recommended-oas3.bench.ts +0 -22
  206. package/src/benchmark/benches/resolve-with-no-external.bench.ts +0 -23
  207. package/src/benchmark/benchmark.js +0 -307
  208. package/src/benchmark/colors.js +0 -29
  209. package/src/benchmark/fork.js +0 -83
  210. package/src/benchmark/utils.ts +0 -36
  211. package/src/bundle.ts +0 -371
  212. package/src/config/__tests__/__snapshots__/config-resolvers.test.ts.snap +0 -157
  213. package/src/config/__tests__/config-resolvers.test.ts +0 -429
  214. package/src/config/__tests__/config.test.ts +0 -244
  215. package/src/config/__tests__/fixtures/plugin-config.yaml +0 -3
  216. package/src/config/__tests__/fixtures/plugin.js +0 -56
  217. package/src/config/__tests__/fixtures/resolve-config/api/nested-config.yaml +0 -12
  218. package/src/config/__tests__/fixtures/resolve-config/api/plugin.js +0 -67
  219. package/src/config/__tests__/fixtures/resolve-config/local-config-with-circular.yaml +0 -8
  220. package/src/config/__tests__/fixtures/resolve-config/local-config-with-file.yaml +0 -19
  221. package/src/config/__tests__/fixtures/resolve-config/local-config.yaml +0 -10
  222. package/src/config/__tests__/fixtures/resolve-config/plugin.js +0 -66
  223. package/src/config/__tests__/fixtures/resolve-remote-configs/nested-remote-config.yaml +0 -4
  224. package/src/config/__tests__/fixtures/resolve-remote-configs/remote-config.yaml +0 -5
  225. package/src/config/__tests__/load.test.ts +0 -83
  226. package/src/config/__tests__/resolve-plugins.test.ts +0 -27
  227. package/src/config/all.ts +0 -65
  228. package/src/config/builtIn.ts +0 -37
  229. package/src/config/config-resolvers.ts +0 -359
  230. package/src/config/config.ts +0 -312
  231. package/src/config/index.ts +0 -7
  232. package/src/config/load.ts +0 -84
  233. package/src/config/minimal.ts +0 -58
  234. package/src/config/recommended.ts +0 -58
  235. package/src/config/rules.ts +0 -46
  236. package/src/config/types.ts +0 -168
  237. package/src/config/utils.ts +0 -208
  238. package/src/decorators/__tests__/remove-x-internal.test.ts +0 -316
  239. package/src/decorators/common/info-description-override.ts +0 -24
  240. package/src/decorators/common/operation-description-override.ts +0 -30
  241. package/src/decorators/common/registry-dependencies.ts +0 -25
  242. package/src/decorators/common/remove-x-internal.ts +0 -59
  243. package/src/decorators/common/tag-description-override.ts +0 -25
  244. package/src/decorators/oas2/index.ts +0 -14
  245. package/src/decorators/oas3/index.ts +0 -14
  246. package/src/format/codeframes.ts +0 -210
  247. package/src/format/format.ts +0 -339
  248. package/src/index.ts +0 -68
  249. package/src/js-yaml/index.ts +0 -18
  250. package/src/lint.ts +0 -125
  251. package/src/oas-types.ts +0 -62
  252. package/src/redocly/__tests__/redocly-client.test.ts +0 -140
  253. package/src/redocly/index.ts +0 -182
  254. package/src/redocly/redocly-client-types.ts +0 -10
  255. package/src/redocly/registry-api-types.ts +0 -32
  256. package/src/redocly/registry-api.ts +0 -134
  257. package/src/ref-utils.ts +0 -79
  258. package/src/resolve.ts +0 -378
  259. package/src/rules/__tests__/fixtures/invalid-yaml.yaml +0 -1
  260. package/src/rules/__tests__/fixtures/ref.yaml +0 -1
  261. package/src/rules/__tests__/no-unresolved-refs.test.ts +0 -168
  262. package/src/rules/ajv.ts +0 -103
  263. package/src/rules/common/__tests__/info-description.test.ts +0 -102
  264. package/src/rules/common/__tests__/info-license.test.ts +0 -62
  265. package/src/rules/common/__tests__/license-url.test.ts +0 -63
  266. package/src/rules/common/__tests__/no-ambiguous-paths.test.ts +0 -96
  267. package/src/rules/common/__tests__/no-enum-type-mismatch.test.ts +0 -209
  268. package/src/rules/common/__tests__/no-identical-paths.test.ts +0 -58
  269. package/src/rules/common/__tests__/no-path-trailing-slash.test.ts +0 -85
  270. package/src/rules/common/__tests__/operation-2xx-response.test.ts +0 -91
  271. package/src/rules/common/__tests__/operation-4xx-response.test.ts +0 -107
  272. package/src/rules/common/__tests__/operation-operationId-unique.test.ts +0 -76
  273. package/src/rules/common/__tests__/operation-operationId-url-safe.test.ts +0 -45
  274. package/src/rules/common/__tests__/operation-parameters-unique.test.ts +0 -167
  275. package/src/rules/common/__tests__/operation-security-defined.test.ts +0 -69
  276. package/src/rules/common/__tests__/operation-singular-tag.test.ts +0 -72
  277. package/src/rules/common/__tests__/path-http-verbs-order.test.ts +0 -95
  278. package/src/rules/common/__tests__/path-not-include-query.test.ts +0 -64
  279. package/src/rules/common/__tests__/path-params-defined.test.ts +0 -133
  280. package/src/rules/common/__tests__/paths-kebab-case.test.ts +0 -108
  281. package/src/rules/common/__tests__/spec.test.ts +0 -62
  282. package/src/rules/common/__tests__/tag-description.test.ts +0 -65
  283. package/src/rules/common/__tests__/tags-alphabetical.test.ts +0 -64
  284. package/src/rules/common/assertions/__tests__/asserts.test.ts +0 -231
  285. package/src/rules/common/assertions/__tests__/index.test.ts +0 -65
  286. package/src/rules/common/assertions/__tests__/utils.test.ts +0 -89
  287. package/src/rules/common/assertions/asserts.ts +0 -137
  288. package/src/rules/common/assertions/index.ts +0 -75
  289. package/src/rules/common/assertions/utils.ts +0 -167
  290. package/src/rules/common/info-contact.ts +0 -15
  291. package/src/rules/common/info-description.ts +0 -10
  292. package/src/rules/common/info-license-url.ts +0 -15
  293. package/src/rules/common/license-url.ts +0 -10
  294. package/src/rules/common/no-ambiguous-paths.ts +0 -50
  295. package/src/rules/common/no-enum-type-mismatch.ts +0 -49
  296. package/src/rules/common/no-http-verbs-in-paths.ts +0 -36
  297. package/src/rules/common/no-identical-paths.ts +0 -24
  298. package/src/rules/common/no-invalid-parameter-examples.ts +0 -36
  299. package/src/rules/common/no-invalid-schema-examples.ts +0 -27
  300. package/src/rules/common/no-path-trailing-slash.ts +0 -15
  301. package/src/rules/common/operation-2xx-response.ts +0 -16
  302. package/src/rules/common/operation-4xx-response.ts +0 -17
  303. package/src/rules/common/operation-description.ts +0 -13
  304. package/src/rules/common/operation-operationId-unique.ts +0 -21
  305. package/src/rules/common/operation-operationId-url-safe.ts +0 -19
  306. package/src/rules/common/operation-operationId.ts +0 -17
  307. package/src/rules/common/operation-parameters-unique.ts +0 -48
  308. package/src/rules/common/operation-security-defined.ts +0 -45
  309. package/src/rules/common/operation-singular-tag.ts +0 -17
  310. package/src/rules/common/operation-summary.ts +0 -13
  311. package/src/rules/common/operation-tag-defined.ts +0 -26
  312. package/src/rules/common/parameter-description.ts +0 -22
  313. package/src/rules/common/path-declaration-must-exist.ts +0 -15
  314. package/src/rules/common/path-excludes-patterns.ts +0 -23
  315. package/src/rules/common/path-http-verbs-order.ts +0 -30
  316. package/src/rules/common/path-not-include-query.ts +0 -17
  317. package/src/rules/common/path-params-defined.ts +0 -58
  318. package/src/rules/common/path-segment-plural.ts +0 -31
  319. package/src/rules/common/paths-kebab-case.ts +0 -16
  320. package/src/rules/common/spec.ts +0 -143
  321. package/src/rules/common/tag-description.ts +0 -10
  322. package/src/rules/common/tags-alphabetical.ts +0 -20
  323. package/src/rules/no-unresolved-refs.ts +0 -51
  324. package/src/rules/oas2/__tests__/boolean-parameter-prefixes.test.ts +0 -110
  325. package/src/rules/oas2/__tests__/spec/fixtures/description.md +0 -1
  326. package/src/rules/oas2/__tests__/spec/info.test.ts +0 -355
  327. package/src/rules/oas2/__tests__/spec/operation.test.ts +0 -123
  328. package/src/rules/oas2/__tests__/spec/paths.test.ts +0 -245
  329. package/src/rules/oas2/__tests__/spec/referenceableScalars.test.ts +0 -31
  330. package/src/rules/oas2/__tests__/spec/utils.ts +0 -32
  331. package/src/rules/oas2/boolean-parameter-prefixes.ts +0 -26
  332. package/src/rules/oas2/index.ts +0 -83
  333. package/src/rules/oas2/remove-unused-components.ts +0 -76
  334. package/src/rules/oas2/request-mime-type.ts +0 -17
  335. package/src/rules/oas2/response-mime-type.ts +0 -17
  336. package/src/rules/oas3/__tests__/boolean-parameter-prefixes.test.ts +0 -111
  337. package/src/rules/oas3/__tests__/fixtures/common.yaml +0 -11
  338. package/src/rules/oas3/__tests__/no-empty-enum-servers.com.test.ts +0 -205
  339. package/src/rules/oas3/__tests__/no-example-value-and-externalValue.test.ts +0 -65
  340. package/src/rules/oas3/__tests__/no-invalid-media-type-examples.test.ts +0 -392
  341. package/src/rules/oas3/__tests__/no-server-example.com.test.ts +0 -60
  342. package/src/rules/oas3/__tests__/no-server-trailing-slash.test.ts +0 -79
  343. package/src/rules/oas3/__tests__/no-unused-components.test.ts +0 -131
  344. package/src/rules/oas3/__tests__/spec/callbacks.test.ts +0 -41
  345. package/src/rules/oas3/__tests__/spec/fixtures/description.md +0 -1
  346. package/src/rules/oas3/__tests__/spec/info.test.ts +0 -391
  347. package/src/rules/oas3/__tests__/spec/operation.test.ts +0 -253
  348. package/src/rules/oas3/__tests__/spec/paths.test.ts +0 -284
  349. package/src/rules/oas3/__tests__/spec/referenceableScalars.test.ts +0 -77
  350. package/src/rules/oas3/__tests__/spec/servers.test.ts +0 -499
  351. package/src/rules/oas3/__tests__/spec/spec.test.ts +0 -288
  352. package/src/rules/oas3/__tests__/spec/utils.ts +0 -32
  353. package/src/rules/oas3/boolean-parameter-prefixes.ts +0 -28
  354. package/src/rules/oas3/index.ts +0 -99
  355. package/src/rules/oas3/no-empty-servers.ts +0 -22
  356. package/src/rules/oas3/no-example-value-and-externalValue.ts +0 -14
  357. package/src/rules/oas3/no-invalid-media-type-examples.ts +0 -41
  358. package/src/rules/oas3/no-server-example.com.ts +0 -14
  359. package/src/rules/oas3/no-server-trailing-slash.ts +0 -15
  360. package/src/rules/oas3/no-servers-empty-enum.ts +0 -67
  361. package/src/rules/oas3/no-undefined-server-variable.ts +0 -30
  362. package/src/rules/oas3/no-unused-components.ts +0 -75
  363. package/src/rules/oas3/remove-unused-components.ts +0 -84
  364. package/src/rules/oas3/request-mime-type.ts +0 -31
  365. package/src/rules/oas3/response-mime-type.ts +0 -31
  366. package/src/rules/other/stats.ts +0 -44
  367. package/src/rules/utils.ts +0 -123
  368. package/src/types/index.ts +0 -138
  369. package/src/types/oas2.ts +0 -397
  370. package/src/types/oas3.ts +0 -506
  371. package/src/types/oas3_1.ts +0 -251
  372. package/src/types/redocly-yaml.ts +0 -637
  373. package/src/typings/common.ts +0 -9
  374. package/src/typings/openapi.ts +0 -297
  375. package/src/typings/swagger.ts +0 -236
  376. package/src/utils.ts +0 -190
  377. package/src/visitors.ts +0 -448
  378. package/src/walk.ts +0 -416
  379. package/tsconfig.json +0 -8
  380. package/tsconfig.tsbuildinfo +0 -1
@@ -1,429 +0,0 @@
1
- import { resolveLint, resolveApis, resolveConfig } from '../config-resolvers';
2
- const path = require('path');
3
-
4
- import type { LintRawConfig, RawConfig } from '../types';
5
-
6
- const configPath = path.join(__dirname, 'fixtures/resolve-config/.redocly.yaml');
7
- const baseLintConfig: LintRawConfig = {
8
- rules: {
9
- 'operation-2xx-response': 'warn',
10
- },
11
- };
12
-
13
- const minimalLintPreset = resolveLint({
14
- lintConfig: { ...baseLintConfig, extends: ['minimal'] },
15
- });
16
-
17
- const recommendedLintPreset = resolveLint({
18
- lintConfig: { ...baseLintConfig, extends: ['recommended'] },
19
- });
20
-
21
- const removeAbsolutePath = (item: string) =>
22
- item.match(/^.*\/packages\/core\/src\/config\/__tests__\/fixtures\/(.*)$/)![1];
23
-
24
- describe('resolveLint', () => {
25
- it('should return the config with no recommended', async () => {
26
- const lint = await resolveLint({ lintConfig: baseLintConfig });
27
- expect(lint.plugins?.length).toEqual(1);
28
- expect(lint.plugins?.[0].id).toEqual('');
29
- expect(lint.rules).toEqual({
30
- 'operation-2xx-response': 'warn',
31
- });
32
- });
33
-
34
- it('should return the config with correct order by preset', async () => {
35
- expect(
36
- await resolveLint({
37
- lintConfig: { ...baseLintConfig, extends: ['minimal', 'recommended'] },
38
- }),
39
- ).toEqual(await recommendedLintPreset);
40
- expect(
41
- await resolveLint({
42
- lintConfig: { ...baseLintConfig, extends: ['recommended', 'minimal'] },
43
- }),
44
- ).toEqual(await minimalLintPreset);
45
- });
46
-
47
- it('should return the same lintConfig when extends is empty array', async () => {
48
- const configWithEmptyExtends = await resolveLint({
49
- lintConfig: { ...baseLintConfig, extends: [] },
50
- });
51
- expect(configWithEmptyExtends.plugins?.length).toEqual(1);
52
- expect(configWithEmptyExtends.plugins?.[0].id).toEqual('');
53
- expect(configWithEmptyExtends.rules).toEqual({
54
- 'operation-2xx-response': 'warn',
55
- });
56
- });
57
-
58
- it('should resolve extends with local file config', async () => {
59
- const config = {
60
- ...baseLintConfig,
61
- extends: ['local-config.yaml'],
62
- };
63
-
64
- const { plugins, ...lint } = await resolveLint({
65
- lintConfig: config,
66
- configPath,
67
- });
68
-
69
- expect(lint?.rules?.['operation-2xx-response']).toEqual('warn');
70
- expect(plugins).toBeDefined();
71
- expect(plugins?.length).toBe(2);
72
-
73
- expect(lint.extendPaths!.map(removeAbsolutePath)).toEqual([
74
- 'resolve-config/.redocly.yaml',
75
- 'resolve-config/local-config.yaml',
76
- 'resolve-config/.redocly.yaml',
77
- ]);
78
- expect(lint.pluginPaths!.map(removeAbsolutePath)).toEqual(['resolve-config/plugin.js']);
79
-
80
- expect(lint.rules).toEqual({
81
- 'boolean-parameter-prefixes': 'error',
82
- 'local/operation-id-not-test': 'error',
83
- 'no-invalid-media-type-examples': 'error',
84
- 'operation-2xx-response': 'warn',
85
- 'operation-description': 'error',
86
- 'path-http-verbs-order': 'error',
87
- });
88
- });
89
-
90
- // TODO: fix circular test
91
- it.skip('should throw circular error', () => {
92
- const config = {
93
- ...baseLintConfig,
94
- extends: ['local-config-with-circular.yaml'],
95
- };
96
- expect(() => {
97
- resolveLint({ lintConfig: config, configPath });
98
- }).toThrow('Circular dependency in config file');
99
- });
100
-
101
- it('should resolve extends with local file config witch contains path to nested config', async () => {
102
- const lintConfig = {
103
- extends: ['local-config-with-file.yaml'],
104
- };
105
- const { plugins, ...lint } = await resolveLint({
106
- lintConfig,
107
- configPath,
108
- });
109
-
110
- expect(lint?.rules?.['no-invalid-media-type-examples']).toEqual('warn');
111
- expect(lint?.rules?.['operation-4xx-response']).toEqual('off');
112
- expect(lint?.rules?.['operation-2xx-response']).toEqual('error');
113
- expect(plugins).toBeDefined();
114
- expect(plugins?.length).toBe(3);
115
-
116
- expect(lint.extendPaths!.map(removeAbsolutePath)).toEqual([
117
- 'resolve-config/.redocly.yaml',
118
- 'resolve-config/local-config-with-file.yaml',
119
- 'resolve-config/api/nested-config.yaml',
120
- 'resolve-config/.redocly.yaml',
121
- ]);
122
- expect(lint.pluginPaths!.map(removeAbsolutePath)).toEqual([
123
- 'resolve-config/api/plugin.js',
124
- 'resolve-config/plugin.js',
125
- 'resolve-config/api/plugin.js',
126
- ]);
127
-
128
- delete lint.extendPaths;
129
- delete lint.pluginPaths;
130
- expect(lint).toMatchSnapshot();
131
- });
132
-
133
- it('should correctly merge assertions from nested config', async () => {
134
- const lintConfig = {
135
- extends: ['local-config-with-file.yaml'],
136
- };
137
-
138
- const lint = await resolveLint({
139
- lintConfig,
140
- configPath,
141
- });
142
-
143
- expect(Array.isArray(lint.rules?.assertions)).toEqual(true);
144
- expect(lint.rules?.assertions).toMatchObject( [
145
- {
146
- subject: 'PathItem',
147
- property: 'get',
148
- message: 'Every path item must have a GET operation.',
149
- defined: true,
150
- assertionId: 'path-item-get-defined'
151
- },
152
- {
153
- subject: 'Tag',
154
- property: 'description',
155
- message: 'Tag description must be at least 13 characters and end with a full stop.',
156
- severity: 'error',
157
- minLength: 13,
158
- pattern: '/\\.$/',
159
- assertionId: 'tag-description'
160
- }
161
- ])
162
- });
163
-
164
- it('should resolve extends with url file config witch contains path to nested config', async () => {
165
- const lintConfig = {
166
- // This points to ./fixtures/resolve-remote-configs/remote-config.yaml
167
- extends: [
168
- 'https://raw.githubusercontent.com/Redocly/openapi-cli/master/packages/core/src/config/__tests__/fixtures/resolve-remote-configs/remote-config.yaml',
169
- ],
170
- };
171
-
172
- const { plugins, ...lint } = await resolveLint({
173
- lintConfig,
174
- configPath,
175
- });
176
-
177
- expect(lint?.rules?.['operation-4xx-response']).toEqual('error');
178
- expect(lint?.rules?.['operation-2xx-response']).toEqual('error');
179
- expect(Object.keys(lint.rules || {}).length).toBe(2);
180
-
181
- expect(lint.extendPaths!.map(removeAbsolutePath)).toEqual([
182
- 'resolve-config/.redocly.yaml',
183
- 'resolve-config/.redocly.yaml',
184
- ]);
185
- expect(lint.pluginPaths!.map(removeAbsolutePath)).toEqual([]);
186
- });
187
- });
188
-
189
- describe('resolveApis', () => {
190
- it('should resolve apis lintConfig and merge minimal extends', async () => {
191
- const rawConfig: RawConfig = {
192
- apis: {
193
- petstore: {
194
- root: 'some/path',
195
- lint: {},
196
- },
197
- },
198
- lint: {
199
- extends: ['minimal'],
200
- },
201
- };
202
- const apisResult = await resolveApis({ rawConfig });
203
- expect(apisResult['petstore'].lint).toEqual(await minimalLintPreset);
204
- });
205
-
206
- it('should not merge recommended extends by default by every level', async () => {
207
- const rawConfig: RawConfig = {
208
- apis: {
209
- petstore: {
210
- root: 'some/path',
211
- lint: {},
212
- },
213
- },
214
- lint: {},
215
- };
216
-
217
- const apisResult = await resolveApis({ rawConfig, configPath });
218
-
219
- expect(apisResult['petstore'].lint.extendPaths!.map(removeAbsolutePath)).toEqual([
220
- 'resolve-config/.redocly.yaml',
221
- ]);
222
- expect(apisResult['petstore'].lint.pluginPaths!.map(removeAbsolutePath)).toEqual([]);
223
-
224
- expect(apisResult['petstore'].lint.rules).toEqual({});
225
- //@ts-ignore
226
- expect(apisResult['petstore'].lint.plugins.length).toEqual(1);
227
- //@ts-ignore
228
- expect(apisResult['petstore'].lint.plugins[0].id).toEqual('');
229
- });
230
-
231
- it('should resolve apis lintConfig when it contains file and not set recommended', async () => {
232
- const rawConfig: RawConfig = {
233
- apis: {
234
- petstore: {
235
- root: 'some/path',
236
- lint: {
237
- rules: {
238
- 'operation-4xx-response': 'error',
239
- },
240
- },
241
- },
242
- },
243
- lint: {
244
- rules: {
245
- 'operation-2xx-response': 'warn',
246
- },
247
- },
248
- };
249
-
250
- const apisResult = await resolveApis({ rawConfig, configPath });
251
- expect(apisResult['petstore'].lint.rules).toEqual({
252
- 'operation-2xx-response': 'warn',
253
- 'operation-4xx-response': 'error',
254
- });
255
- //@ts-ignore
256
- expect(apisResult['petstore'].lint.plugins.length).toEqual(1);
257
- //@ts-ignore
258
- expect(apisResult['petstore'].lint.plugins[0].id).toEqual('');
259
-
260
- expect(apisResult['petstore'].lint.extendPaths!.map(removeAbsolutePath)).toEqual([
261
- 'resolve-config/.redocly.yaml',
262
- ]);
263
- expect(apisResult['petstore'].lint.pluginPaths!.map(removeAbsolutePath)).toEqual([]);
264
- });
265
-
266
- it('should resolve apis lintConfig when it contains file', async () => {
267
- const rawConfig: RawConfig = {
268
- apis: {
269
- petstore: {
270
- root: 'some/path',
271
- lint: {
272
- extends: ['local-config.yaml'],
273
- rules: {
274
- 'operation-4xx-response': 'error',
275
- },
276
- },
277
- },
278
- },
279
- lint: {
280
- extends: ['minimal'],
281
- rules: {
282
- 'operation-2xx-response': 'warn',
283
- },
284
- },
285
- };
286
-
287
- const apisResult = await resolveApis({ rawConfig, configPath });
288
- expect(apisResult['petstore'].lint.rules).toBeDefined();
289
- expect(apisResult['petstore'].lint.rules?.['operation-2xx-response']).toEqual('warn'); // think about prioritize in merge ???
290
- expect(apisResult['petstore'].lint.rules?.['operation-4xx-response']).toEqual('error');
291
- expect(apisResult['petstore'].lint.rules?.['local/operation-id-not-test']).toEqual('error');
292
- //@ts-ignore
293
- expect(apisResult['petstore'].lint.plugins.length).toEqual(2);
294
-
295
- expect(apisResult['petstore'].lint.extendPaths!.map(removeAbsolutePath)).toEqual([
296
- 'resolve-config/.redocly.yaml',
297
- 'resolve-config/local-config.yaml',
298
- 'resolve-config/.redocly.yaml',
299
- ]);
300
- expect(apisResult['petstore'].lint.pluginPaths!.map(removeAbsolutePath)).toEqual([
301
- 'resolve-config/plugin.js',
302
- ]);
303
- });
304
- });
305
-
306
- describe('resolveConfig', () => {
307
- it('should add recommended to top level by default', async () => {
308
- const rawConfig: RawConfig = {
309
- apis: {
310
- petstore: {
311
- root: 'some/path',
312
- lint: {
313
- rules: {
314
- 'operation-4xx-response': 'error',
315
- },
316
- },
317
- },
318
- },
319
- lint: {
320
- rules: {
321
- 'operation-2xx-response': 'warn',
322
- },
323
- },
324
- };
325
-
326
- const { apis } = await resolveConfig(rawConfig, configPath);
327
- //@ts-ignore
328
- expect(apis['petstore'].lint.plugins.length).toEqual(1);
329
- //@ts-ignore
330
- expect(apis['petstore'].lint.plugins[0].id).toEqual('');
331
-
332
- expect(apis['petstore'].lint.extendPaths!.map(removeAbsolutePath)).toEqual([
333
- 'resolve-config/.redocly.yaml',
334
- ]);
335
- expect(apis['petstore'].lint.pluginPaths!.map(removeAbsolutePath)).toEqual([]);
336
-
337
- expect(apis['petstore'].lint.rules).toEqual({
338
- ...(await recommendedLintPreset).rules,
339
- 'operation-2xx-response': 'warn',
340
- 'operation-4xx-response': 'error',
341
- });
342
- });
343
-
344
- it('should not add recommended to top level by default when apis have extends file', async () => {
345
- const rawConfig: RawConfig = {
346
- apis: {
347
- petstore: {
348
- root: 'some/path',
349
- lint: {
350
- extends: ['local-config.yaml'],
351
- rules: {
352
- 'operation-4xx-response': 'error',
353
- },
354
- },
355
- },
356
- },
357
- lint: {
358
- rules: {
359
- 'operation-2xx-response': 'warn',
360
- },
361
- },
362
- };
363
-
364
- const { apis } = await resolveConfig(rawConfig, configPath);
365
- expect(apis['petstore'].lint.rules).toBeDefined();
366
- expect(Object.keys(apis['petstore'].lint.rules || {}).length).toEqual(7);
367
- expect(apis['petstore'].lint.rules?.['operation-2xx-response']).toEqual('warn');
368
- expect(apis['petstore'].lint.rules?.['operation-4xx-response']).toEqual('error');
369
- expect(apis['petstore'].lint.rules?.['operation-description']).toEqual('error'); // from extends file config
370
- //@ts-ignore
371
- expect(apis['petstore'].lint.plugins.length).toEqual(2);
372
-
373
- expect(apis['petstore'].lint.extendPaths!.map(removeAbsolutePath)).toEqual([
374
- 'resolve-config/.redocly.yaml',
375
- 'resolve-config/local-config.yaml',
376
- 'resolve-config/.redocly.yaml',
377
- ]);
378
- expect(apis['petstore'].lint.pluginPaths!.map(removeAbsolutePath)).toEqual([
379
- 'resolve-config/plugin.js',
380
- ]);
381
-
382
- expect(apis['petstore'].lint.recommendedFallback).toBe(false);
383
- });
384
-
385
- it('should ignore minimal from the root and read local file', async () => {
386
- const rawConfig: RawConfig = {
387
- apis: {
388
- petstore: {
389
- root: 'some/path',
390
- lint: {
391
- extends: ['recommended', 'local-config.yaml'],
392
- rules: {
393
- 'operation-4xx-response': 'error',
394
- },
395
- },
396
- },
397
- },
398
- lint: {
399
- extends: ['minimal'],
400
- rules: {
401
- 'operation-2xx-response': 'warn',
402
- },
403
- },
404
- };
405
-
406
- const { apis } = await resolveConfig(rawConfig, configPath);
407
- expect(apis['petstore'].lint.rules).toBeDefined();
408
- expect(apis['petstore'].lint.rules?.['operation-2xx-response']).toEqual('warn');
409
- expect(apis['petstore'].lint.rules?.['operation-4xx-response']).toEqual('error');
410
- expect(apis['petstore'].lint.rules?.['operation-description']).toEqual('error'); // from extends file config
411
- //@ts-ignore
412
- expect(apis['petstore'].lint.plugins.length).toEqual(2);
413
- //@ts-ignore
414
- delete apis['petstore'].lint.plugins;
415
-
416
- expect(apis['petstore'].lint.extendPaths!.map(removeAbsolutePath)).toEqual([
417
- 'resolve-config/.redocly.yaml',
418
- 'resolve-config/local-config.yaml',
419
- 'resolve-config/.redocly.yaml',
420
- ]);
421
- expect(apis['petstore'].lint.pluginPaths!.map(removeAbsolutePath)).toEqual([
422
- 'resolve-config/plugin.js',
423
- ]);
424
-
425
- delete apis['petstore'].lint.extendPaths;
426
- delete apis['petstore'].lint.pluginPaths;
427
- expect(apis['petstore'].lint).toMatchSnapshot();
428
- });
429
- });
@@ -1,244 +0,0 @@
1
- import { Config } from '../config';
2
- import { getMergedConfig } from '../utils';
3
-
4
- const testConfig: Config = {
5
- rawConfig: {
6
- apis: {
7
- 'test@v1': {
8
- root: 'resources/pets.yaml',
9
- lint: { rules: { 'operation-summary': 'warn' } },
10
- },
11
- },
12
- organization: 'redocly-test',
13
- lint: {
14
- rules: { 'operation-summary': 'error', 'no-empty-servers': 'error' },
15
- plugins: [],
16
- },
17
- },
18
- configFile: 'redocly.yaml',
19
- apis: {
20
- 'test@v1': {
21
- root: 'resources/pets.yaml',
22
- lint: { rules: { 'operation-summary': 'warn' } },
23
- },
24
- },
25
- // @ts-ignore
26
- lint: {
27
- rawConfig: {
28
- rules: { 'operation-summary': 'error', 'no-empty-servers': 'error' },
29
- plugins: [],
30
- },
31
- configFile: 'redocly.yaml',
32
- ignore: {},
33
- _usedRules: new Set(),
34
- _usedVersions: new Set(),
35
- recommendedFallback: false,
36
- plugins: [],
37
- doNotResolveExamples: false,
38
- rules: {
39
- oas2: { 'operation-summary': 'error', 'no-empty-servers': 'error' },
40
- oas3_0: { 'operation-summary': 'error', 'no-empty-servers': 'error' },
41
- oas3_1: { 'operation-summary': 'error', 'no-empty-servers': 'error' },
42
- },
43
- preprocessors: { oas2: {}, oas3_0: {}, oas3_1: {} },
44
- decorators: { oas2: {}, oas3_0: {}, oas3_1: {} },
45
- },
46
- 'features.openapi': {},
47
- 'features.mockServer': {},
48
- resolve: { http: { headers: [] } },
49
- organization: 'redocly-test',
50
- };
51
-
52
- describe('getMergedConfig', () => {
53
- it('should get lint defined in "apis" section', () => {
54
- expect(getMergedConfig(testConfig, 'test@v1')).toMatchInlineSnapshot(`
55
- Config {
56
- "apis": Object {
57
- "test@v1": Object {
58
- "lint": Object {
59
- "rules": Object {
60
- "operation-summary": "warn",
61
- },
62
- },
63
- "root": "resources/pets.yaml",
64
- },
65
- },
66
- "configFile": "redocly.yaml",
67
- "features.mockServer": Object {},
68
- "features.openapi": Object {},
69
- "lint": LintConfig {
70
- "_usedRules": Set {},
71
- "_usedVersions": Set {},
72
- "configFile": "redocly.yaml",
73
- "decorators": Object {
74
- "oas2": Object {},
75
- "oas3_0": Object {},
76
- "oas3_1": Object {},
77
- },
78
- "doNotResolveExamples": false,
79
- "extendPaths": Array [],
80
- "ignore": Object {},
81
- "pluginPaths": Array [],
82
- "plugins": Array [],
83
- "preprocessors": Object {
84
- "oas2": Object {},
85
- "oas3_0": Object {},
86
- "oas3_1": Object {},
87
- },
88
- "rawConfig": Object {
89
- "extendPaths": Array [],
90
- "pluginPaths": Array [],
91
- "rules": Object {
92
- "operation-summary": "warn",
93
- },
94
- },
95
- "recommendedFallback": false,
96
- "rules": Object {
97
- "oas2": Object {
98
- "operation-summary": "warn",
99
- },
100
- "oas3_0": Object {
101
- "operation-summary": "warn",
102
- },
103
- "oas3_1": Object {
104
- "operation-summary": "warn",
105
- },
106
- },
107
- },
108
- "organization": "redocly-test",
109
- "rawConfig": Object {
110
- "apis": Object {
111
- "test@v1": Object {
112
- "lint": Object {
113
- "rules": Object {
114
- "operation-summary": "warn",
115
- },
116
- },
117
- "root": "resources/pets.yaml",
118
- },
119
- },
120
- "features.mockServer": Object {},
121
- "features.openapi": Object {},
122
- "lint": Object {
123
- "extendPaths": Array [],
124
- "pluginPaths": Array [],
125
- "rules": Object {
126
- "operation-summary": "warn",
127
- },
128
- },
129
- "organization": "redocly-test",
130
- },
131
- "region": undefined,
132
- "resolve": Object {
133
- "http": Object {
134
- "customFetch": undefined,
135
- "headers": Array [],
136
- },
137
- },
138
- }
139
- `);
140
- });
141
- it('should take into account a config file', () => {
142
- const result = getMergedConfig(testConfig, 'test@v1');
143
- expect(result.configFile).toEqual('redocly.yaml');
144
- expect(result.lint.configFile).toEqual('redocly.yaml');
145
- });
146
- it('should return the same config when there is no alias provided', () => {
147
- expect(getMergedConfig(testConfig)).toEqual(testConfig);
148
- });
149
- it('should handle wrong alias - return the same lint, empty features', () => {
150
- expect(getMergedConfig(testConfig, 'wrong-alias')).toMatchInlineSnapshot(`
151
- Config {
152
- "apis": Object {
153
- "test@v1": Object {
154
- "lint": Object {
155
- "rules": Object {
156
- "operation-summary": "warn",
157
- },
158
- },
159
- "root": "resources/pets.yaml",
160
- },
161
- },
162
- "configFile": "redocly.yaml",
163
- "features.mockServer": Object {},
164
- "features.openapi": Object {},
165
- "lint": LintConfig {
166
- "_usedRules": Set {},
167
- "_usedVersions": Set {},
168
- "configFile": "redocly.yaml",
169
- "decorators": Object {
170
- "oas2": Object {},
171
- "oas3_0": Object {},
172
- "oas3_1": Object {},
173
- },
174
- "doNotResolveExamples": false,
175
- "extendPaths": Array [],
176
- "ignore": Object {},
177
- "pluginPaths": Array [],
178
- "plugins": Array [],
179
- "preprocessors": Object {
180
- "oas2": Object {},
181
- "oas3_0": Object {},
182
- "oas3_1": Object {},
183
- },
184
- "rawConfig": Object {
185
- "extendPaths": Array [],
186
- "pluginPaths": Array [],
187
- "plugins": Array [],
188
- "rules": Object {
189
- "no-empty-servers": "error",
190
- "operation-summary": "error",
191
- },
192
- },
193
- "recommendedFallback": false,
194
- "rules": Object {
195
- "oas2": Object {
196
- "no-empty-servers": "error",
197
- "operation-summary": "error",
198
- },
199
- "oas3_0": Object {
200
- "no-empty-servers": "error",
201
- "operation-summary": "error",
202
- },
203
- "oas3_1": Object {
204
- "no-empty-servers": "error",
205
- "operation-summary": "error",
206
- },
207
- },
208
- },
209
- "organization": "redocly-test",
210
- "rawConfig": Object {
211
- "apis": Object {
212
- "test@v1": Object {
213
- "lint": Object {
214
- "rules": Object {
215
- "operation-summary": "warn",
216
- },
217
- },
218
- "root": "resources/pets.yaml",
219
- },
220
- },
221
- "features.mockServer": Object {},
222
- "features.openapi": Object {},
223
- "lint": Object {
224
- "extendPaths": Array [],
225
- "pluginPaths": Array [],
226
- "plugins": Array [],
227
- "rules": Object {
228
- "no-empty-servers": "error",
229
- "operation-summary": "error",
230
- },
231
- },
232
- "organization": "redocly-test",
233
- },
234
- "region": undefined,
235
- "resolve": Object {
236
- "http": Object {
237
- "customFetch": undefined,
238
- "headers": Array [],
239
- },
240
- },
241
- }
242
- `);
243
- });
244
- });
@@ -1,3 +0,0 @@
1
- lint:
2
- plugins:
3
- - './plugin.js'