@api-client/core 0.19.10 → 0.19.11
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/LICENSE.md +9 -63
- package/bin/test.ts +1 -12
- package/build/src/browser.d.ts +0 -15
- package/build/src/browser.d.ts.map +1 -1
- package/build/src/browser.js +0 -17
- package/build/src/browser.js.map +1 -1
- package/build/src/events/EventTypes.d.ts +0 -6
- package/build/src/events/EventTypes.d.ts.map +1 -1
- package/build/src/events/EventTypes.js +0 -2
- package/build/src/events/EventTypes.js.map +1 -1
- package/build/src/events/Events.d.ts +0 -2
- package/build/src/events/Events.d.ts.map +1 -1
- package/build/src/events/Events.js +0 -2
- package/build/src/events/Events.js.map +1 -1
- package/build/src/index.d.ts +0 -15
- package/build/src/index.d.ts.map +1 -1
- package/build/src/index.js +0 -17
- package/build/src/index.js.map +1 -1
- package/build/src/modeling/Bindings.d.ts +3 -3
- package/build/src/modeling/Bindings.d.ts.map +1 -1
- package/build/src/modeling/Bindings.js.map +1 -1
- package/build/src/modeling/DomainAssociation.d.ts +5 -5
- package/build/src/modeling/DomainAssociation.d.ts.map +1 -1
- package/build/src/modeling/DomainAssociation.js.map +1 -1
- package/build/src/modeling/DomainEntity.d.ts +2 -3
- package/build/src/modeling/DomainEntity.d.ts.map +1 -1
- package/build/src/modeling/DomainEntity.js +1 -1
- package/build/src/modeling/DomainEntity.js.map +1 -1
- package/build/src/modeling/DomainProperty.d.ts +2 -3
- package/build/src/modeling/DomainProperty.d.ts.map +1 -1
- package/build/src/modeling/DomainProperty.js +1 -1
- package/build/src/modeling/DomainProperty.js.map +1 -1
- package/build/src/modeling/ai/types.d.ts +2 -2
- package/build/src/modeling/ai/types.d.ts.map +1 -1
- package/build/src/modeling/ai/types.js.map +1 -1
- package/build/src/{amf → modeling/amf}/DataValueGenerator.d.ts +1 -1
- package/build/src/modeling/amf/DataValueGenerator.d.ts.map +1 -0
- package/build/src/{amf → modeling/amf}/DataValueGenerator.js +2 -3
- package/build/src/modeling/amf/DataValueGenerator.js.map +1 -0
- package/build/src/modeling/amf/ShapeGenerator.d.ts +20 -20
- package/build/src/modeling/amf/ShapeGenerator.d.ts.map +1 -1
- package/build/src/modeling/amf/ShapeGenerator.js +16 -18
- package/build/src/modeling/amf/ShapeGenerator.js.map +1 -1
- package/build/src/modeling/amf/core_types.d.ts +9 -0
- package/build/src/modeling/amf/core_types.d.ts.map +1 -0
- package/build/src/modeling/amf/core_types.js +45 -0
- package/build/src/modeling/amf/core_types.js.map +1 -0
- package/build/src/models/http-flows/LegacyTranslator.js +1 -1
- package/build/src/models/http-flows/LegacyTranslator.js.map +1 -1
- package/build/src/runtime/http-runner/HttpFlows.js +1 -1
- package/build/src/runtime/http-runner/HttpFlows.js.map +1 -1
- package/build/tsconfig.tsbuildinfo +1 -1
- package/eslint.config.js +0 -1
- package/package.json +11 -14
- package/src/events/EventTypes.ts +0 -2
- package/src/events/Events.ts +0 -2
- package/src/modeling/Bindings.ts +3 -3
- package/src/modeling/DomainAssociation.ts +5 -5
- package/src/modeling/DomainEntity.ts +3 -4
- package/src/modeling/DomainProperty.ts +3 -4
- package/src/modeling/ai/types.ts +2 -2
- package/src/{amf → modeling/amf}/DataValueGenerator.ts +3 -4
- package/src/modeling/amf/ShapeGenerator.ts +45 -61
- package/src/modeling/amf/core_types.ts +47 -0
- package/src/models/http-flows/LegacyTranslator.ts +1 -1
- package/src/runtime/http-runner/HttpFlows.ts +1 -1
- package/tests/unit/{amf → modeling/amf}/data_value_generator.spec.ts +2 -2
- package/tests/unit/modeling/amf/shape_generator.spec.ts +146 -167
- package/tests/unit/modeling/domain_asociation.spec.ts +13 -13
- package/tests/unit/runtime/runners/http_assertion_runner.spec.ts +1 -1
- package/tests/unit/runtime/runners/http_flow_runner.spec.ts +1 -1
- package/tests/unit/runtime/runners/project_runner.spec.ts +1 -1
- package/tests/unit/runtime/runners/request_runner.spec.ts +1 -1
- package/tests/unit/runtime/runners/serial_runner.spec.ts +1 -1
- package/build/src/amf/AmfMixin.d.ts +0 -396
- package/build/src/amf/AmfMixin.d.ts.map +0 -1
- package/build/src/amf/AmfMixin.js +0 -1138
- package/build/src/amf/AmfMixin.js.map +0 -1
- package/build/src/amf/AmfSerializer.d.ts +0 -137
- package/build/src/amf/AmfSerializer.d.ts.map +0 -1
- package/build/src/amf/AmfSerializer.js +0 -1947
- package/build/src/amf/AmfSerializer.js.map +0 -1
- package/build/src/amf/AmfTypes.d.ts +0 -25
- package/build/src/amf/AmfTypes.d.ts.map +0 -1
- package/build/src/amf/AmfTypes.js +0 -143
- package/build/src/amf/AmfTypes.js.map +0 -1
- package/build/src/amf/ApiExampleGenerator.d.ts +0 -40
- package/build/src/amf/ApiExampleGenerator.d.ts.map +0 -1
- package/build/src/amf/ApiExampleGenerator.js +0 -112
- package/build/src/amf/ApiExampleGenerator.js.map +0 -1
- package/build/src/amf/ApiMonacoSchemaGenerator.d.ts +0 -68
- package/build/src/amf/ApiMonacoSchemaGenerator.d.ts.map +0 -1
- package/build/src/amf/ApiMonacoSchemaGenerator.js +0 -248
- package/build/src/amf/ApiMonacoSchemaGenerator.js.map +0 -1
- package/build/src/amf/ApiSchemaGenerator.d.ts +0 -56
- package/build/src/amf/ApiSchemaGenerator.d.ts.map +0 -1
- package/build/src/amf/ApiSchemaGenerator.js +0 -94
- package/build/src/amf/ApiSchemaGenerator.js.map +0 -1
- package/build/src/amf/ApiSchemaValues.d.ts +0 -111
- package/build/src/amf/ApiSchemaValues.d.ts.map +0 -1
- package/build/src/amf/ApiSchemaValues.js +0 -463
- package/build/src/amf/ApiSchemaValues.js.map +0 -1
- package/build/src/amf/DataValueGenerator.d.ts.map +0 -1
- package/build/src/amf/DataValueGenerator.js.map +0 -1
- package/build/src/amf/Parsing.d.ts +0 -48
- package/build/src/amf/Parsing.d.ts.map +0 -1
- package/build/src/amf/Parsing.js +0 -2
- package/build/src/amf/Parsing.js.map +0 -1
- package/build/src/amf/Utils.d.ts +0 -37
- package/build/src/amf/Utils.d.ts.map +0 -1
- package/build/src/amf/Utils.js +0 -169
- package/build/src/amf/Utils.js.map +0 -1
- package/build/src/amf/data-node/DataNodeBase.d.ts +0 -34
- package/build/src/amf/data-node/DataNodeBase.d.ts.map +0 -1
- package/build/src/amf/data-node/DataNodeBase.js +0 -77
- package/build/src/amf/data-node/DataNodeBase.js.map +0 -1
- package/build/src/amf/data-node/JsonDataNodeGenerator.d.ts +0 -15
- package/build/src/amf/data-node/JsonDataNodeGenerator.d.ts.map +0 -1
- package/build/src/amf/data-node/JsonDataNodeGenerator.js +0 -23
- package/build/src/amf/data-node/JsonDataNodeGenerator.js.map +0 -1
- package/build/src/amf/data-node/UrlEncodedDataNodeGenerator.d.ts +0 -14
- package/build/src/amf/data-node/UrlEncodedDataNodeGenerator.d.ts.map +0 -1
- package/build/src/amf/data-node/UrlEncodedDataNodeGenerator.js +0 -48
- package/build/src/amf/data-node/UrlEncodedDataNodeGenerator.js.map +0 -1
- package/build/src/amf/data-node/XmlDataNodeGenerator.d.ts +0 -22
- package/build/src/amf/data-node/XmlDataNodeGenerator.d.ts.map +0 -1
- package/build/src/amf/data-node/XmlDataNodeGenerator.js +0 -34
- package/build/src/amf/data-node/XmlDataNodeGenerator.js.map +0 -1
- package/build/src/amf/definitions/Amf.d.ts +0 -363
- package/build/src/amf/definitions/Amf.d.ts.map +0 -1
- package/build/src/amf/definitions/Amf.js +0 -3
- package/build/src/amf/definitions/Amf.js.map +0 -1
- package/build/src/amf/definitions/Api.d.ts +0 -383
- package/build/src/amf/definitions/Api.d.ts.map +0 -1
- package/build/src/amf/definitions/Api.js +0 -2
- package/build/src/amf/definitions/Api.js.map +0 -1
- package/build/src/amf/definitions/Base.d.ts +0 -12
- package/build/src/amf/definitions/Base.d.ts.map +0 -1
- package/build/src/amf/definitions/Base.js +0 -2
- package/build/src/amf/definitions/Base.js.map +0 -1
- package/build/src/amf/definitions/Namespace.d.ts +0 -327
- package/build/src/amf/definitions/Namespace.d.ts.map +0 -1
- package/build/src/amf/definitions/Namespace.js +0 -346
- package/build/src/amf/definitions/Namespace.js.map +0 -1
- package/build/src/amf/definitions/Shapes.d.ts +0 -312
- package/build/src/amf/definitions/Shapes.d.ts.map +0 -1
- package/build/src/amf/definitions/Shapes.js +0 -87
- package/build/src/amf/definitions/Shapes.js.map +0 -1
- package/build/src/amf/models/AmfDataNode.d.ts +0 -67
- package/build/src/amf/models/AmfDataNode.d.ts.map +0 -1
- package/build/src/amf/models/AmfDataNode.js +0 -192
- package/build/src/amf/models/AmfDataNode.js.map +0 -1
- package/build/src/amf/shape/ShapeBase.d.ts +0 -74
- package/build/src/amf/shape/ShapeBase.d.ts.map +0 -1
- package/build/src/amf/shape/ShapeBase.js +0 -93
- package/build/src/amf/shape/ShapeBase.js.map +0 -1
- package/build/src/amf/shape/ShapeJsonSchemaGenerator.d.ts +0 -47
- package/build/src/amf/shape/ShapeJsonSchemaGenerator.d.ts.map +0 -1
- package/build/src/amf/shape/ShapeJsonSchemaGenerator.js +0 -420
- package/build/src/amf/shape/ShapeJsonSchemaGenerator.js.map +0 -1
- package/build/src/amf/shape/ShapeXmlSchemaGenerator.d.ts +0 -85
- package/build/src/amf/shape/ShapeXmlSchemaGenerator.d.ts.map +0 -1
- package/build/src/amf/shape/ShapeXmlSchemaGenerator.js +0 -852
- package/build/src/amf/shape/ShapeXmlSchemaGenerator.js.map +0 -1
- package/build/src/events/amf/AmfEventTypes.d.ts +0 -7
- package/build/src/events/amf/AmfEventTypes.d.ts.map +0 -1
- package/build/src/events/amf/AmfEventTypes.js +0 -7
- package/build/src/events/amf/AmfEventTypes.js.map +0 -1
- package/build/src/events/amf/AmfEvents.d.ts +0 -34
- package/build/src/events/amf/AmfEvents.d.ts.map +0 -1
- package/build/src/events/amf/AmfEvents.js +0 -63
- package/build/src/events/amf/AmfEvents.js.map +0 -1
- package/build/src/mocking/RandExp.d.ts +0 -55
- package/build/src/mocking/RandExp.d.ts.map +0 -1
- package/build/src/mocking/RandExp.js +0 -302
- package/build/src/mocking/RandExp.js.map +0 -1
- package/build/src/mocking/lib/ret.d.ts +0 -16
- package/build/src/mocking/lib/ret.d.ts.map +0 -1
- package/build/src/mocking/lib/ret.js +0 -284
- package/build/src/mocking/lib/ret.js.map +0 -1
- package/data/apis/APIC-187/APIC-187.raml +0 -21
- package/data/apis/APIC-187/dataType.raml +0 -132
- package/data/apis/APIC-187/example.raml +0 -84
- package/data/apis/APIC-188/APIC-188.raml +0 -21
- package/data/apis/APIC-188/dataType.raml +0 -132
- package/data/apis/APIC-188/example.raml +0 -84
- package/data/apis/APIC-233/APIC-233.raml +0 -15
- package/data/apis/APIC-391/APIC-391.raml +0 -44
- package/data/apis/APIC-391/examples/post-body-request-example.raml +0 -7
- package/data/apis/APIC-483/APIC-483.raml +0 -16
- package/data/apis/APIC-483/example/list-of-bank-succ.json +0 -32
- package/data/apis/APIC-483/schema/response-retrieve-list-bank.json +0 -68
- package/data/apis/APIC-487/APIC-487.raml +0 -36
- package/data/apis/APIC-655/APIC-655.raml +0 -44
- package/data/apis/APIC-655/delivery.json +0 -12
- package/data/apis/APIC-689/APIC-689.raml +0 -20
- package/data/apis/APIC-690/APIC-690.raml +0 -17
- package/data/apis/APIC-690/datatypes/Address.raml +0 -10
- package/data/apis/APIC-690/datatypes/Customer.raml +0 -17
- package/data/apis/APIC-690/examples/CustomerExample2.raml +0 -17
- package/data/apis/APIC-690/examples/CustomersExample.raml +0 -34
- package/data/apis/SE-10469/Purchase-Order-oagis-id-dd32f9c6c01048a19e15c423c9c741ae.json +0 -1383
- package/data/apis/SE-10469/SE-10469.raml +0 -11
- package/data/apis/SE-13092/Examples/PersonExample.raml +0 -7
- package/data/apis/SE-13092/SE-13092.raml +0 -37
- package/data/apis/SE-13092/datatypes/Address.raml +0 -5
- package/data/apis/SE-13092/datatypes/InlineType.raml +0 -5
- package/data/apis/SE-13092/datatypes/Person.raml +0 -15
- package/data/apis/SE-22063/SE-22063.raml +0 -14
- package/data/apis/SE-22063/stock.raml +0 -41
- package/data/apis/amf-helper-api/amf-helper-api.raml +0 -1024
- package/data/apis/amf-helper-api/examples/comment-example.json +0 -42
- package/data/apis/amf-helper-api/examples/commentCreateRequest-example.json +0 -7
- package/data/apis/amf-helper-api/examples/commentList-example.json +0 -48
- package/data/apis/amf-helper-api/examples/person.json +0 -14
- package/data/apis/amf-helper-api/examples/person.raml +0 -13
- package/data/apis/amf-helper-api/examples/person.xml +0 -14
- package/data/apis/amf-helper-api/libraries/comment-lib.raml +0 -143
- package/data/apis/amf-helper-api/library.raml +0 -7
- package/data/apis/amf-helper-api/schemas/person.json +0 -104
- package/data/apis/amf-helper-api/schemas/person.xsd +0 -26
- package/data/apis/amf-helper-api/traits/file.raml +0 -33
- package/data/apis/amf-helper-api/traits/pagination.raml +0 -80
- package/data/apis/amf-helper-api/traits/results.raml +0 -19
- package/data/apis/amf-helper-api/traits/visibility.raml +0 -14
- package/data/apis/amf-helper-api/types/app-person.raml +0 -101
- package/data/apis/amf-helper-api/types/dimensions.raml +0 -24
- package/data/apis/amf-helper-api/types/external-type.raml +0 -7
- package/data/apis/amf-helper-api/types/image.raml +0 -23
- package/data/apis/amf-helper-api/types/product.raml +0 -52
- package/data/apis/amf-helper-api/types/resource.raml +0 -11
- package/data/apis/amf-helper-api/types/standard-request.raml +0 -50
- package/data/apis/amf-helper-api/types/user.raml +0 -37
- package/data/apis/arc-demo-api/arc-demo-api.raml +0 -468
- package/data/apis/arc-demo-api/examples/e400.xml +0 -4
- package/data/apis/arc-demo-api/examples/e401.xml +0 -4
- package/data/apis/arc-demo-api/examples/e404.xml +0 -4
- package/data/apis/arc-demo-api/examples/image.xml +0 -5
- package/data/apis/arc-demo-api/examples/messages-example.json +0 -22
- package/data/apis/arc-demo-api/examples/messages-sent-example.json +0 -15
- package/data/apis/arc-demo-api/examples/person.json +0 -14
- package/data/apis/arc-demo-api/examples/person.url.encoded +0 -1
- package/data/apis/arc-demo-api/examples/person.xml +0 -14
- package/data/apis/arc-demo-api/examples/product.xml +0 -9
- package/data/apis/arc-demo-api/library.raml +0 -36
- package/data/apis/arc-demo-api/resourceTypes/app-person.raml +0 -49
- package/data/apis/arc-demo-api/resourceTypes/example-types.raml +0 -45
- package/data/apis/arc-demo-api/resourceTypes/image.raml +0 -23
- package/data/apis/arc-demo-api/resourceTypes/message-sent-type.raml +0 -23
- package/data/apis/arc-demo-api/resourceTypes/message-type.raml +0 -33
- package/data/apis/arc-demo-api/resourceTypes/product.raml +0 -52
- package/data/apis/arc-demo-api/resourceTypes/resource.raml +0 -11
- package/data/apis/arc-demo-api/schemas/error-response.xsd +0 -11
- package/data/apis/arc-demo-api/schemas/image.xsd +0 -11
- package/data/apis/arc-demo-api/schemas/person.json +0 -104
- package/data/apis/arc-demo-api/schemas/person.xsd +0 -26
- package/data/apis/arc-demo-api/schemas/product.xsd +0 -17
- package/data/apis/arc-demo-api/securitySchemes/basic.raml +0 -5
- package/data/apis/arc-demo-api/securitySchemes/oauth_2_0.raml +0 -29
- package/data/apis/arc-demo-api/securitySchemes/x-custom.raml +0 -26
- package/data/apis/arc-demo-api/traits/adminable.raml +0 -23
- package/data/apis/arc-demo-api/traits/pagination.raml +0 -83
- package/data/apis/arc-demo-api/traits/rate-limited.raml +0 -9
- package/data/apis/async-api/async-api.yaml +0 -96
- package/data/apis/example-generator-api/contact-email-example.raml +0 -6
- package/data/apis/example-generator-api/contact-example.raml +0 -5
- package/data/apis/example-generator-api/contact-fax-example.raml +0 -5
- package/data/apis/example-generator-api/contact-website-example.raml +0 -2
- package/data/apis/example-generator-api/example-1.raml +0 -6
- package/data/apis/example-generator-api/example-2.raml +0 -9
- package/data/apis/example-generator-api/example-3.raml +0 -4
- package/data/apis/example-generator-api/example-4.raml +0 -2
- package/data/apis/example-generator-api/example-5.raml +0 -4
- package/data/apis/example-generator-api/example-6.raml +0 -2
- package/data/apis/example-generator-api/example-7.raml +0 -5
- package/data/apis/example-generator-api/example-generator-api.raml +0 -423
- package/data/apis/example-generator-api/example.json +0 -14
- package/data/apis/example-generator-api/example.xml +0 -15
- package/data/apis/example-generator-api/example.xsd +0 -26
- package/data/apis/example-generator-api/examples/employee.raml +0 -7
- package/data/apis/example-generator-api/examples/employees.raml +0 -7
- package/data/apis/example-generator-api/linked-named-example.raml +0 -21
- package/data/apis/example-generator-api/named-example-with-link.raml +0 -5
- package/data/apis/example-generator-api/named-example.raml +0 -9
- package/data/apis/example-generator-api/user-json-example.raml +0 -17
- package/data/apis/example-generator-api/user-raml-example.raml +0 -37
- package/data/apis/example-generator-api/user.json +0 -8
- package/data/apis/example-generator-api/user.raml +0 -18
- package/data/apis/example-generator-api/users-json-example.raml +0 -17
- package/data/apis/example-generator-api/users-raml-example.raml +0 -32
- package/data/apis/example-generator-api/users.json +0 -8
- package/data/apis/expanded-api/expanded-api.raml +0 -8
- package/data/apis/flattened-api/flattened-api.raml +0 -8
- package/data/apis/multiple-servers/multiple-servers.yaml +0 -112
- package/data/apis/oas-3-api/oas-3-api.yaml +0 -356
- package/data/apis/oas-date/oas-date.yaml +0 -28
- package/data/apis/oas-types/oas-types.yaml +0 -159
- package/data/apis/oas-unions/oas-unions.yaml +0 -75
- package/data/apis/petstore/petstore.yaml +0 -954
- package/data/apis/raml-date/raml-date.raml +0 -28
- package/data/apis/recursive/recursive.raml +0 -14
- package/data/apis/schema-api/examples/person.json +0 -14
- package/data/apis/schema-api/examples/person.raml +0 -14
- package/data/apis/schema-api/examples/person.url.encoded +0 -1
- package/data/apis/schema-api/examples/person.xml +0 -14
- package/data/apis/schema-api/library/demo-types.raml +0 -43
- package/data/apis/schema-api/schema-api.raml +0 -656
- package/data/apis/schema-api/schemas/person.json +0 -104
- package/data/apis/schema-api/schemas/person.xsd +0 -26
- package/data/apis/schema-api/types/DemoPerson.raml +0 -67
- package/data/apis/secured-api/oauth-2-custom-settings.raml +0 -143
- package/data/apis/secured-api/oauth2-header-delivery.raml +0 -13
- package/data/apis/secured-api/oauth2-no-delivery.raml +0 -8
- package/data/apis/secured-api/oauth2-no-grants.raml +0 -12
- package/data/apis/secured-api/oauth2-pkce.raml +0 -13
- package/data/apis/secured-api/oauth2-query-delivery.raml +0 -13
- package/data/apis/secured-api/oauth_1_0.raml +0 -8
- package/data/apis/secured-api/oauth_1_0_no-settings.raml +0 -3
- package/data/apis/secured-api/oauth_1_0_no-signature.raml +0 -7
- package/data/apis/secured-api/oauth_1_0_signature.raml +0 -8
- package/data/apis/secured-api/passthrough-querystring.raml +0 -16
- package/data/apis/secured-api/passthrough.raml +0 -24
- package/data/apis/secured-api/secured-api.raml +0 -231
- package/data/apis/secured-api/x-custom.raml +0 -33
- package/data/apis/secured-api/x-other.raml +0 -29
- package/data/apis/secured-api/x-query-string.raml +0 -16
- package/data/apis/tracked-examples/datatypes/employee.raml +0 -5
- package/data/apis/tracked-examples/examples/employee.raml +0 -4
- package/data/apis/tracked-examples/examples/employees.raml +0 -8
- package/data/apis/tracked-examples/tracked-to-linked.raml +0 -28
- package/data/model.js +0 -129
- package/data/models/APIC-187.json +0 -11416
- package/data/models/APIC-188.json +0 -11416
- package/data/models/APIC-233.json +0 -539
- package/data/models/APIC-391.json +0 -1903
- package/data/models/APIC-483.json +0 -3110
- package/data/models/APIC-487.json +0 -1225
- package/data/models/APIC-655.json +0 -3145
- package/data/models/APIC-689.json +0 -797
- package/data/models/APIC-690.json +0 -5992
- package/data/models/SE-10469.json +0 -22898
- package/data/models/SE-13092.json +0 -2769
- package/data/models/SE-22063.json +0 -2314
- package/data/models/amf-helper-api.json +0 -84457
- package/data/models/arc-demo-api.json +0 -52041
- package/data/models/async-api.json +0 -3227
- package/data/models/example-generator-api.json +0 -45209
- package/data/models/expanded-api.json +0 -251
- package/data/models/flattened-api.json +0 -251
- package/data/models/multiple-servers.json +0 -2769
- package/data/models/oas-3-api.json +0 -10590
- package/data/models/oas-date.json +0 -637
- package/data/models/oas-types.json +0 -5352
- package/data/models/oas-unions.json +0 -1935
- package/data/models/petstore.json +0 -27712
- package/data/models/raml-date.json +0 -1114
- package/data/models/recursive.json +0 -610
- package/data/models/schema-api.json +0 -35527
- package/data/models/secured-api.json +0 -21071
- package/data/models/tracked-to-linked.json +0 -1914
- package/src/amf/AmfMixin.ts +0 -1726
- package/src/amf/AmfSerializer.ts +0 -2358
- package/src/amf/AmfTypes.ts +0 -147
- package/src/amf/ApiExampleGenerator.ts +0 -122
- package/src/amf/ApiMonacoSchemaGenerator.ts +0 -332
- package/src/amf/ApiSchemaGenerator.ts +0 -115
- package/src/amf/ApiSchemaValues.ts +0 -509
- package/src/amf/Parsing.ts +0 -50
- package/src/amf/Utils.ts +0 -172
- package/src/amf/data-node/DataNodeBase.ts +0 -83
- package/src/amf/data-node/JsonDataNodeGenerator.ts +0 -24
- package/src/amf/data-node/README.md +0 -3
- package/src/amf/data-node/UrlEncodedDataNodeGenerator.ts +0 -49
- package/src/amf/data-node/XmlDataNodeGenerator.ts +0 -46
- package/src/amf/definitions/Amf.ts +0 -440
- package/src/amf/definitions/Api.ts +0 -445
- package/src/amf/definitions/Base.ts +0 -13
- package/src/amf/definitions/Namespace.ts +0 -357
- package/src/amf/definitions/Shapes.ts +0 -438
- package/src/amf/models/AmfDataNode.ts +0 -210
- package/src/amf/shape/README.md +0 -4
- package/src/amf/shape/ShapeBase.ts +0 -174
- package/src/amf/shape/ShapeJsonSchemaGenerator.ts +0 -457
- package/src/amf/shape/ShapeXmlSchemaGenerator.ts +0 -933
- package/src/events/amf/AmfEventTypes.ts +0 -6
- package/src/events/amf/AmfEvents.ts +0 -78
- package/src/mocking/RandExp.ts +0 -335
- package/src/mocking/lib/ret.ts +0 -279
- package/tests/unit/amf/APIC-187.spec.ts +0 -41
- package/tests/unit/amf/APIC-188.spec.ts +0 -30
- package/tests/unit/amf/APIC-233.spec.ts +0 -32
- package/tests/unit/amf/APIC-391.spec.ts +0 -39
- package/tests/unit/amf/APIC-487.spec.ts +0 -44
- package/tests/unit/amf/APIC-655.spec.ts +0 -41
- package/tests/unit/amf/APIC-689.spec.ts +0 -28
- package/tests/unit/amf/APIC-690.spec.ts +0 -93
- package/tests/unit/amf/AmfLoader.ts +0 -538
- package/tests/unit/amf/AmfMixin.spec.ts +0 -1707
- package/tests/unit/amf/ApiExampleGenerator.spec.ts +0 -250
- package/tests/unit/amf/ApiMonacoSchemaGenerator.spec.ts +0 -183
- package/tests/unit/amf/ApiSchemaValues.spec.ts +0 -602
- package/tests/unit/amf/Namepsace.spec.ts +0 -494
- package/tests/unit/amf/SE-10469.spec.ts +0 -35
- package/tests/unit/amf/SE-13092.spec.ts +0 -64
- package/tests/unit/amf/SE-22063.spec.ts +0 -45
- package/tests/unit/amf/raml-examples.spec.ts +0 -43
- package/tests/unit/amf/schema_gen_array.spec.ts +0 -199
- package/tests/unit/amf/schema_gen_oas.spec.ts +0 -140
- package/tests/unit/amf/schema_gen_object.spec.ts +0 -279
- package/tests/unit/amf/schema_gen_scalar.spec.ts +0 -143
- package/tests/unit/amf/schema_gen_union.spec.ts +0 -401
- package/tests/unit/amf/schema_gen_unknown.spec.ts +0 -42
- package/tests/unit/amf/schema_gen_xml.spec.ts +0 -726
- package/tests/unit/amf/serializer/APIC-483.spec.ts +0 -36
- package/tests/unit/amf/serializer/Anotations.spec.ts +0 -50
- package/tests/unit/amf/serializer/Api.spec.ts +0 -210
- package/tests/unit/amf/serializer/Documentation.spec.ts +0 -52
- package/tests/unit/amf/serializer/Endpoints.spec.ts +0 -172
- package/tests/unit/amf/serializer/Operations.spec.ts +0 -330
- package/tests/unit/amf/serializer/Parameters.spec.ts +0 -149
- package/tests/unit/amf/serializer/PayloadExamples.spec.ts +0 -152
- package/tests/unit/amf/serializer/Security.spec.ts +0 -626
- package/tests/unit/amf/serializer/Server.spec.ts +0 -78
- package/tests/unit/amf/serializer/Shapes.spec.ts +0 -304
- package/tests/unit/amf/serializer/SourceMaps.spec.ts +0 -52
- package/tests/unit/amf/shapes/ShapeXmlSchemaGenerator.spec.ts +0 -28
- package/tests/unit/amf/tracked-to-linked.spec.ts +0 -90
- package/tests/unit/amf/xml-data-processing.spec.ts +0 -217
- package/tests/unit/events/amf.spec.ts +0 -151
|
@@ -1,78 +0,0 @@
|
|
|
1
|
-
import { test } from '@japa/runner'
|
|
2
|
-
import { AmfLoader } from '../AmfLoader.js'
|
|
3
|
-
import { AmfSerializer } from '../../../../src/amf/AmfSerializer.js'
|
|
4
|
-
import type { IAmfDocument, IAmfServer } from '../../../../src/amf/definitions/Amf.js'
|
|
5
|
-
import { AmfNamespace } from '../../../../src/amf/definitions/Namespace.js'
|
|
6
|
-
|
|
7
|
-
const loader = new AmfLoader()
|
|
8
|
-
let api: IAmfDocument
|
|
9
|
-
let serializer: AmfSerializer
|
|
10
|
-
let servers: IAmfServer[]
|
|
11
|
-
|
|
12
|
-
test.group('OAS 3', (group) => {
|
|
13
|
-
group.setup(async () => {
|
|
14
|
-
api = await loader.getGraph('oas-3-api')
|
|
15
|
-
serializer = new AmfSerializer(api)
|
|
16
|
-
servers = loader.lookupServers(api)!
|
|
17
|
-
})
|
|
18
|
-
|
|
19
|
-
test('returns a server object', ({ assert }) => {
|
|
20
|
-
const result = serializer.server(servers[3])
|
|
21
|
-
assert.typeOf(result, 'object', 'returns an object')
|
|
22
|
-
assert.include(result.types, AmfNamespace.aml.vocabularies.apiContract.Server, 'has the server type')
|
|
23
|
-
assert.typeOf(result.sourceMaps, 'object', 'has source maps')
|
|
24
|
-
})
|
|
25
|
-
|
|
26
|
-
test('has the id', ({ assert }) => {
|
|
27
|
-
const result = serializer.server(servers[3])
|
|
28
|
-
assert.typeOf(result.id, 'string')
|
|
29
|
-
})
|
|
30
|
-
|
|
31
|
-
test('has the url', ({ assert }) => {
|
|
32
|
-
const result = serializer.server(servers[3])
|
|
33
|
-
assert.equal(result.url, 'https://{username}.gigantic-server.com:{port}/{basePath}')
|
|
34
|
-
})
|
|
35
|
-
|
|
36
|
-
test('has the variables', ({ assert }) => {
|
|
37
|
-
const result = serializer.server(servers[3])
|
|
38
|
-
assert.typeOf(result.variables, 'array', 'has the variables property')
|
|
39
|
-
assert.lengthOf(result.variables, 3, 'has all variables')
|
|
40
|
-
const [v1] = result.variables
|
|
41
|
-
assert.typeOf(v1, 'object', 'the variable is an object')
|
|
42
|
-
assert.include(v1.types, AmfNamespace.aml.vocabularies.apiContract.Parameter, 'has the Parameter type')
|
|
43
|
-
})
|
|
44
|
-
|
|
45
|
-
test('has the description', ({ assert }) => {
|
|
46
|
-
const result = serializer.server(servers[1])
|
|
47
|
-
assert.equal(result.description, 'Staging server')
|
|
48
|
-
})
|
|
49
|
-
})
|
|
50
|
-
|
|
51
|
-
test.group('Async API', (group) => {
|
|
52
|
-
group.setup(async () => {
|
|
53
|
-
api = await loader.getGraph('async-api')
|
|
54
|
-
serializer = new AmfSerializer(api)
|
|
55
|
-
servers = loader.lookupServers(api)!
|
|
56
|
-
})
|
|
57
|
-
|
|
58
|
-
test('returns the server object', ({ assert }) => {
|
|
59
|
-
const result = serializer.server(servers[0])
|
|
60
|
-
assert.typeOf(result, 'object', 'returns an object')
|
|
61
|
-
assert.include(result.types, AmfNamespace.aml.vocabularies.apiContract.Server, 'has the server type')
|
|
62
|
-
assert.typeOf(result.sourceMaps, 'object', 'has source maps')
|
|
63
|
-
})
|
|
64
|
-
|
|
65
|
-
test('has the protocol info', ({ assert }) => {
|
|
66
|
-
const result = serializer.server(servers[0])
|
|
67
|
-
assert.equal(result.protocol, 'amqp', 'has the protocol')
|
|
68
|
-
assert.equal(result.protocolVersion, '1.0.0', 'has the protocolVersion')
|
|
69
|
-
})
|
|
70
|
-
|
|
71
|
-
test('has the security', ({ assert }) => {
|
|
72
|
-
const result = serializer.server(servers[0])
|
|
73
|
-
assert.typeOf(result.security, 'array', 'has the security')
|
|
74
|
-
assert.lengthOf(result.security!, 2, 'has all security')
|
|
75
|
-
const [security] = result.security!
|
|
76
|
-
assert.lengthOf(security.schemes, 1, 'has the security.schema')
|
|
77
|
-
})
|
|
78
|
-
})
|
|
@@ -1,304 +0,0 @@
|
|
|
1
|
-
import { test } from '@japa/runner'
|
|
2
|
-
import { AmfLoader } from '../AmfLoader.js'
|
|
3
|
-
import { AmfSerializer } from '../../../../src/amf/AmfSerializer.js'
|
|
4
|
-
import type { IAmfDocument } from '../../../../src/amf/definitions/Amf.js'
|
|
5
|
-
import type {
|
|
6
|
-
IApiArrayShape,
|
|
7
|
-
IApiFileShape,
|
|
8
|
-
IApiNodeShape,
|
|
9
|
-
IApiPropertyShape,
|
|
10
|
-
IApiRecursiveShape,
|
|
11
|
-
IApiScalarNode,
|
|
12
|
-
IApiScalarShape,
|
|
13
|
-
IApiSchemaShape,
|
|
14
|
-
IApiUnionShape,
|
|
15
|
-
} from '../../../../src/amf/definitions/Shapes.js'
|
|
16
|
-
import { AmfNamespace } from '../../../../src/amf/definitions/Namespace.js'
|
|
17
|
-
import { IApiCustomDomainProperty } from '../../../../src/amf/definitions/Base.js'
|
|
18
|
-
|
|
19
|
-
const loader = new AmfLoader()
|
|
20
|
-
|
|
21
|
-
test.group('RAML shapes', (group) => {
|
|
22
|
-
let api: IAmfDocument
|
|
23
|
-
let serializer: AmfSerializer
|
|
24
|
-
group.setup(async () => {
|
|
25
|
-
api = await loader.getGraph('amf-helper-api')
|
|
26
|
-
serializer = new AmfSerializer()
|
|
27
|
-
serializer.amf = api
|
|
28
|
-
})
|
|
29
|
-
|
|
30
|
-
test('processes an ArrayShape', ({ assert }) => {
|
|
31
|
-
const shape = loader.lookupDeclaredShape(api, 'Arrable')
|
|
32
|
-
const result = serializer.unknownShape(shape) as IApiArrayShape
|
|
33
|
-
assert.equal(result.id, shape['@id'], 'has the id')
|
|
34
|
-
assert.include(result.types, AmfNamespace.aml.vocabularies.shapes.ArrayShape, 'has the ArrayShape type')
|
|
35
|
-
assert.equal(result.name, 'Arrable', 'has the name')
|
|
36
|
-
assert.deepEqual(result.examples, [], 'has empty examples')
|
|
37
|
-
assert.deepEqual(result.values, [], 'has empty values')
|
|
38
|
-
assert.deepEqual(result.inherits, [], 'has empty inherits')
|
|
39
|
-
assert.deepEqual(result.or, [], 'has empty or')
|
|
40
|
-
assert.deepEqual(result.and, [], 'has empty and')
|
|
41
|
-
assert.deepEqual(result.xone, [], 'has empty xone')
|
|
42
|
-
assert.deepEqual(result.customDomainProperties, [], 'has empty customDomainProperties')
|
|
43
|
-
assert.typeOf(result.items, 'object', 'has the items')
|
|
44
|
-
assert.include(result.items!.types, AmfNamespace.w3.shacl.NodeShape, 'items has the NodeShape type')
|
|
45
|
-
assert.typeOf(result.sourceMaps, 'object', 'has source maps')
|
|
46
|
-
})
|
|
47
|
-
|
|
48
|
-
test('processes a NodeShape', ({ assert }) => {
|
|
49
|
-
const shape = loader.lookupDeclaredShape(api, 'AppPerson')
|
|
50
|
-
const result = serializer.unknownShape(shape) as IApiNodeShape
|
|
51
|
-
assert.equal(result.id, shape['@id'], 'has the id')
|
|
52
|
-
assert.include(result.types, AmfNamespace.w3.shacl.NodeShape, 'has the NodeShape type')
|
|
53
|
-
assert.equal(result.name, 'AppPerson', 'has the name')
|
|
54
|
-
assert.typeOf(result.description, 'string', 'has the description')
|
|
55
|
-
assert.lengthOf(result.examples, 1, 'has an example')
|
|
56
|
-
assert.include(
|
|
57
|
-
result.examples[0].types,
|
|
58
|
-
AmfNamespace.aml.vocabularies.apiContract.Example,
|
|
59
|
-
'example has the Example type'
|
|
60
|
-
)
|
|
61
|
-
assert.deepEqual(result.values, [], 'has empty values')
|
|
62
|
-
assert.deepEqual(result.inherits, [], 'has empty inherits')
|
|
63
|
-
assert.deepEqual(result.or, [], 'has empty or')
|
|
64
|
-
assert.deepEqual(result.and, [], 'has empty and')
|
|
65
|
-
assert.deepEqual(result.xone, [], 'has empty xone')
|
|
66
|
-
assert.deepEqual(result.customShapeProperties, [], 'has empty customShapeProperties')
|
|
67
|
-
assert.deepEqual(result.customShapePropertyDefinitions, [], 'has empty customShapePropertyDefinitions')
|
|
68
|
-
assert.deepEqual(result.dependencies, [], 'has empty dependencies')
|
|
69
|
-
assert.deepEqual(result.customDomainProperties, [], 'has empty customDomainProperties')
|
|
70
|
-
assert.isFalse(result.closed, 'has the closed')
|
|
71
|
-
assert.typeOf(result.properties, 'array', 'has the properties')
|
|
72
|
-
assert.isNotEmpty(result.properties, 'the properties is not empty')
|
|
73
|
-
assert.typeOf(result.sourceMaps, 'object', 'has source maps')
|
|
74
|
-
})
|
|
75
|
-
|
|
76
|
-
test('processes an UnionShape', ({ assert }) => {
|
|
77
|
-
const shape = loader.lookupDeclaredShape(api, 'Unionable')
|
|
78
|
-
const result = serializer.unknownShape(shape) as IApiUnionShape
|
|
79
|
-
assert.equal(result.id, shape['@id'], 'has the id')
|
|
80
|
-
assert.include(result.types, AmfNamespace.aml.vocabularies.shapes.UnionShape, 'has the NodeShape type')
|
|
81
|
-
assert.equal(result.name, 'Unionable', 'has the name')
|
|
82
|
-
assert.isUndefined(result.description, 'has no description')
|
|
83
|
-
assert.deepEqual(result.examples, [], 'has no examples')
|
|
84
|
-
assert.deepEqual(result.values, [], 'has empty values')
|
|
85
|
-
assert.deepEqual(result.inherits, [], 'has empty inherits')
|
|
86
|
-
assert.deepEqual(result.or, [], 'has empty or')
|
|
87
|
-
assert.deepEqual(result.and, [], 'has empty and')
|
|
88
|
-
assert.deepEqual(result.xone, [], 'has empty xone')
|
|
89
|
-
assert.deepEqual(result.customDomainProperties, [], 'has empty customDomainProperties')
|
|
90
|
-
assert.typeOf(result.anyOf, 'array', 'has the anyOf')
|
|
91
|
-
assert.lengthOf(result.anyOf, 2, 'has all anyOf')
|
|
92
|
-
assert.typeOf(result.sourceMaps, 'object', 'has source maps')
|
|
93
|
-
const [any1] = result.anyOf
|
|
94
|
-
assert.typeOf(any1.id, 'string', 'has the anyOf definition as Shape')
|
|
95
|
-
assert.typeOf(any1.sourceMaps, 'object', 'has source maps')
|
|
96
|
-
})
|
|
97
|
-
|
|
98
|
-
test('processes a ScalarShape', ({ assert }) => {
|
|
99
|
-
const shape = loader.lookupDeclaredShape(api, 'Feature')
|
|
100
|
-
const result = serializer.unknownShape(shape) as IApiScalarShape
|
|
101
|
-
assert.equal(result.id, shape['@id'], 'has the id')
|
|
102
|
-
assert.include(result.types, AmfNamespace.aml.vocabularies.shapes.ScalarShape, 'has the NodeShape type')
|
|
103
|
-
assert.equal(result.name, 'Feature', 'has the name')
|
|
104
|
-
assert.typeOf(result.description, 'string', 'has the description')
|
|
105
|
-
assert.deepEqual(result.examples, [], 'has no examples')
|
|
106
|
-
assert.deepEqual(result.inherits, [], 'has empty inherits')
|
|
107
|
-
assert.deepEqual(result.or, [], 'has empty or')
|
|
108
|
-
assert.deepEqual(result.and, [], 'has empty and')
|
|
109
|
-
assert.deepEqual(result.xone, [], 'has empty xone')
|
|
110
|
-
assert.deepEqual(result.customDomainProperties, [], 'has empty customDomainProperties')
|
|
111
|
-
assert.equal(result.dataType, 'http://www.w3.org/2001/XMLSchema#string', 'has the dataType')
|
|
112
|
-
assert.lengthOf(result.values, 3, 'has the values set')
|
|
113
|
-
assert.typeOf(result.sourceMaps, 'object', 'has source maps')
|
|
114
|
-
})
|
|
115
|
-
|
|
116
|
-
test('processes a ScalarShape with enum values', ({ assert }) => {
|
|
117
|
-
const shape = loader.lookupDeclaredShape(api, 'Feature')
|
|
118
|
-
const result = serializer.unknownShape(shape) as IApiScalarShape
|
|
119
|
-
const [v1, v2, v3] = result.values as IApiScalarNode[]
|
|
120
|
-
assert.include(v1.types, AmfNamespace.aml.vocabularies.data.Scalar, 'v1 has the type')
|
|
121
|
-
assert.include(v2.types, AmfNamespace.aml.vocabularies.data.Scalar, 'v2 has the type')
|
|
122
|
-
assert.include(v3.types, AmfNamespace.aml.vocabularies.data.Scalar, 'v3 has the type')
|
|
123
|
-
assert.equal(v1.name, 'scalar_1', 'v1 has the name')
|
|
124
|
-
assert.equal(v2.name, 'scalar_2', 'v2 has the name')
|
|
125
|
-
assert.equal(v3.name, 'scalar_3', 'v3 has the name')
|
|
126
|
-
assert.equal(v1.value, 'A', 'v1 has the value')
|
|
127
|
-
assert.equal(v2.value, 'B', 'v2 has the value')
|
|
128
|
-
assert.equal(v3.value, 'C', 'v3 has the value')
|
|
129
|
-
assert.equal(v1.dataType, AmfNamespace.w3.xmlSchema.string, 'v1 has the dataType')
|
|
130
|
-
assert.equal(v2.dataType, AmfNamespace.w3.xmlSchema.string, 'v2 has the dataType')
|
|
131
|
-
assert.equal(v3.dataType, AmfNamespace.w3.xmlSchema.string, 'v3 has the dataType')
|
|
132
|
-
assert.typeOf(result.sourceMaps, 'object', 'has source maps')
|
|
133
|
-
})
|
|
134
|
-
|
|
135
|
-
test('processes a FileShape with enum values', ({ assert }) => {
|
|
136
|
-
const shape = loader.lookupDeclaredShape(api, 'MaFile')
|
|
137
|
-
const result = serializer.unknownShape(shape) as IApiFileShape
|
|
138
|
-
|
|
139
|
-
assert.equal(result.id, shape['@id'], 'has the id')
|
|
140
|
-
assert.include(result.types, AmfNamespace.aml.vocabularies.shapes.FileShape, 'has the FileShape type')
|
|
141
|
-
assert.equal(result.name, 'MaFile', 'has the name')
|
|
142
|
-
assert.typeOf(result.description, 'string', 'has the description')
|
|
143
|
-
assert.deepEqual(result.examples, [], 'has no examples')
|
|
144
|
-
assert.deepEqual(result.inherits, [], 'has empty inherits')
|
|
145
|
-
assert.deepEqual(result.or, [], 'has empty or')
|
|
146
|
-
assert.deepEqual(result.and, [], 'has empty and')
|
|
147
|
-
assert.deepEqual(result.xone, [], 'has empty xone')
|
|
148
|
-
assert.deepEqual(result.values, [], 'has empty values')
|
|
149
|
-
assert.deepEqual(result.customDomainProperties, [], 'has empty customDomainProperties')
|
|
150
|
-
assert.deepEqual(result.fileTypes, ['image/png', 'image/jpeg', 'image/jpg', 'image/gif'], 'has the fileTypes')
|
|
151
|
-
assert.equal(result.minLength, 1, 'has the minLength set')
|
|
152
|
-
assert.equal(result.maxLength, 10, 'has the maxLength set')
|
|
153
|
-
assert.typeOf(result.sourceMaps, 'object', 'has source maps')
|
|
154
|
-
})
|
|
155
|
-
|
|
156
|
-
test('processes a RecursiveShape', ({ assert }) => {
|
|
157
|
-
const shape = loader.lookupDeclaredShape(api, 'RecursiveShape')
|
|
158
|
-
const result = serializer.unknownShape(shape) as IApiNodeShape
|
|
159
|
-
// AMF moved the recursive shape to properties. When they reverse that then restore the previous "item".
|
|
160
|
-
const item = ((result.properties[1].range as IApiNodeShape).properties[1] as IApiPropertyShape)
|
|
161
|
-
.range as IApiRecursiveShape
|
|
162
|
-
// const item = (result.properties[1].range) as IApiRecursiveShape;
|
|
163
|
-
assert.typeOf(item.id, 'string', 'has the id')
|
|
164
|
-
assert.include(item.types, AmfNamespace.aml.vocabularies.shapes.RecursiveShape, 'has the RecursiveShape type')
|
|
165
|
-
assert.equal(item.name, 'relatedTo', 'has the name')
|
|
166
|
-
// assert.typeOf(item.description, 'string', 'has the description');
|
|
167
|
-
assert.deepEqual(item.inherits, [], 'has empty inherits')
|
|
168
|
-
assert.deepEqual(item.or, [], 'has empty or')
|
|
169
|
-
assert.deepEqual(item.and, [], 'has empty and')
|
|
170
|
-
assert.deepEqual(item.xone, [], 'has empty xone')
|
|
171
|
-
assert.deepEqual(item.values, [], 'has empty values')
|
|
172
|
-
assert.deepEqual(item.customDomainProperties, [], 'has empty customDomainProperties')
|
|
173
|
-
assert.typeOf(item.fixPoint, 'string', 'has the fixPoint')
|
|
174
|
-
})
|
|
175
|
-
|
|
176
|
-
test('processes a custom domain properties', ({ assert }) => {
|
|
177
|
-
const shape = loader.lookupDeclaredShape(api, 'RecursiveShape')
|
|
178
|
-
const result = serializer.unknownShape(shape) as IApiNodeShape
|
|
179
|
-
const cdp = result.customDomainProperties as IApiCustomDomainProperty[]
|
|
180
|
-
assert.typeOf(cdp, 'array', 'has the properties')
|
|
181
|
-
assert.lengthOf(cdp, 1, 'has a single property')
|
|
182
|
-
const [item] = cdp
|
|
183
|
-
assert.typeOf(item.id, 'string', 'has the id')
|
|
184
|
-
assert.include(item.extension.types, AmfNamespace.aml.vocabularies.data.Scalar, 'has the Scalar type')
|
|
185
|
-
assert.equal(item.name, 'deprecated', 'has the extensionName')
|
|
186
|
-
// @ts-expect-error Used in testing
|
|
187
|
-
assert.typeOf(item.extension.value, 'string', 'has the value')
|
|
188
|
-
})
|
|
189
|
-
|
|
190
|
-
test('processes a SchemaShape', ({ assert }) => {
|
|
191
|
-
const expects = loader.lookupExpects(api, '/xml', 'post')
|
|
192
|
-
// @ts-expect-error Used in testing
|
|
193
|
-
const payload = expects[loader._getAmfKey(AmfNamespace.aml.vocabularies.apiContract.payload)][0]
|
|
194
|
-
const shape = payload[serializer._getAmfKey(AmfNamespace.aml.vocabularies.shapes.schema)][0]
|
|
195
|
-
const result = serializer.unknownShape(shape) as IApiSchemaShape
|
|
196
|
-
assert.equal(result.mediaType, 'application/xml', 'has media type')
|
|
197
|
-
assert.typeOf(result.raw, 'string', 'has raw')
|
|
198
|
-
assert.typeOf(result.examples, 'array', 'has examples')
|
|
199
|
-
|
|
200
|
-
// serializer recognizes that the this example is referenced to a payload and not to a type.
|
|
201
|
-
assert.lengthOf(result.examples, 0, 'has no examples')
|
|
202
|
-
})
|
|
203
|
-
|
|
204
|
-
//
|
|
205
|
-
// AMF resolvers links in the Editing pipeline. this probably can be removed.
|
|
206
|
-
//
|
|
207
|
-
test('resolves links', ({ assert }) => {
|
|
208
|
-
// takes any operation that has a link-target in the shape
|
|
209
|
-
const expects = loader.lookupExpects(api, '/files/{fileId}/comments', 'post')
|
|
210
|
-
// @ts-expect-error Used in testing
|
|
211
|
-
const payload = expects[loader._getAmfKey(AmfNamespace.aml.vocabularies.apiContract.payload)][0]
|
|
212
|
-
const shape = payload[serializer._getAmfKey(AmfNamespace.aml.vocabularies.shapes.schema)][0]
|
|
213
|
-
const result = serializer.unknownShape(shape) as IApiNodeShape
|
|
214
|
-
assert.equal(result.linkLabel, 'CommentWritable', 'has linkLabel')
|
|
215
|
-
assert.typeOf(result.examples, 'array', 'has examples')
|
|
216
|
-
|
|
217
|
-
// serializer recognizes that the this example is referenced to a payload and not to a type.
|
|
218
|
-
assert.lengthOf(result.examples, 0, 'has single examples')
|
|
219
|
-
}).skip()
|
|
220
|
-
})
|
|
221
|
-
|
|
222
|
-
test.group('OAS shapes', (group) => {
|
|
223
|
-
let api: IAmfDocument
|
|
224
|
-
let serializer: AmfSerializer
|
|
225
|
-
group.setup(async () => {
|
|
226
|
-
api = await loader.getGraph('petstore')
|
|
227
|
-
serializer = new AmfSerializer()
|
|
228
|
-
serializer.amf = api
|
|
229
|
-
})
|
|
230
|
-
|
|
231
|
-
test('processes the oneOf shape (xone)', ({ assert }) => {
|
|
232
|
-
const expects = loader.lookupExpects(api, '/unions', 'patch')
|
|
233
|
-
// @ts-expect-error Used in testing
|
|
234
|
-
const payload = expects[serializer._getAmfKey(AmfNamespace.aml.vocabularies.apiContract.payload)][0]
|
|
235
|
-
const schema = payload[serializer._getAmfKey(AmfNamespace.aml.vocabularies.shapes.schema)][0]
|
|
236
|
-
const result = serializer.unknownShape(schema)
|
|
237
|
-
// Not sure why is this "any" shape.
|
|
238
|
-
assert.include(result.types, AmfNamespace.aml.vocabularies.shapes.AnyShape, 'has the AnyShape type')
|
|
239
|
-
assert.deepEqual(result.or, [], 'has empty or')
|
|
240
|
-
assert.deepEqual(result.and, [], 'has empty and')
|
|
241
|
-
assert.deepEqual(result.values, [], 'has empty values')
|
|
242
|
-
assert.lengthOf(result.xone, 2, 'has the xone array')
|
|
243
|
-
assert.typeOf(result.sourceMaps, 'object', 'has source maps')
|
|
244
|
-
})
|
|
245
|
-
|
|
246
|
-
test('processes the allOf shape (and)', ({ assert }) => {
|
|
247
|
-
const expects = loader.lookupExpects(api, '/unions', 'post')
|
|
248
|
-
// @ts-expect-error Used in testing
|
|
249
|
-
const payload = expects[serializer._getAmfKey(AmfNamespace.aml.vocabularies.apiContract.payload)][0]
|
|
250
|
-
const schema = payload[serializer._getAmfKey(AmfNamespace.aml.vocabularies.shapes.schema)][0]
|
|
251
|
-
const result = serializer.unknownShape(schema)
|
|
252
|
-
assert.include(result.types, AmfNamespace.w3.shacl.NodeShape, 'has the NodeShape type')
|
|
253
|
-
assert.deepEqual(result.or, [], 'has empty or')
|
|
254
|
-
assert.deepEqual(result.xone, [], 'has empty xone')
|
|
255
|
-
assert.deepEqual(result.values, [], 'has empty values')
|
|
256
|
-
assert.lengthOf(result.and, 2, 'has the and array')
|
|
257
|
-
})
|
|
258
|
-
|
|
259
|
-
test('processes the anyOf shape (or)', ({ assert }) => {
|
|
260
|
-
const returns = loader.lookupReturns(api, '/pet/listCommon', 'get')
|
|
261
|
-
// @ts-expect-error Used in testing
|
|
262
|
-
const payload = returns[0][serializer._getAmfKey(AmfNamespace.aml.vocabularies.apiContract.payload)][0]
|
|
263
|
-
const schema = payload[serializer._getAmfKey(AmfNamespace.aml.vocabularies.shapes.schema)][0]
|
|
264
|
-
const result = serializer.unknownShape(schema) as IApiArrayShape
|
|
265
|
-
const type = result.items!
|
|
266
|
-
// Not sure why is this "any" shape.
|
|
267
|
-
assert.include(type.types, AmfNamespace.aml.vocabularies.shapes.AnyShape, 'has the AnyShape type')
|
|
268
|
-
assert.deepEqual(type.and, [], 'has empty and')
|
|
269
|
-
assert.deepEqual(type.xone, [], 'has empty xone')
|
|
270
|
-
assert.deepEqual(type.values, [], 'has empty values')
|
|
271
|
-
assert.lengthOf(type.or, 3, 'has the or array')
|
|
272
|
-
})
|
|
273
|
-
|
|
274
|
-
test('reads the discriminator value', ({ assert }) => {
|
|
275
|
-
const shape = loader.lookupDeclaredShape(api, 'Pet')
|
|
276
|
-
const result = serializer.unknownShape(shape) as IApiNodeShape
|
|
277
|
-
assert.equal(result.discriminator, 'petType')
|
|
278
|
-
})
|
|
279
|
-
|
|
280
|
-
test('reads the xmlSerialization value', ({ assert }) => {
|
|
281
|
-
const shape = loader.lookupDeclaredShape(api, 'Pet')
|
|
282
|
-
const result = serializer.unknownShape(shape) as IApiNodeShape
|
|
283
|
-
assert.typeOf(result.xmlSerialization, 'object', 'has the xmlSerialization')
|
|
284
|
-
const xml = result.xmlSerialization
|
|
285
|
-
assert.include(xml.types, AmfNamespace.aml.vocabularies.shapes.XMLSerializer, 'has the XMLSerializer type')
|
|
286
|
-
assert.deepEqual(xml.customDomainProperties, [], 'has empty customDomainProperties')
|
|
287
|
-
assert.isFalse(xml.attribute, 'has the attribute')
|
|
288
|
-
assert.isFalse(xml.wrapped, 'has the wrapped')
|
|
289
|
-
assert.equal(xml.name, 'pet', 'has the name')
|
|
290
|
-
})
|
|
291
|
-
|
|
292
|
-
test('reads the customDomainProperties value', ({ assert }) => {
|
|
293
|
-
const shape = loader.lookupDeclaredShape(api, 'Pet')
|
|
294
|
-
const result = serializer.unknownShape(shape) as IApiNodeShape
|
|
295
|
-
assert.lengthOf(result.customDomainProperties, 1, 'has the customDomainProperties')
|
|
296
|
-
const [cdp] = result.customDomainProperties
|
|
297
|
-
assert.equal(cdp.name, 'swagger-router-model', 'has the name')
|
|
298
|
-
const typed = cdp.extension as IApiScalarNode
|
|
299
|
-
assert.include(typed.types, AmfNamespace.aml.vocabularies.data.Scalar, 'has the Scalar type')
|
|
300
|
-
assert.deepEqual(typed.customDomainProperties, [], 'has empty customDomainProperties')
|
|
301
|
-
assert.equal(typed.dataType, AmfNamespace.w3.xmlSchema.string, 'has the dataType')
|
|
302
|
-
assert.equal(typed.value, 'io.swagger.petstore.model.Pet', 'has the value')
|
|
303
|
-
})
|
|
304
|
-
})
|
|
@@ -1,52 +0,0 @@
|
|
|
1
|
-
import { test } from '@japa/runner'
|
|
2
|
-
import { AmfLoader } from '../AmfLoader.js'
|
|
3
|
-
import { AmfSerializer } from '../../../../src/amf/AmfSerializer.js'
|
|
4
|
-
import { IAmfDocument } from '../../../../src/amf/definitions/Amf.js'
|
|
5
|
-
import { AmfNamespace } from '../../../../src/amf/definitions/Namespace.js'
|
|
6
|
-
|
|
7
|
-
test.group('Source maps', (group) => {
|
|
8
|
-
const loader = new AmfLoader()
|
|
9
|
-
const jsonMime = 'application/json'
|
|
10
|
-
// const xmlMime = 'application/xml';
|
|
11
|
-
|
|
12
|
-
let api: IAmfDocument
|
|
13
|
-
let serializer: AmfSerializer
|
|
14
|
-
group.setup(async () => {
|
|
15
|
-
api = await loader.getGraph('amf-helper-api')
|
|
16
|
-
serializer = new AmfSerializer(api)
|
|
17
|
-
})
|
|
18
|
-
|
|
19
|
-
test('adds parsedJsonSchema', ({ assert }) => {
|
|
20
|
-
const shape = loader.lookupRequestPayload(api, '/json', 'post', jsonMime)
|
|
21
|
-
// @ts-expect-error Used in testing
|
|
22
|
-
let schema = shape[serializer._getAmfKey(AmfNamespace.aml.vocabularies.shapes.schema)]
|
|
23
|
-
if (Array.isArray(schema)) {
|
|
24
|
-
;[schema] = schema
|
|
25
|
-
}
|
|
26
|
-
const result = serializer.unknownShape(schema)
|
|
27
|
-
|
|
28
|
-
const { parsedJsonSchema } = result.sourceMaps!
|
|
29
|
-
assert.typeOf(parsedJsonSchema, 'object', 'has parsedJsonSchema')
|
|
30
|
-
assert.typeOf(parsedJsonSchema!.id, 'string', 'has the id')
|
|
31
|
-
assert.typeOf(parsedJsonSchema!.element, 'string', 'has the element')
|
|
32
|
-
assert.typeOf(parsedJsonSchema!.value, 'string', 'has the value')
|
|
33
|
-
})
|
|
34
|
-
|
|
35
|
-
test('adds autoGeneratedName', ({ assert }) => {
|
|
36
|
-
const shape = loader.lookupRequestPayload(api, '/json', 'post', jsonMime)
|
|
37
|
-
// @ts-expect-error Used in testing
|
|
38
|
-
let schema = shape[serializer._getAmfKey(AmfNamespace.aml.vocabularies.shapes.schema)]
|
|
39
|
-
if (Array.isArray(schema)) {
|
|
40
|
-
;[schema] = schema
|
|
41
|
-
}
|
|
42
|
-
const result = serializer.unknownShape(schema)
|
|
43
|
-
|
|
44
|
-
const { autoGeneratedName } = result.sourceMaps!
|
|
45
|
-
assert.typeOf(autoGeneratedName, 'array', 'has autoGeneratedName array')
|
|
46
|
-
|
|
47
|
-
const [item] = autoGeneratedName!
|
|
48
|
-
assert.typeOf(item.id, 'string', 'has the id')
|
|
49
|
-
assert.typeOf(item.element, 'string', 'has the element')
|
|
50
|
-
assert.typeOf(item.value, 'string', 'has the value')
|
|
51
|
-
})
|
|
52
|
-
})
|
|
@@ -1,28 +0,0 @@
|
|
|
1
|
-
import { test } from '@japa/runner'
|
|
2
|
-
import { normalizeXmlTagName } from '../../../../src/amf/shape/ShapeXmlSchemaGenerator.js'
|
|
3
|
-
|
|
4
|
-
test.group('normalizeXmlTagName()', () => {
|
|
5
|
-
test('removes prohibited characters', ({ assert }) => {
|
|
6
|
-
const name = 'a & b = c?'
|
|
7
|
-
const result = normalizeXmlTagName(name)
|
|
8
|
-
assert.equal(result, 'abc')
|
|
9
|
-
})
|
|
10
|
-
|
|
11
|
-
test('keeps hyphen characters', ({ assert }) => {
|
|
12
|
-
const name = 'a-&-b =-c?'
|
|
13
|
-
const result = normalizeXmlTagName(name)
|
|
14
|
-
assert.equal(result, 'a--b-c')
|
|
15
|
-
})
|
|
16
|
-
|
|
17
|
-
test('keeps underscore characters', ({ assert }) => {
|
|
18
|
-
const name = 'a_&_b =_c?'
|
|
19
|
-
const result = normalizeXmlTagName(name)
|
|
20
|
-
assert.equal(result, 'a__b_c')
|
|
21
|
-
})
|
|
22
|
-
|
|
23
|
-
test('keeps dot characters', ({ assert }) => {
|
|
24
|
-
const name = 'a.&.b =.c?'
|
|
25
|
-
const result = normalizeXmlTagName(name)
|
|
26
|
-
assert.equal(result, 'a..b.c')
|
|
27
|
-
})
|
|
28
|
-
})
|
|
@@ -1,90 +0,0 @@
|
|
|
1
|
-
import { test } from '@japa/runner'
|
|
2
|
-
import { ApiSchemaGenerator } from '../../../src/amf/ApiSchemaGenerator.js'
|
|
3
|
-
import { IAmfDocument } from '../../../src/amf/definitions/Amf.js'
|
|
4
|
-
import { IApiAnyShape } from '../../../src/amf/definitions/Shapes.js'
|
|
5
|
-
import { AmfLoader } from './AmfLoader.js'
|
|
6
|
-
|
|
7
|
-
test.group('Tracked examples', (group) => {
|
|
8
|
-
const loader = new AmfLoader()
|
|
9
|
-
const jsonMime = 'application/json'
|
|
10
|
-
const xmlMime = 'application/xml'
|
|
11
|
-
let model: IAmfDocument
|
|
12
|
-
|
|
13
|
-
group.setup(async () => {
|
|
14
|
-
model = await loader.getGraph('tracked-to-linked')
|
|
15
|
-
})
|
|
16
|
-
|
|
17
|
-
test('basic formatting and type name', ({ assert }) => {
|
|
18
|
-
const payload = loader.getPayloads(model, '/employees', 'get')[0]
|
|
19
|
-
|
|
20
|
-
const anyShape = payload.schema as IApiAnyShape
|
|
21
|
-
const result = ApiSchemaGenerator.asExample(anyShape, jsonMime, {
|
|
22
|
-
renderExamples: true,
|
|
23
|
-
renderOptional: true,
|
|
24
|
-
})!
|
|
25
|
-
|
|
26
|
-
assert.equal(result.value, '-\n id: 1\n name: John\n-\n id: 2\n name: Sam', "Example's raw is set")
|
|
27
|
-
|
|
28
|
-
const parsed = JSON.parse(result.renderValue as string)
|
|
29
|
-
|
|
30
|
-
assert.typeOf(parsed, 'array', 'represents an array')
|
|
31
|
-
assert.lengthOf(parsed, 2, 'has 2 items')
|
|
32
|
-
|
|
33
|
-
const [e1, e2] = parsed
|
|
34
|
-
assert.equal(e1.id, 1, 'has the example1.id')
|
|
35
|
-
assert.equal(e1.name, 'John', 'has the example1.name')
|
|
36
|
-
assert.equal(e2.id, 2, 'has the example2.id')
|
|
37
|
-
assert.equal(e2.name, 'Sam', 'has the example2.name')
|
|
38
|
-
})
|
|
39
|
-
|
|
40
|
-
test('generates example for POST', ({ assert }) => {
|
|
41
|
-
const payload = loader.getPayloads(model, '/employees', 'post')[0]
|
|
42
|
-
|
|
43
|
-
const anyShape = payload.schema as IApiAnyShape
|
|
44
|
-
const result = ApiSchemaGenerator.asExample(anyShape, jsonMime, {
|
|
45
|
-
renderExamples: true,
|
|
46
|
-
renderOptional: true,
|
|
47
|
-
})!
|
|
48
|
-
|
|
49
|
-
assert.equal(result.value, 'id: 1\nname: "John"', "Example's raw is set")
|
|
50
|
-
|
|
51
|
-
const parsed = JSON.parse(result.renderValue as string)
|
|
52
|
-
|
|
53
|
-
assert.deepEqual(parsed, {
|
|
54
|
-
id: 1,
|
|
55
|
-
name: 'John',
|
|
56
|
-
})
|
|
57
|
-
})
|
|
58
|
-
|
|
59
|
-
test('generates example for DELETE', ({ assert }) => {
|
|
60
|
-
const payload = loader.getPayloads(model, '/employees', 'delete')[0]
|
|
61
|
-
|
|
62
|
-
const anyShape = payload.schema as IApiAnyShape
|
|
63
|
-
const result = ApiSchemaGenerator.asExample(anyShape, jsonMime, {
|
|
64
|
-
renderExamples: true,
|
|
65
|
-
renderOptional: true,
|
|
66
|
-
})!
|
|
67
|
-
|
|
68
|
-
assert.equal(result.value, 'id: 1\nname: "John"', "Example's raw is set")
|
|
69
|
-
|
|
70
|
-
const parsed = JSON.parse(result.renderValue as string)
|
|
71
|
-
|
|
72
|
-
assert.deepEqual(parsed, {
|
|
73
|
-
id: 1,
|
|
74
|
-
name: 'John',
|
|
75
|
-
})
|
|
76
|
-
})
|
|
77
|
-
|
|
78
|
-
test('generates example for HEAD', ({ assert }) => {
|
|
79
|
-
const payload = loader.getPayloads(model, '/employees', 'head')[0]
|
|
80
|
-
|
|
81
|
-
const anyShape = payload.schema as IApiAnyShape
|
|
82
|
-
const result = ApiSchemaGenerator.asExample(anyShape, xmlMime, {
|
|
83
|
-
renderExamples: true,
|
|
84
|
-
renderOptional: true,
|
|
85
|
-
})!
|
|
86
|
-
|
|
87
|
-
assert.equal(result.value, 'id: 1\nname: "John"', "Example's raw is set")
|
|
88
|
-
assert.equal(result.renderValue, '<Employee>\n <id>1</id>\n <name>John</name>\n</Employee>\n')
|
|
89
|
-
})
|
|
90
|
-
})
|