@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.
- package/README.md +6 -6
- package/lib/benchmark/benches/lint-with-top-level-rule-report.bench.js +0 -1
- package/lib/benchmark/benches/recommended-oas3.bench.js +1 -1
- package/lib/benchmark/benches/resolve-with-no-external.bench.js +1 -1
- package/lib/benchmark/utils.d.ts +2 -2
- package/lib/benchmark/utils.js +2 -2
- package/lib/bundle.d.ts +10 -15
- package/lib/bundle.js +32 -12
- package/lib/config/all.d.ts +2 -2
- package/lib/config/all.js +16 -6
- package/lib/config/builtIn.d.ts +2 -2
- package/lib/config/builtIn.js +2 -2
- package/lib/config/config-resolvers.d.ts +5 -5
- package/lib/config/config-resolvers.js +121 -66
- package/lib/config/config.d.ts +12 -18
- package/lib/config/config.js +42 -26
- package/lib/config/load.d.ts +16 -3
- package/lib/config/load.js +36 -14
- package/lib/config/minimal.d.ts +2 -2
- package/lib/config/minimal.js +10 -6
- package/lib/config/recommended.d.ts +2 -2
- package/lib/config/recommended.js +10 -6
- package/lib/config/rules.d.ts +7 -4
- package/lib/config/rules.js +5 -4
- package/lib/config/types.d.ts +72 -23
- package/lib/config/types.js +13 -0
- package/lib/config/utils.d.ts +6 -5
- package/lib/config/utils.js +110 -32
- package/lib/decorators/common/filters/filter-helper.d.ts +3 -0
- package/lib/decorators/common/filters/filter-helper.js +67 -0
- package/lib/decorators/common/filters/filter-in.d.ts +2 -0
- package/lib/decorators/common/filters/filter-in.js +17 -0
- package/lib/decorators/common/filters/filter-out.d.ts +2 -0
- package/lib/decorators/common/filters/filter-out.js +17 -0
- package/lib/decorators/common/info-override.d.ts +2 -0
- package/lib/decorators/common/info-override.js +28 -0
- package/lib/decorators/common/media-type-examples-override.d.ts +2 -0
- package/lib/decorators/common/media-type-examples-override.js +53 -0
- package/lib/decorators/common/registry-dependencies.js +2 -2
- package/lib/decorators/common/remove-x-internal.js +2 -2
- package/lib/decorators/oas2/index.d.ts +3 -0
- package/lib/decorators/oas2/index.js +7 -1
- package/lib/decorators/oas3/index.d.ts +4 -0
- package/lib/decorators/oas3/index.js +9 -1
- package/lib/env.d.ts +3 -0
- package/lib/env.js +8 -0
- package/lib/format/codeframes.js +16 -10
- package/lib/format/format.d.ts +1 -1
- package/lib/format/format.js +64 -32
- package/lib/index.d.ts +6 -6
- package/lib/index.js +7 -2
- package/lib/js-yaml/index.js +2 -6
- package/lib/lint.d.ts +4 -2
- package/lib/lint.js +36 -11
- package/lib/logger.d.ts +10 -0
- package/lib/logger.js +31 -0
- package/lib/output.d.ts +3 -0
- package/lib/output.js +9 -0
- package/lib/redocly/index.js +10 -9
- package/lib/redocly/registry-api-types.d.ts +28 -28
- package/lib/redocly/registry-api.d.ts +3 -3
- package/lib/redocly/registry-api.js +10 -2
- package/lib/ref-utils.d.ts +1 -0
- package/lib/ref-utils.js +7 -2
- package/lib/resolve.d.ts +1 -1
- package/lib/resolve.js +33 -3
- package/lib/rules/ajv.d.ts +2 -2
- package/lib/rules/ajv.js +12 -12
- package/lib/rules/common/assertions/asserts.d.ts +29 -4
- package/lib/rules/common/assertions/asserts.js +227 -97
- package/lib/rules/common/assertions/index.d.ts +27 -2
- package/lib/rules/common/assertions/index.js +9 -37
- package/lib/rules/common/assertions/utils.d.ts +16 -8
- package/lib/rules/common/assertions/utils.js +160 -76
- package/lib/rules/common/info-license-url.d.ts +1 -1
- package/lib/rules/common/info-license-url.js +5 -10
- package/lib/rules/common/info-license.d.ts +2 -0
- package/lib/rules/common/info-license.js +17 -0
- package/lib/rules/common/no-ambiguous-paths.js +1 -1
- package/lib/rules/common/no-enum-type-mismatch.js +1 -3
- package/lib/rules/common/no-identical-paths.js +4 -4
- package/lib/rules/common/no-invalid-parameter-examples.js +3 -3
- package/lib/rules/common/no-invalid-schema-examples.js +3 -3
- package/lib/rules/common/operation-2xx-response.js +15 -9
- package/lib/rules/common/operation-4xx-response.js +15 -9
- package/lib/rules/common/operation-operationId.js +2 -2
- package/lib/rules/common/operation-tag-defined.js +1 -1
- package/lib/rules/common/path-not-include-query.js +2 -2
- package/lib/rules/common/path-params-defined.js +7 -2
- package/lib/rules/common/paths-kebab-case.js +4 -1
- package/lib/rules/common/required-string-property-missing-min-length.d.ts +2 -0
- package/lib/rules/common/required-string-property-missing-min-length.js +37 -0
- package/lib/rules/common/response-contains-header.js +2 -2
- package/lib/rules/common/scalar-property-missing-example.js +2 -1
- package/lib/rules/common/security-defined.d.ts +2 -0
- package/lib/rules/common/{operation-security-defined.js → security-defined.js} +25 -6
- package/lib/rules/common/spec-strict-refs.d.ts +2 -0
- package/lib/rules/common/spec-strict-refs.js +30 -0
- package/lib/rules/common/spec.js +41 -18
- package/lib/rules/common/tags-alphabetical.js +1 -1
- package/lib/rules/oas2/index.d.ts +3 -2
- package/lib/rules/oas2/index.js +10 -8
- package/lib/rules/oas2/remove-unused-components.js +6 -6
- package/lib/rules/oas2/request-mime-type.d.ts +1 -1
- package/lib/rules/oas2/request-mime-type.js +1 -1
- package/lib/rules/oas2/response-mime-type.d.ts +1 -1
- package/lib/rules/oas2/response-mime-type.js +1 -1
- package/lib/rules/oas3/component-name-unique.d.ts +2 -0
- package/lib/rules/oas3/component-name-unique.js +124 -0
- package/lib/rules/oas3/index.js +18 -10
- package/lib/rules/oas3/no-empty-servers.js +2 -2
- package/lib/rules/oas3/no-invalid-media-type-examples.js +2 -2
- package/lib/rules/oas3/no-server-variables-empty-enum.d.ts +2 -0
- package/lib/rules/oas3/{no-servers-empty-enum.js → no-server-variables-empty-enum.js} +5 -5
- package/lib/rules/oas3/no-unused-components.js +2 -2
- package/lib/rules/oas3/operation-4xx-problem-details-rfc7807.d.ts +5 -0
- package/lib/rules/oas3/operation-4xx-problem-details-rfc7807.js +36 -0
- package/lib/rules/oas3/remove-unused-components.js +6 -6
- package/lib/rules/oas3/request-mime-type.d.ts +1 -1
- package/lib/rules/oas3/request-mime-type.js +1 -1
- package/lib/rules/oas3/response-mime-type.d.ts +1 -1
- package/lib/rules/oas3/response-mime-type.js +1 -1
- package/lib/rules/oas3/spec-components-invalid-map-name.d.ts +2 -0
- package/lib/rules/oas3/spec-components-invalid-map-name.js +62 -0
- package/lib/rules/other/stats.d.ts +2 -2
- package/lib/rules/other/stats.js +45 -16
- package/lib/rules/utils.d.ts +5 -2
- package/lib/rules/utils.js +54 -6
- package/lib/types/config-external-schemas.d.ts +2193 -0
- package/lib/types/config-external-schemas.js +805 -0
- package/lib/types/index.d.ts +3 -2
- package/lib/types/index.js +9 -1
- package/lib/types/oas2.js +91 -15
- package/lib/types/oas3.js +125 -46
- package/lib/types/oas3_1.js +23 -19
- package/lib/types/redocly-yaml.js +406 -60
- package/lib/utils.d.ts +15 -4
- package/lib/utils.js +72 -8
- package/lib/visitors.d.ts +20 -16
- package/lib/visitors.js +28 -3
- package/lib/walk.d.ts +11 -19
- package/lib/walk.js +74 -53
- package/package.json +5 -6
- package/__tests__/utils.ts +0 -86
- package/lib/rules/common/info-description.d.ts +0 -2
- package/lib/rules/common/info-description.js +0 -12
- package/lib/rules/common/license-url.d.ts +0 -2
- package/lib/rules/common/license-url.js +0 -12
- package/lib/rules/common/operation-security-defined.d.ts +0 -2
- package/lib/rules/oas3/no-servers-empty-enum.d.ts +0 -2
- package/src/__tests__/__snapshots__/bundle.test.ts.snap +0 -255
- package/src/__tests__/bundle.test.ts +0 -156
- package/src/__tests__/codeframes.test.ts +0 -531
- package/src/__tests__/fixtures/extension.js +0 -24
- package/src/__tests__/fixtures/refs/definitions.yaml +0 -3
- package/src/__tests__/fixtures/refs/examples.yaml +0 -8
- package/src/__tests__/fixtures/refs/external-request-body.yaml +0 -13
- package/src/__tests__/fixtures/refs/externalref.yaml +0 -35
- package/src/__tests__/fixtures/refs/hosted.yaml +0 -35
- package/src/__tests__/fixtures/refs/openapi-with-external-refs-conflicting-names.yaml +0 -21
- package/src/__tests__/fixtures/refs/openapi-with-external-refs.yaml +0 -33
- package/src/__tests__/fixtures/refs/openapi-with-url-refs.yaml +0 -18
- package/src/__tests__/fixtures/refs/param-b.yaml +0 -1
- package/src/__tests__/fixtures/refs/param-c.yaml +0 -1
- package/src/__tests__/fixtures/refs/rename.yaml +0 -1
- package/src/__tests__/fixtures/refs/requestBody.yaml +0 -9
- package/src/__tests__/fixtures/refs/schema-a.yaml +0 -1
- package/src/__tests__/fixtures/refs/simple.yaml +0 -1
- package/src/__tests__/fixtures/refs/vendor.schema.yaml +0 -20
- package/src/__tests__/fixtures/resolve/External.yaml +0 -10
- package/src/__tests__/fixtures/resolve/External2.yaml +0 -4
- package/src/__tests__/fixtures/resolve/description.md +0 -3
- package/src/__tests__/fixtures/resolve/externalInfo.yaml +0 -4
- package/src/__tests__/fixtures/resolve/externalLicense.yaml +0 -1
- package/src/__tests__/fixtures/resolve/openapi-with-back.yaml +0 -13
- package/src/__tests__/fixtures/resolve/openapi-with-md-description.yaml +0 -5
- package/src/__tests__/fixtures/resolve/openapi.yaml +0 -28
- package/src/__tests__/fixtures/resolve/schemas/type-a.yaml +0 -10
- package/src/__tests__/fixtures/resolve/schemas/type-b.yaml +0 -6
- package/src/__tests__/fixtures/resolve/transitive/a.yaml +0 -1
- package/src/__tests__/fixtures/resolve/transitive/components.yaml +0 -5
- package/src/__tests__/fixtures/resolve/transitive/schemas.yaml +0 -3
- package/src/__tests__/js-yaml.test.ts +0 -71
- package/src/__tests__/lint.test.ts +0 -195
- package/src/__tests__/login.test.ts +0 -17
- package/src/__tests__/normalizeVisitors.test.ts +0 -151
- package/src/__tests__/ref-utils.test.ts +0 -120
- package/src/__tests__/resolve-http.test.ts +0 -77
- package/src/__tests__/resolve.test.ts +0 -405
- package/src/__tests__/utils.test.ts +0 -85
- package/src/__tests__/walk.test.ts +0 -1485
- package/src/benchmark/benches/lint-with-many-rules.bench.ts +0 -35
- package/src/benchmark/benches/lint-with-nested-rule.bench.ts +0 -39
- package/src/benchmark/benches/lint-with-no-rules.bench.ts +0 -20
- package/src/benchmark/benches/lint-with-top-level-rule-report.bench.ts +0 -36
- package/src/benchmark/benches/lint-with-top-level-rule.bench.ts +0 -32
- package/src/benchmark/benches/rebilly.yaml +0 -32267
- package/src/benchmark/benches/recommended-oas3.bench.ts +0 -22
- package/src/benchmark/benches/resolve-with-no-external.bench.ts +0 -23
- package/src/benchmark/benchmark.js +0 -307
- package/src/benchmark/colors.js +0 -29
- package/src/benchmark/fork.js +0 -83
- package/src/benchmark/utils.ts +0 -36
- package/src/bundle.ts +0 -386
- package/src/config/__tests__/__snapshots__/config-resolvers.test.ts.snap +0 -157
- package/src/config/__tests__/config-resolvers.test.ts +0 -429
- package/src/config/__tests__/config.test.ts +0 -244
- package/src/config/__tests__/fixtures/plugin-config.yaml +0 -3
- package/src/config/__tests__/fixtures/plugin.js +0 -56
- package/src/config/__tests__/fixtures/resolve-config/api/nested-config.yaml +0 -12
- package/src/config/__tests__/fixtures/resolve-config/api/plugin.js +0 -67
- package/src/config/__tests__/fixtures/resolve-config/local-config-with-circular.yaml +0 -8
- package/src/config/__tests__/fixtures/resolve-config/local-config-with-file.yaml +0 -19
- package/src/config/__tests__/fixtures/resolve-config/local-config.yaml +0 -10
- package/src/config/__tests__/fixtures/resolve-config/plugin.js +0 -66
- package/src/config/__tests__/fixtures/resolve-remote-configs/nested-remote-config.yaml +0 -4
- package/src/config/__tests__/fixtures/resolve-remote-configs/remote-config.yaml +0 -5
- package/src/config/__tests__/load.test.ts +0 -83
- package/src/config/__tests__/resolve-plugins.test.ts +0 -27
- package/src/config/all.ts +0 -66
- package/src/config/builtIn.ts +0 -37
- package/src/config/config-resolvers.ts +0 -359
- package/src/config/config.ts +0 -312
- package/src/config/index.ts +0 -7
- package/src/config/load.ts +0 -84
- package/src/config/minimal.ts +0 -58
- package/src/config/recommended.ts +0 -58
- package/src/config/rules.ts +0 -46
- package/src/config/types.ts +0 -168
- package/src/config/utils.ts +0 -208
- package/src/decorators/__tests__/remove-x-internal.test.ts +0 -316
- package/src/decorators/common/info-description-override.ts +0 -24
- package/src/decorators/common/operation-description-override.ts +0 -30
- package/src/decorators/common/registry-dependencies.ts +0 -25
- package/src/decorators/common/remove-x-internal.ts +0 -59
- package/src/decorators/common/tag-description-override.ts +0 -25
- package/src/decorators/oas2/index.ts +0 -14
- package/src/decorators/oas3/index.ts +0 -14
- package/src/format/codeframes.ts +0 -210
- package/src/format/format.ts +0 -339
- package/src/index.ts +0 -68
- package/src/js-yaml/index.ts +0 -18
- package/src/lint.ts +0 -125
- package/src/oas-types.ts +0 -62
- package/src/redocly/__tests__/redocly-client.test.ts +0 -140
- package/src/redocly/index.ts +0 -182
- package/src/redocly/redocly-client-types.ts +0 -10
- package/src/redocly/registry-api-types.ts +0 -32
- package/src/redocly/registry-api.ts +0 -134
- package/src/ref-utils.ts +0 -80
- package/src/resolve.ts +0 -378
- package/src/rules/__tests__/fixtures/invalid-yaml.yaml +0 -1
- package/src/rules/__tests__/fixtures/ref.yaml +0 -1
- package/src/rules/__tests__/no-unresolved-refs.test.ts +0 -168
- package/src/rules/ajv.ts +0 -103
- package/src/rules/common/__tests__/info-description.test.ts +0 -102
- package/src/rules/common/__tests__/info-license.test.ts +0 -62
- package/src/rules/common/__tests__/license-url.test.ts +0 -63
- package/src/rules/common/__tests__/no-ambiguous-paths.test.ts +0 -96
- package/src/rules/common/__tests__/no-enum-type-mismatch.test.ts +0 -209
- package/src/rules/common/__tests__/no-identical-paths.test.ts +0 -58
- package/src/rules/common/__tests__/no-path-trailing-slash.test.ts +0 -85
- package/src/rules/common/__tests__/operation-2xx-response.test.ts +0 -91
- package/src/rules/common/__tests__/operation-4xx-response.test.ts +0 -107
- package/src/rules/common/__tests__/operation-operationId-unique.test.ts +0 -76
- package/src/rules/common/__tests__/operation-operationId-url-safe.test.ts +0 -45
- package/src/rules/common/__tests__/operation-parameters-unique.test.ts +0 -167
- package/src/rules/common/__tests__/operation-security-defined.test.ts +0 -69
- package/src/rules/common/__tests__/operation-singular-tag.test.ts +0 -72
- package/src/rules/common/__tests__/path-http-verbs-order.test.ts +0 -95
- package/src/rules/common/__tests__/path-not-include-query.test.ts +0 -64
- package/src/rules/common/__tests__/path-params-defined.test.ts +0 -133
- package/src/rules/common/__tests__/paths-kebab-case.test.ts +0 -108
- package/src/rules/common/__tests__/scalar-property-missing-example.test.ts +0 -207
- package/src/rules/common/__tests__/spec.test.ts +0 -62
- package/src/rules/common/__tests__/tag-description.test.ts +0 -65
- package/src/rules/common/__tests__/tags-alphabetical.test.ts +0 -64
- package/src/rules/common/assertions/__tests__/asserts.test.ts +0 -231
- package/src/rules/common/assertions/__tests__/index.test.ts +0 -65
- package/src/rules/common/assertions/__tests__/utils.test.ts +0 -89
- package/src/rules/common/assertions/asserts.ts +0 -137
- package/src/rules/common/assertions/index.ts +0 -75
- package/src/rules/common/assertions/utils.ts +0 -167
- package/src/rules/common/info-contact.ts +0 -15
- package/src/rules/common/info-description.ts +0 -10
- package/src/rules/common/info-license-url.ts +0 -15
- package/src/rules/common/license-url.ts +0 -10
- package/src/rules/common/no-ambiguous-paths.ts +0 -50
- package/src/rules/common/no-enum-type-mismatch.ts +0 -49
- package/src/rules/common/no-http-verbs-in-paths.ts +0 -36
- package/src/rules/common/no-identical-paths.ts +0 -24
- package/src/rules/common/no-invalid-parameter-examples.ts +0 -36
- package/src/rules/common/no-invalid-schema-examples.ts +0 -27
- package/src/rules/common/no-path-trailing-slash.ts +0 -15
- package/src/rules/common/operation-2xx-response.ts +0 -16
- package/src/rules/common/operation-4xx-response.ts +0 -17
- package/src/rules/common/operation-description.ts +0 -13
- package/src/rules/common/operation-operationId-unique.ts +0 -21
- package/src/rules/common/operation-operationId-url-safe.ts +0 -19
- package/src/rules/common/operation-operationId.ts +0 -17
- package/src/rules/common/operation-parameters-unique.ts +0 -48
- package/src/rules/common/operation-security-defined.ts +0 -45
- package/src/rules/common/operation-singular-tag.ts +0 -17
- package/src/rules/common/operation-summary.ts +0 -13
- package/src/rules/common/operation-tag-defined.ts +0 -26
- package/src/rules/common/parameter-description.ts +0 -22
- package/src/rules/common/path-declaration-must-exist.ts +0 -15
- package/src/rules/common/path-excludes-patterns.ts +0 -23
- package/src/rules/common/path-http-verbs-order.ts +0 -30
- package/src/rules/common/path-not-include-query.ts +0 -17
- package/src/rules/common/path-params-defined.ts +0 -58
- package/src/rules/common/path-segment-plural.ts +0 -31
- package/src/rules/common/paths-kebab-case.ts +0 -16
- package/src/rules/common/response-contains-header.ts +0 -30
- package/src/rules/common/scalar-property-missing-example.ts +0 -55
- package/src/rules/common/spec.ts +0 -143
- package/src/rules/common/tag-description.ts +0 -10
- package/src/rules/common/tags-alphabetical.ts +0 -20
- package/src/rules/no-unresolved-refs.ts +0 -51
- package/src/rules/oas2/__tests__/boolean-parameter-prefixes.test.ts +0 -110
- package/src/rules/oas2/__tests__/response-contains-header.test.ts +0 -174
- package/src/rules/oas2/__tests__/response-contains-property.test.ts +0 -155
- package/src/rules/oas2/__tests__/spec/fixtures/description.md +0 -1
- package/src/rules/oas2/__tests__/spec/info.test.ts +0 -355
- package/src/rules/oas2/__tests__/spec/operation.test.ts +0 -123
- package/src/rules/oas2/__tests__/spec/paths.test.ts +0 -245
- package/src/rules/oas2/__tests__/spec/referenceableScalars.test.ts +0 -31
- package/src/rules/oas2/__tests__/spec/utils.ts +0 -32
- package/src/rules/oas2/boolean-parameter-prefixes.ts +0 -26
- package/src/rules/oas2/index.ts +0 -89
- package/src/rules/oas2/remove-unused-components.ts +0 -76
- package/src/rules/oas2/request-mime-type.ts +0 -17
- package/src/rules/oas2/response-contains-property.ts +0 -36
- package/src/rules/oas2/response-mime-type.ts +0 -17
- package/src/rules/oas3/__tests__/boolean-parameter-prefixes.test.ts +0 -111
- package/src/rules/oas3/__tests__/fixtures/common.yaml +0 -11
- package/src/rules/oas3/__tests__/no-empty-enum-servers.com.test.ts +0 -205
- package/src/rules/oas3/__tests__/no-example-value-and-externalValue.test.ts +0 -65
- package/src/rules/oas3/__tests__/no-invalid-media-type-examples.test.ts +0 -392
- package/src/rules/oas3/__tests__/no-server-example.com.test.ts +0 -60
- package/src/rules/oas3/__tests__/no-server-trailing-slash.test.ts +0 -79
- package/src/rules/oas3/__tests__/no-unused-components.test.ts +0 -131
- package/src/rules/oas3/__tests__/response-contains-header.test.ts +0 -273
- package/src/rules/oas3/__tests__/response-contains-property.test.ts +0 -403
- package/src/rules/oas3/__tests__/spec/callbacks.test.ts +0 -41
- package/src/rules/oas3/__tests__/spec/fixtures/description.md +0 -1
- package/src/rules/oas3/__tests__/spec/info.test.ts +0 -391
- package/src/rules/oas3/__tests__/spec/operation.test.ts +0 -253
- package/src/rules/oas3/__tests__/spec/paths.test.ts +0 -284
- package/src/rules/oas3/__tests__/spec/referenceableScalars.test.ts +0 -77
- package/src/rules/oas3/__tests__/spec/servers.test.ts +0 -499
- package/src/rules/oas3/__tests__/spec/spec.test.ts +0 -288
- package/src/rules/oas3/__tests__/spec/utils.ts +0 -32
- package/src/rules/oas3/boolean-parameter-prefixes.ts +0 -28
- package/src/rules/oas3/index.ts +0 -105
- package/src/rules/oas3/no-empty-servers.ts +0 -22
- package/src/rules/oas3/no-example-value-and-externalValue.ts +0 -14
- package/src/rules/oas3/no-invalid-media-type-examples.ts +0 -41
- package/src/rules/oas3/no-server-example.com.ts +0 -14
- package/src/rules/oas3/no-server-trailing-slash.ts +0 -15
- package/src/rules/oas3/no-servers-empty-enum.ts +0 -67
- package/src/rules/oas3/no-undefined-server-variable.ts +0 -30
- package/src/rules/oas3/no-unused-components.ts +0 -75
- package/src/rules/oas3/remove-unused-components.ts +0 -84
- package/src/rules/oas3/request-mime-type.ts +0 -31
- package/src/rules/oas3/response-contains-property.ts +0 -38
- package/src/rules/oas3/response-mime-type.ts +0 -31
- package/src/rules/other/stats.ts +0 -44
- package/src/rules/utils.ts +0 -123
- package/src/types/index.ts +0 -138
- package/src/types/oas2.ts +0 -397
- package/src/types/oas3.ts +0 -515
- package/src/types/oas3_1.ts +0 -253
- package/src/types/redocly-yaml.ts +0 -647
- package/src/typings/common.ts +0 -9
- package/src/typings/openapi.ts +0 -298
- package/src/typings/swagger.ts +0 -236
- package/src/utils.ts +0 -193
- package/src/visitors.ts +0 -448
- package/src/walk.ts +0 -416
- package/tsconfig.json +0 -8
- package/tsconfig.tsbuildinfo +0 -1
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
import { readFileSync } from 'fs';
|
|
2
|
-
import { join as pathJoin, resolve as pathResolve } from 'path';
|
|
3
|
-
import { lintDocument } from '../../lint';
|
|
4
|
-
import { LintConfig, defaultPlugin, resolvePreset } from '../../config';
|
|
5
|
-
import { BaseResolver } from '../../resolve';
|
|
6
|
-
import { parseYamlToDocument } from '../utils';
|
|
7
|
-
|
|
8
|
-
export const name = 'Validate with recommended rules';
|
|
9
|
-
export const count = 10;
|
|
10
|
-
const rebillyDefinitionRef = pathResolve(pathJoin(__dirname, 'rebilly.yaml'));
|
|
11
|
-
const rebillyDocument = parseYamlToDocument(
|
|
12
|
-
readFileSync(rebillyDefinitionRef, 'utf-8'),
|
|
13
|
-
rebillyDefinitionRef,
|
|
14
|
-
);
|
|
15
|
-
|
|
16
|
-
export function measureAsync() {
|
|
17
|
-
return lintDocument({
|
|
18
|
-
externalRefResolver: new BaseResolver(),
|
|
19
|
-
document: rebillyDocument,
|
|
20
|
-
config: new LintConfig(resolvePreset('recommended', [defaultPlugin])),
|
|
21
|
-
});
|
|
22
|
-
}
|
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
import * as path from 'path';
|
|
2
|
-
import { readFileSync } from 'fs';
|
|
3
|
-
import { resolveDocument, BaseResolver } from '../../resolve';
|
|
4
|
-
import { parseYamlToDocument } from '../utils';
|
|
5
|
-
import { Oas3Types } from '../../types/oas3';
|
|
6
|
-
import { normalizeTypes } from '../../types';
|
|
7
|
-
|
|
8
|
-
export const name = 'Resolve with no external refs';
|
|
9
|
-
export const count = 10;
|
|
10
|
-
const rebillyDefinitionRef = path.resolve(path.join(__dirname, 'rebilly.yaml'));
|
|
11
|
-
const rebillyDocument = parseYamlToDocument(
|
|
12
|
-
readFileSync(rebillyDefinitionRef, 'utf-8'),
|
|
13
|
-
rebillyDefinitionRef,
|
|
14
|
-
);
|
|
15
|
-
const externalRefResolver = new BaseResolver();
|
|
16
|
-
|
|
17
|
-
export function measureAsync() {
|
|
18
|
-
return resolveDocument({
|
|
19
|
-
rootDocument: rebillyDocument,
|
|
20
|
-
externalRefResolver,
|
|
21
|
-
rootType: normalizeTypes(Oas3Types).DefinitionRoot,
|
|
22
|
-
});
|
|
23
|
-
}
|
|
@@ -1,307 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
const os = require('os');
|
|
3
|
-
const fs = require('fs');
|
|
4
|
-
const path = require('path');
|
|
5
|
-
const assert = require('assert');
|
|
6
|
-
const { execSync } = require('child_process');
|
|
7
|
-
const { red, green, yellow, cyan, grey } = require('./colors');
|
|
8
|
-
const { sampleModule } = require('./fork');
|
|
9
|
-
const NS_PER_SEC = 1e9;
|
|
10
|
-
const LOCAL = 'local';
|
|
11
|
-
|
|
12
|
-
// The maximum time in seconds a benchmark is allowed to run before finishing.
|
|
13
|
-
const maxTime = 10;
|
|
14
|
-
// The minimum sample size required to perform statistical analysis.
|
|
15
|
-
const minSamples = 5;
|
|
16
|
-
|
|
17
|
-
function LOCAL_DIR(...paths) {
|
|
18
|
-
return path.join(__dirname, '..', ...paths);
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
// Build a benchmark-friendly environment for the given revision
|
|
22
|
-
// and returns path to its 'lib' directory.
|
|
23
|
-
function prepareRevision(revision) {
|
|
24
|
-
console.log(`🍳 Preparing ${revision}...`);
|
|
25
|
-
|
|
26
|
-
if (revision === LOCAL) {
|
|
27
|
-
return tscBuild(path.join(LOCAL_DIR(), '../../..'));
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
// Returns the complete git hash for a given git revision reference.
|
|
31
|
-
const hash = exec(`git rev-parse "${revision}"`);
|
|
32
|
-
const dir = path.join(os.tmpdir(), 'redocly-cli-benchmark', hash);
|
|
33
|
-
if (fs.existsSync(dir)) {
|
|
34
|
-
fs.rmdirSync(dir, { recursive: true});
|
|
35
|
-
}
|
|
36
|
-
fs.mkdirSync(dir, { recursive: true });
|
|
37
|
-
|
|
38
|
-
exec(`git archive "${hash}" | tar -xC "${dir}"`);
|
|
39
|
-
exec('npm ci', { cwd: dir });
|
|
40
|
-
const to = path.join(dir, 'packages/core/src/benchmark/benches');
|
|
41
|
-
exec(`rm -rf ${to}`);
|
|
42
|
-
exec(`cp -R ${LOCAL_DIR('benchmark/benches')} ${to}`);
|
|
43
|
-
return tscBuild(dir);
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
function tscBuild(dir) {
|
|
47
|
-
const oldCwd = process.cwd();
|
|
48
|
-
process.chdir(dir);
|
|
49
|
-
execSync('npm run compile', { stdio: 'inherit' });
|
|
50
|
-
exec(
|
|
51
|
-
`cp ${path.join(dir, 'packages/core/src/benchmark/benches/*.yaml')} ${path.join(dir, 'packages/core/lib/benchmark/benches/')}`,
|
|
52
|
-
);
|
|
53
|
-
process.chdir(oldCwd);
|
|
54
|
-
return path.join(dir, 'packages/core/lib/benchmark/benches');
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
async function collectSamples(modulePath) {
|
|
58
|
-
const samples = [];
|
|
59
|
-
|
|
60
|
-
// If time permits, increase sample size to reduce the margin of error.
|
|
61
|
-
const start = Date.now();
|
|
62
|
-
while (samples.length < minSamples || (Date.now() - start) / 1e3 < maxTime) {
|
|
63
|
-
const { clocked, memUsed } = await sampleModule(modulePath);
|
|
64
|
-
assert(clocked > 0);
|
|
65
|
-
assert(memUsed > 0);
|
|
66
|
-
samples.push({ clocked, memUsed });
|
|
67
|
-
}
|
|
68
|
-
return samples;
|
|
69
|
-
}
|
|
70
|
-
|
|
71
|
-
// T-Distribution two-tailed critical values for 95% confidence.
|
|
72
|
-
// See http://www.itl.nist.gov/div898/handbook/eda/section3/eda3672.htm.
|
|
73
|
-
const tTable = /* prettier-ignore */ {
|
|
74
|
-
'1': 12.706, '2': 4.303, '3': 3.182, '4': 2.776, '5': 2.571, '6': 2.447,
|
|
75
|
-
'7': 2.365, '8': 2.306, '9': 2.262, '10': 2.228, '11': 2.201, '12': 2.179,
|
|
76
|
-
'13': 2.16, '14': 2.145, '15': 2.131, '16': 2.12, '17': 2.11, '18': 2.101,
|
|
77
|
-
'19': 2.093, '20': 2.086, '21': 2.08, '22': 2.074, '23': 2.069, '24': 2.064,
|
|
78
|
-
'25': 2.06, '26': 2.056, '27': 2.052, '28': 2.048, '29': 2.045, '30': 2.042,
|
|
79
|
-
infinity: 1.96,
|
|
80
|
-
};
|
|
81
|
-
|
|
82
|
-
// Computes stats on benchmark results.
|
|
83
|
-
function computeStats(samples) {
|
|
84
|
-
assert(samples.length > 1);
|
|
85
|
-
|
|
86
|
-
// Compute the sample mean (estimate of the population mean).
|
|
87
|
-
let mean = 0;
|
|
88
|
-
let meanMemUsed = 0;
|
|
89
|
-
for (const { clocked, memUsed } of samples) {
|
|
90
|
-
mean += clocked;
|
|
91
|
-
meanMemUsed += memUsed;
|
|
92
|
-
}
|
|
93
|
-
mean /= samples.length;
|
|
94
|
-
meanMemUsed /= samples.length;
|
|
95
|
-
|
|
96
|
-
// Compute the sample variance (estimate of the population variance).
|
|
97
|
-
let variance = 0;
|
|
98
|
-
for (const { clocked } of samples) {
|
|
99
|
-
variance += (clocked - mean) ** 2;
|
|
100
|
-
}
|
|
101
|
-
variance /= samples.length - 1;
|
|
102
|
-
|
|
103
|
-
// Compute the sample standard deviation (estimate of the population standard deviation).
|
|
104
|
-
const sd = Math.sqrt(variance);
|
|
105
|
-
|
|
106
|
-
// Compute the standard error of the mean (a.k.a. the standard deviation of the sampling distribution of the sample mean).
|
|
107
|
-
const sem = sd / Math.sqrt(samples.length);
|
|
108
|
-
|
|
109
|
-
// Compute the degrees of freedom.
|
|
110
|
-
const df = samples.length - 1;
|
|
111
|
-
|
|
112
|
-
// Compute the critical value.
|
|
113
|
-
const critical = tTable[df] || tTable.infinity;
|
|
114
|
-
|
|
115
|
-
// Compute the margin of error.
|
|
116
|
-
const moe = sem * critical;
|
|
117
|
-
|
|
118
|
-
// The relative margin of error (expressed as a percentage of the mean).
|
|
119
|
-
const rme = (moe / mean) * 100 || 0;
|
|
120
|
-
|
|
121
|
-
return {
|
|
122
|
-
memPerOp: Math.floor(meanMemUsed),
|
|
123
|
-
ops: NS_PER_SEC / mean,
|
|
124
|
-
deviation: rme,
|
|
125
|
-
numSamples: samples.length,
|
|
126
|
-
};
|
|
127
|
-
}
|
|
128
|
-
|
|
129
|
-
function beautifyBenchmark(results) {
|
|
130
|
-
const nameMaxLen = maxBy(results, ({ name }) => name.length);
|
|
131
|
-
const opsTop = maxBy(results, ({ ops }) => ops);
|
|
132
|
-
const opsMaxLen = maxBy(results, ({ ops }) => beautifyNumber(ops).length);
|
|
133
|
-
const memPerOpMaxLen = maxBy(results, ({ memPerOp }) => beautifyBytes(memPerOp).length);
|
|
134
|
-
|
|
135
|
-
for (const result of results) {
|
|
136
|
-
printBench(result);
|
|
137
|
-
}
|
|
138
|
-
|
|
139
|
-
function printBench(bench) {
|
|
140
|
-
const { name, memPerOp, ops, deviation, numSamples } = bench;
|
|
141
|
-
console.log(
|
|
142
|
-
' ' +
|
|
143
|
-
nameStr() +
|
|
144
|
-
grey(' x ') +
|
|
145
|
-
opsStr() +
|
|
146
|
-
' ops/sec ' +
|
|
147
|
-
grey('\xb1') +
|
|
148
|
-
deviationStr() +
|
|
149
|
-
cyan('%') +
|
|
150
|
-
grey(' x ') +
|
|
151
|
-
memPerOpStr() +
|
|
152
|
-
'/op' +
|
|
153
|
-
grey(' (' + numSamples + ' runs sampled)'),
|
|
154
|
-
);
|
|
155
|
-
|
|
156
|
-
function nameStr() {
|
|
157
|
-
const nameFmt = name.padEnd(nameMaxLen);
|
|
158
|
-
return ops === opsTop ? green(nameFmt) : nameFmt;
|
|
159
|
-
}
|
|
160
|
-
|
|
161
|
-
function opsStr() {
|
|
162
|
-
const percent = ops / opsTop;
|
|
163
|
-
const colorFn = percent > 0.95 ? green : percent > 0.8 ? yellow : red;
|
|
164
|
-
return colorFn(beautifyNumber(ops).padStart(opsMaxLen));
|
|
165
|
-
}
|
|
166
|
-
|
|
167
|
-
function deviationStr() {
|
|
168
|
-
const colorFn = deviation > 5 ? red : deviation > 2 ? yellow : green;
|
|
169
|
-
return colorFn(deviation.toFixed(2));
|
|
170
|
-
}
|
|
171
|
-
|
|
172
|
-
function memPerOpStr() {
|
|
173
|
-
return beautifyBytes(memPerOp).padStart(memPerOpMaxLen);
|
|
174
|
-
}
|
|
175
|
-
}
|
|
176
|
-
}
|
|
177
|
-
|
|
178
|
-
function beautifyBytes(bytes) {
|
|
179
|
-
const sizes = ['Bytes', 'KB', 'MB', 'GB'];
|
|
180
|
-
const i = Math.floor(Math.log2(bytes) / 10);
|
|
181
|
-
return beautifyNumber(bytes / 2 ** (i * 10)) + ' ' + sizes[i];
|
|
182
|
-
}
|
|
183
|
-
|
|
184
|
-
function beautifyNumber(num) {
|
|
185
|
-
return Number(num.toFixed(num > 100 ? 0 : 2)).toLocaleString();
|
|
186
|
-
}
|
|
187
|
-
|
|
188
|
-
function maxBy(array, fn) {
|
|
189
|
-
return Math.max(...array.map(fn));
|
|
190
|
-
}
|
|
191
|
-
|
|
192
|
-
// Prepare all revisions and run benchmarks matching a pattern against them.
|
|
193
|
-
async function prepareAndRunBenchmarks(benchmarkPatterns, revisions) {
|
|
194
|
-
const environments = revisions.map((revision) => ({
|
|
195
|
-
revision,
|
|
196
|
-
distPath: prepareRevision(revision),
|
|
197
|
-
}));
|
|
198
|
-
|
|
199
|
-
console.log(`🚀 Starting benchmarks...`);
|
|
200
|
-
|
|
201
|
-
for (const benchmark of matchBenchmarks(benchmarkPatterns)) {
|
|
202
|
-
const results = [];
|
|
203
|
-
for (let i = 0; i < environments.length; ++i) {
|
|
204
|
-
const environment = environments[i];
|
|
205
|
-
const modulePath = path.join(environment.distPath, benchmark);
|
|
206
|
-
|
|
207
|
-
if (i === 0) {
|
|
208
|
-
const { name } = await sampleModule(modulePath);
|
|
209
|
-
console.log('⏱️ ' + name);
|
|
210
|
-
}
|
|
211
|
-
|
|
212
|
-
try {
|
|
213
|
-
const samples = await collectSamples(modulePath);
|
|
214
|
-
|
|
215
|
-
results.push({
|
|
216
|
-
name: environment.revision,
|
|
217
|
-
samples,
|
|
218
|
-
...computeStats(samples),
|
|
219
|
-
});
|
|
220
|
-
process.stdout.write(' ' + cyan(i + 1) + ' tests completed.\u000D');
|
|
221
|
-
} catch (error) {
|
|
222
|
-
console.log(' ' + environment.revision + ': ' + red(String(error)));
|
|
223
|
-
}
|
|
224
|
-
}
|
|
225
|
-
console.log('\n');
|
|
226
|
-
|
|
227
|
-
beautifyBenchmark(results);
|
|
228
|
-
console.log('');
|
|
229
|
-
}
|
|
230
|
-
}
|
|
231
|
-
|
|
232
|
-
function findFiles(cwd, pattern) {
|
|
233
|
-
const out = exec(`find . -path '${pattern}'`, { cwd });
|
|
234
|
-
return out.split('\n').filter(Boolean);
|
|
235
|
-
}
|
|
236
|
-
|
|
237
|
-
function removeTrailingNewLine(str) {
|
|
238
|
-
if (str == null) {
|
|
239
|
-
return str;
|
|
240
|
-
}
|
|
241
|
-
return str.split('\n').slice(0, -1).join('\n');
|
|
242
|
-
}
|
|
243
|
-
|
|
244
|
-
function exec(command, options) {
|
|
245
|
-
const output = execSync(command, {
|
|
246
|
-
maxBuffer: 10 * 1024 * 1024, // 10MB
|
|
247
|
-
encoding: 'utf-8',
|
|
248
|
-
...options,
|
|
249
|
-
});
|
|
250
|
-
return removeTrailingNewLine(output);
|
|
251
|
-
}
|
|
252
|
-
|
|
253
|
-
// Find all benchmark tests to be run.
|
|
254
|
-
function matchBenchmarks(patterns) {
|
|
255
|
-
let benchmarks = findFiles(LOCAL_DIR('../lib/benchmark/benches'), '*.bench.js');
|
|
256
|
-
if (patterns.length > 0) {
|
|
257
|
-
benchmarks = benchmarks.filter((benchmark) =>
|
|
258
|
-
patterns.some((pattern) => path.join('../lib/benchmark/benches', benchmark).includes(pattern)),
|
|
259
|
-
);
|
|
260
|
-
}
|
|
261
|
-
|
|
262
|
-
if (benchmarks.length === 0) {
|
|
263
|
-
console.warn('No benchmarks matching: ' + patterns.map(bold).join(''));
|
|
264
|
-
}
|
|
265
|
-
|
|
266
|
-
return benchmarks;
|
|
267
|
-
}
|
|
268
|
-
|
|
269
|
-
function getArguments(argv) {
|
|
270
|
-
const revsIdx = argv.indexOf('--revs');
|
|
271
|
-
const revsArgs = revsIdx === -1 ? [] : argv.slice(revsIdx + 1);
|
|
272
|
-
const benchmarkPatterns = revsIdx === -1 ? argv : argv.slice(0, revsIdx);
|
|
273
|
-
let assumeArgs;
|
|
274
|
-
let revisions;
|
|
275
|
-
switch (revsArgs.length) {
|
|
276
|
-
case 0:
|
|
277
|
-
assumeArgs = [...benchmarkPatterns, '--revs', 'local', 'HEAD'];
|
|
278
|
-
revisions = [LOCAL, 'HEAD'];
|
|
279
|
-
break;
|
|
280
|
-
case 1:
|
|
281
|
-
if (revsArgs[0] === LOCAL) {
|
|
282
|
-
assumeArgs = [...benchmarkPatterns, '--revs', revsArgs[0]];
|
|
283
|
-
revisions = [revsArgs[0]];
|
|
284
|
-
} else {
|
|
285
|
-
assumeArgs = [...benchmarkPatterns, '--revs', 'local', revsArgs[0]];
|
|
286
|
-
revisions = [LOCAL, revsArgs[0]];
|
|
287
|
-
}
|
|
288
|
-
break;
|
|
289
|
-
default:
|
|
290
|
-
revisions = revsArgs;
|
|
291
|
-
break;
|
|
292
|
-
}
|
|
293
|
-
if (assumeArgs) {
|
|
294
|
-
console.warn('Assuming you meant: ' + bold('benchmark ' + assumeArgs.join(' ')));
|
|
295
|
-
}
|
|
296
|
-
return { benchmarkPatterns, revisions };
|
|
297
|
-
}
|
|
298
|
-
|
|
299
|
-
function bold(str) {
|
|
300
|
-
return '\u001b[1m' + str + '\u001b[0m';
|
|
301
|
-
}
|
|
302
|
-
|
|
303
|
-
// Get the revisions and make things happen!
|
|
304
|
-
if (require.main === module) {
|
|
305
|
-
const { benchmarkPatterns, revisions } = getArguments(process.argv.slice(2));
|
|
306
|
-
prepareAndRunBenchmarks(benchmarkPatterns, revisions);
|
|
307
|
-
}
|
package/src/benchmark/colors.js
DELETED
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
function red(str) {
|
|
4
|
-
return '\u001b[31m' + str + '\u001b[0m';
|
|
5
|
-
}
|
|
6
|
-
|
|
7
|
-
function green(str) {
|
|
8
|
-
return '\u001b[32m' + str + '\u001b[0m';
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
function yellow(str) {
|
|
12
|
-
return '\u001b[33m' + str + '\u001b[0m';
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
function cyan(str) {
|
|
16
|
-
return '\u001b[36m' + str + '\u001b[0m';
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
function grey(str) {
|
|
20
|
-
return '\u001b[90m' + str + '\u001b[0m';
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
module.exports = {
|
|
24
|
-
red,
|
|
25
|
-
green,
|
|
26
|
-
yellow,
|
|
27
|
-
cyan,
|
|
28
|
-
grey,
|
|
29
|
-
};
|
package/src/benchmark/fork.js
DELETED
|
@@ -1,83 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
const assert = require('assert');
|
|
4
|
-
const cp = require('child_process');
|
|
5
|
-
|
|
6
|
-
// Clocks the time taken to execute a test per cycle (secs).
|
|
7
|
-
function clock(count, fn) {
|
|
8
|
-
const start = process.hrtime.bigint();
|
|
9
|
-
for (let i = 0; i < count; ++i) {
|
|
10
|
-
fn();
|
|
11
|
-
}
|
|
12
|
-
return Number(process.hrtime.bigint() - start);
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
async function clockAsync(count, fn) {
|
|
16
|
-
const start = process.hrtime.bigint();
|
|
17
|
-
for (let i = 0; i < count; ++i) {
|
|
18
|
-
await fn();
|
|
19
|
-
}
|
|
20
|
-
return Number(process.hrtime.bigint() - start);
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
if (require.main === module) {
|
|
24
|
-
const modulePath = process.env.BENCHMARK_MODULE_PATH;
|
|
25
|
-
assert(typeof modulePath === 'string');
|
|
26
|
-
assert(process.send);
|
|
27
|
-
const module = require(modulePath);
|
|
28
|
-
|
|
29
|
-
if (module.measureAsync) {
|
|
30
|
-
async function run() {
|
|
31
|
-
await clockAsync(7, module.measureAsync); // warm up
|
|
32
|
-
global.gc();
|
|
33
|
-
process.nextTick(async () => {
|
|
34
|
-
const memBaseline = process.memoryUsage().heapUsed;
|
|
35
|
-
const clocked = await clockAsync(module.count, module.measureAsync);
|
|
36
|
-
process.send({
|
|
37
|
-
name: module.name,
|
|
38
|
-
clocked: clocked / module.count,
|
|
39
|
-
memUsed: (process.memoryUsage().heapUsed - memBaseline) / module.count,
|
|
40
|
-
});
|
|
41
|
-
});
|
|
42
|
-
}
|
|
43
|
-
run();
|
|
44
|
-
} else {
|
|
45
|
-
clock(7, module.measure); // warm up
|
|
46
|
-
global.gc();
|
|
47
|
-
process.nextTick(() => {
|
|
48
|
-
const memBaseline = process.memoryUsage().heapUsed;
|
|
49
|
-
const clocked = clock(module.count, module.measure);
|
|
50
|
-
process.send({
|
|
51
|
-
name: module.name,
|
|
52
|
-
clocked: clocked / module.count,
|
|
53
|
-
memUsed: (process.memoryUsage().heapUsed - memBaseline) / module.count,
|
|
54
|
-
});
|
|
55
|
-
});
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
function sampleModule(modulePath) {
|
|
60
|
-
return new Promise((resolve, reject) => {
|
|
61
|
-
const env = {
|
|
62
|
-
NODE_ENV: 'production',
|
|
63
|
-
BENCHMARK_MODULE_PATH: modulePath,
|
|
64
|
-
};
|
|
65
|
-
const child = cp.fork(__filename, { env });
|
|
66
|
-
let message;
|
|
67
|
-
let error;
|
|
68
|
-
|
|
69
|
-
child.on('message', (msg) => (message = msg));
|
|
70
|
-
child.on('error', (e) => (error = e));
|
|
71
|
-
child.on('close', () => {
|
|
72
|
-
if (message) {
|
|
73
|
-
return resolve(message);
|
|
74
|
-
}
|
|
75
|
-
reject(error || new Error('Forked process closed without error'));
|
|
76
|
-
});
|
|
77
|
-
}).then((result) => {
|
|
78
|
-
global.gc();
|
|
79
|
-
return result;
|
|
80
|
-
});
|
|
81
|
-
}
|
|
82
|
-
|
|
83
|
-
module.exports = { sampleModule };
|
package/src/benchmark/utils.ts
DELETED
|
@@ -1,36 +0,0 @@
|
|
|
1
|
-
import { parseYaml } from '../js-yaml';
|
|
2
|
-
import { Document, Source } from '../resolve';
|
|
3
|
-
import { Oas3RuleSet } from '../oas-types';
|
|
4
|
-
import { LintConfig, mergeExtends, resolvePlugins } from '../config';
|
|
5
|
-
|
|
6
|
-
import type { RuleConfig, Plugin, ResolvedLintConfig } from '../config/types';
|
|
7
|
-
|
|
8
|
-
export function parseYamlToDocument(body: string, absoluteRef: string = ''): Document {
|
|
9
|
-
return {
|
|
10
|
-
source: new Source(absoluteRef, body),
|
|
11
|
-
parsed: parseYaml(body, { filename: absoluteRef }),
|
|
12
|
-
};
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
export function makeConfigForRuleset(rules: Oas3RuleSet, plugin?: Partial<Plugin>) {
|
|
16
|
-
const rulesConf: Record<string, RuleConfig> = {};
|
|
17
|
-
const ruleId = 'test';
|
|
18
|
-
Object.keys(rules).forEach((name) => {
|
|
19
|
-
rulesConf[`${ruleId}/${name}`] = 'error';
|
|
20
|
-
});
|
|
21
|
-
const extendConfigs = [
|
|
22
|
-
resolvePlugins([
|
|
23
|
-
{
|
|
24
|
-
...plugin,
|
|
25
|
-
id: ruleId,
|
|
26
|
-
rules: { oas3: rules },
|
|
27
|
-
},
|
|
28
|
-
]) as ResolvedLintConfig,
|
|
29
|
-
];
|
|
30
|
-
if (rules) {
|
|
31
|
-
extendConfigs.push({ rules });
|
|
32
|
-
}
|
|
33
|
-
const lint = mergeExtends(extendConfigs);
|
|
34
|
-
|
|
35
|
-
return new LintConfig(lint);
|
|
36
|
-
}
|