@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,250 +0,0 @@
|
|
|
1
|
-
import { test } from '@japa/runner'
|
|
2
|
-
import { DOMParser } from '@xmldom/xmldom'
|
|
3
|
-
import { AmfNamespace as ns } from '../../../src/amf/definitions/Namespace.js'
|
|
4
|
-
import { ApiExampleGenerator } from '../../../src/amf/ApiExampleGenerator.js'
|
|
5
|
-
import { AmfLoader } from './AmfLoader.js'
|
|
6
|
-
import { IAmfDocument } from '../../../src/amf/definitions/Amf.js'
|
|
7
|
-
import { IApiAnyShape, IApiDataExample } from '../../../src/amf/definitions/Shapes.js'
|
|
8
|
-
|
|
9
|
-
const loader = new AmfLoader()
|
|
10
|
-
const jsonMime = 'application/json'
|
|
11
|
-
const xmlMime = 'application/xml'
|
|
12
|
-
const urlEncodedMime = 'application/x-www-form-urlencoded'
|
|
13
|
-
|
|
14
|
-
test.group(jsonMime, (group) => {
|
|
15
|
-
let reader: ApiExampleGenerator
|
|
16
|
-
let model: IAmfDocument
|
|
17
|
-
|
|
18
|
-
group.setup(async () => {
|
|
19
|
-
model = await loader.getGraph('schema-api')
|
|
20
|
-
reader = new ApiExampleGenerator()
|
|
21
|
-
})
|
|
22
|
-
|
|
23
|
-
test('returns null when no value and no structured value', ({ assert }) => {
|
|
24
|
-
const example: IApiDataExample = {
|
|
25
|
-
id: '',
|
|
26
|
-
strict: true,
|
|
27
|
-
types: [ns.aml.vocabularies.document.NamedExamples],
|
|
28
|
-
customDomainProperties: [],
|
|
29
|
-
}
|
|
30
|
-
const result = reader.read(example, jsonMime)
|
|
31
|
-
assert.isUndefined(result)
|
|
32
|
-
})
|
|
33
|
-
|
|
34
|
-
test('returns the value when no mime type', ({ assert }) => {
|
|
35
|
-
const example: IApiDataExample = {
|
|
36
|
-
id: '',
|
|
37
|
-
strict: true,
|
|
38
|
-
types: [ns.aml.vocabularies.document.NamedExamples],
|
|
39
|
-
value: 'test',
|
|
40
|
-
customDomainProperties: [],
|
|
41
|
-
}
|
|
42
|
-
const result = reader.read(example)
|
|
43
|
-
assert.strictEqual(result, 'test')
|
|
44
|
-
})
|
|
45
|
-
|
|
46
|
-
test('returns the value when corresponds to the mime type', ({ assert }) => {
|
|
47
|
-
const example: IApiDataExample = {
|
|
48
|
-
id: '',
|
|
49
|
-
strict: true,
|
|
50
|
-
types: [ns.aml.vocabularies.document.NamedExamples],
|
|
51
|
-
value: '[]',
|
|
52
|
-
customDomainProperties: [],
|
|
53
|
-
}
|
|
54
|
-
const result = reader.read(example, jsonMime)
|
|
55
|
-
assert.strictEqual(result, '[]')
|
|
56
|
-
})
|
|
57
|
-
|
|
58
|
-
test('reads a number scalar value', ({ assert }) => {
|
|
59
|
-
const shape = loader.getShape(model, 'ScalarNumberWithExample') as IApiAnyShape
|
|
60
|
-
const result = reader.read(shape.examples[0], jsonMime)
|
|
61
|
-
assert.strictEqual(result, '24')
|
|
62
|
-
})
|
|
63
|
-
|
|
64
|
-
test('reads a string array value', async ({ assert }) => {
|
|
65
|
-
const shape = loader.getShape(model, 'StringArrayExample') as IApiAnyShape
|
|
66
|
-
const result = reader.read(shape.examples[0], jsonMime) as string
|
|
67
|
-
const parsed = JSON.parse(result)
|
|
68
|
-
assert.deepEqual(parsed, ['test', 'other'])
|
|
69
|
-
})
|
|
70
|
-
|
|
71
|
-
test('reads a number array value', async ({ assert }) => {
|
|
72
|
-
const shape = loader.getShape(model, 'NumberArrayExample') as IApiAnyShape
|
|
73
|
-
const result = reader.read(shape.examples[0], jsonMime) as string
|
|
74
|
-
const parsed = JSON.parse(result)
|
|
75
|
-
assert.deepEqual(parsed, [1, 2])
|
|
76
|
-
})
|
|
77
|
-
|
|
78
|
-
test('reads a complex value value', async ({ assert }) => {
|
|
79
|
-
const shape = loader.getShape(model, 'ScalarObjectUnionExample') as IApiAnyShape
|
|
80
|
-
const result = reader.read(shape.examples[0], jsonMime) as string
|
|
81
|
-
const parsed = JSON.parse(result)
|
|
82
|
-
assert.strictEqual(parsed.name, 'Pawel Uchida-Psztyc', 'has example.name')
|
|
83
|
-
assert.strictEqual(parsed.id, '128a654bc54d898e43f', 'has example.id')
|
|
84
|
-
assert.strictEqual(parsed.age, 30, 'has example.age')
|
|
85
|
-
assert.strictEqual(parsed.sex, 'male', 'has example.sex')
|
|
86
|
-
assert.strictEqual(parsed.newsletter, false, 'has example.newsletter')
|
|
87
|
-
assert.strictEqual(parsed.tosAccepted, true, 'has example.tosAccepted')
|
|
88
|
-
})
|
|
89
|
-
})
|
|
90
|
-
|
|
91
|
-
test.group(xmlMime, (group) => {
|
|
92
|
-
let reader: ApiExampleGenerator
|
|
93
|
-
let model: IAmfDocument
|
|
94
|
-
|
|
95
|
-
group.setup(async () => {
|
|
96
|
-
model = await loader.getGraph('schema-api')
|
|
97
|
-
reader = new ApiExampleGenerator()
|
|
98
|
-
})
|
|
99
|
-
|
|
100
|
-
test('returns the value when corresponds to the mime type', ({ assert }) => {
|
|
101
|
-
const example: IApiDataExample = {
|
|
102
|
-
id: '',
|
|
103
|
-
strict: true,
|
|
104
|
-
types: [ns.aml.vocabularies.document.NamedExamples],
|
|
105
|
-
value: '<feed></feed>',
|
|
106
|
-
customDomainProperties: [],
|
|
107
|
-
}
|
|
108
|
-
const result = reader.read(example, xmlMime)
|
|
109
|
-
assert.strictEqual(result, '<feed></feed>')
|
|
110
|
-
})
|
|
111
|
-
|
|
112
|
-
test('reads a number scalar value', async ({ assert }) => {
|
|
113
|
-
const shape = loader.getShape(model, 'ScalarNumberWithExample') as IApiAnyShape
|
|
114
|
-
const result = reader.read(shape.examples[0], xmlMime, shape)
|
|
115
|
-
assert.strictEqual(result, '<ScalarNumberWithExample>24</ScalarNumberWithExample>\n')
|
|
116
|
-
})
|
|
117
|
-
|
|
118
|
-
test('reads a string array value', async ({ assert }) => {
|
|
119
|
-
const shape = loader.getShape(model, 'StringArrayExample') as IApiAnyShape
|
|
120
|
-
const result = reader.read(shape.examples[0], xmlMime, shape)
|
|
121
|
-
|
|
122
|
-
const parser = new DOMParser()
|
|
123
|
-
const schema = parser.parseFromString(`<root>${result}</root>`, xmlMime)
|
|
124
|
-
|
|
125
|
-
const nodes = schema.getElementsByTagName('StringArrayExample')
|
|
126
|
-
assert.lengthOf(nodes, 2, 'has both example values')
|
|
127
|
-
assert.equal((nodes[0].textContent as string).trim(), 'test', 'has first example value')
|
|
128
|
-
assert.equal((nodes[1].textContent as string).trim(), 'other', 'has second example value')
|
|
129
|
-
})
|
|
130
|
-
|
|
131
|
-
test('reads an object array value', async ({ assert }) => {
|
|
132
|
-
const shape = loader.getShape(model, 'XmlArrayExample') as IApiAnyShape
|
|
133
|
-
const result = reader.read(shape.examples[0], xmlMime, shape) as string
|
|
134
|
-
|
|
135
|
-
const parser = new DOMParser()
|
|
136
|
-
const schema = parser.parseFromString(result, xmlMime)
|
|
137
|
-
|
|
138
|
-
const root = schema.getElementsByTagName('XmlArrayExample')[0]
|
|
139
|
-
assert.ok(root, 'has the root node')
|
|
140
|
-
const street = root.getElementsByTagName('street')[0]
|
|
141
|
-
const city = root.getElementsByTagName('city')[0]
|
|
142
|
-
assert.ok(street, 'has the street node')
|
|
143
|
-
assert.ok(city, 'has the city node')
|
|
144
|
-
assert.equal((street.textContent as string).trim(), '1234 Market street')
|
|
145
|
-
assert.equal((city.textContent as string).trim(), 'San Francisco')
|
|
146
|
-
})
|
|
147
|
-
|
|
148
|
-
test('reads a number array value', async ({ assert }) => {
|
|
149
|
-
const shape = loader.getShape(model, 'NumberArrayExample') as IApiAnyShape
|
|
150
|
-
const result = reader.read(shape.examples[0], xmlMime, shape)
|
|
151
|
-
|
|
152
|
-
const parser = new DOMParser()
|
|
153
|
-
const schema = parser.parseFromString(`<root>${result}</root>`, xmlMime)
|
|
154
|
-
|
|
155
|
-
const nodes = schema.getElementsByTagName('NumberArrayExample')
|
|
156
|
-
assert.lengthOf(nodes, 2, 'has both example values')
|
|
157
|
-
assert.equal((nodes[0].textContent as string).trim(), '1', 'has first example value')
|
|
158
|
-
assert.equal((nodes[1].textContent as string).trim(), '2', 'has second example value')
|
|
159
|
-
})
|
|
160
|
-
|
|
161
|
-
test('reads a complex value value', async ({ assert }) => {
|
|
162
|
-
const shape = loader.getShape(model, 'ScalarObjectUnionExample') as IApiAnyShape
|
|
163
|
-
const result = reader.read(shape.examples[0], xmlMime, shape) as string
|
|
164
|
-
|
|
165
|
-
const parser = new DOMParser()
|
|
166
|
-
const schema = parser.parseFromString(result, xmlMime)
|
|
167
|
-
|
|
168
|
-
const root = schema.getElementsByTagName('ScalarObjectUnionExample')[0]
|
|
169
|
-
assert.ok(root, 'has the root node')
|
|
170
|
-
const name = root.getElementsByTagName('name')[0]
|
|
171
|
-
const id = root.getElementsByTagName('id')[0]
|
|
172
|
-
const age = root.getElementsByTagName('age')[0]
|
|
173
|
-
const sex = root.getElementsByTagName('sex')[0]
|
|
174
|
-
const newsletter = root.getElementsByTagName('newsletter')[0]
|
|
175
|
-
const tosAccepted = root.getElementsByTagName('tosAccepted')[0]
|
|
176
|
-
assert.ok(name, 'has the name node')
|
|
177
|
-
assert.ok(id, 'has the id node')
|
|
178
|
-
assert.ok(age, 'has the age node')
|
|
179
|
-
assert.ok(sex, 'has the sex node')
|
|
180
|
-
assert.ok(newsletter, 'has the newsletter node')
|
|
181
|
-
assert.ok(tosAccepted, 'has the tosAccepted node')
|
|
182
|
-
assert.equal((name.textContent as string).trim(), 'Pawel Uchida-Psztyc')
|
|
183
|
-
assert.equal((id.textContent as string).trim(), '128a654bc54d898e43f')
|
|
184
|
-
assert.equal((age.textContent as string).trim(), '30')
|
|
185
|
-
assert.equal((sex.textContent as string).trim(), 'male')
|
|
186
|
-
assert.equal((newsletter.textContent as string).trim(), 'false')
|
|
187
|
-
assert.equal((tosAccepted.textContent as string).trim(), 'true')
|
|
188
|
-
})
|
|
189
|
-
})
|
|
190
|
-
|
|
191
|
-
test.group(urlEncodedMime, (group) => {
|
|
192
|
-
let reader: ApiExampleGenerator
|
|
193
|
-
let model: IAmfDocument
|
|
194
|
-
|
|
195
|
-
group.setup(async () => {
|
|
196
|
-
model = await loader.getGraph('schema-api')
|
|
197
|
-
reader = new ApiExampleGenerator()
|
|
198
|
-
})
|
|
199
|
-
|
|
200
|
-
test('returns the value when corresponds to the mime type', ({ assert }) => {
|
|
201
|
-
const example: IApiDataExample = {
|
|
202
|
-
id: '',
|
|
203
|
-
strict: true,
|
|
204
|
-
types: [ns.aml.vocabularies.document.NamedExamples],
|
|
205
|
-
value: 'a=b&c=d',
|
|
206
|
-
customDomainProperties: [],
|
|
207
|
-
}
|
|
208
|
-
const result = reader.read(example, urlEncodedMime)
|
|
209
|
-
assert.strictEqual(result, 'a=b&c=d')
|
|
210
|
-
})
|
|
211
|
-
|
|
212
|
-
test('reads a number scalar value', async ({ assert }) => {
|
|
213
|
-
const shape = loader.getShape(model, 'ScalarNumberWithExample') as IApiAnyShape
|
|
214
|
-
const result = reader.read(shape.examples[0], urlEncodedMime, shape)
|
|
215
|
-
assert.strictEqual(result, 'ScalarNumberWithExample=24')
|
|
216
|
-
})
|
|
217
|
-
|
|
218
|
-
test('reads a string array value', async ({ assert }) => {
|
|
219
|
-
const shape = loader.getShape(model, 'StringArrayExample') as IApiAnyShape
|
|
220
|
-
const result = reader.read(shape.examples[0], urlEncodedMime, shape)
|
|
221
|
-
|
|
222
|
-
assert.strictEqual(result, 'StringArrayExample[]=test&StringArrayExample[]=other')
|
|
223
|
-
})
|
|
224
|
-
|
|
225
|
-
test('reads an object array value', async ({ assert }) => {
|
|
226
|
-
const shape = loader.getShape(model, 'XmlArrayExample') as IApiAnyShape
|
|
227
|
-
const result = reader.read(shape.examples[0], urlEncodedMime, shape)
|
|
228
|
-
|
|
229
|
-
assert.strictEqual(result, 'street=1234+Market+street&city=San+Francisco')
|
|
230
|
-
})
|
|
231
|
-
|
|
232
|
-
test('reads a number array value', async ({ assert }) => {
|
|
233
|
-
const shape = loader.getShape(model, 'NumberArrayExample') as IApiAnyShape
|
|
234
|
-
const result = reader.read(shape.examples[0], urlEncodedMime, shape)
|
|
235
|
-
|
|
236
|
-
assert.strictEqual(result, 'NumberArrayExample[]=1&NumberArrayExample[]=2')
|
|
237
|
-
})
|
|
238
|
-
|
|
239
|
-
test('reads a complex value value', async ({ assert }) => {
|
|
240
|
-
const shape = loader.getShape(model, 'ScalarObjectUnionExample') as IApiAnyShape
|
|
241
|
-
const result = reader.read(shape.examples[0], urlEncodedMime, shape) as string
|
|
242
|
-
const parsed = new URLSearchParams(result)
|
|
243
|
-
assert.equal(parsed.get('name'), 'Pawel Uchida-Psztyc')
|
|
244
|
-
assert.equal(parsed.get('id'), '128a654bc54d898e43f')
|
|
245
|
-
assert.equal(parsed.get('age'), '30')
|
|
246
|
-
assert.equal(parsed.get('sex'), 'male')
|
|
247
|
-
assert.equal(parsed.get('newsletter'), 'false')
|
|
248
|
-
assert.equal(parsed.get('tosAccepted'), 'true')
|
|
249
|
-
})
|
|
250
|
-
})
|
|
@@ -1,183 +0,0 @@
|
|
|
1
|
-
import { test } from '@japa/runner'
|
|
2
|
-
import { AmfNamespace as ns } from '../../../src/amf/definitions/Namespace.js'
|
|
3
|
-
import {
|
|
4
|
-
ApiMonacoSchemaGenerator,
|
|
5
|
-
IMonacoArrayProperty,
|
|
6
|
-
IMonacoObjectProperty,
|
|
7
|
-
IMonacoScalarProperty,
|
|
8
|
-
} from '../../../src/amf/ApiMonacoSchemaGenerator.js'
|
|
9
|
-
import { AmfLoader } from './AmfLoader.js'
|
|
10
|
-
import { IAmfDocument } from '../../../src/amf/definitions/Amf.js'
|
|
11
|
-
const loader = new AmfLoader()
|
|
12
|
-
|
|
13
|
-
test.group('generate()', (group) => {
|
|
14
|
-
const parentUri = 'https://domain.com'
|
|
15
|
-
|
|
16
|
-
let reader: ApiMonacoSchemaGenerator
|
|
17
|
-
let model: IAmfDocument
|
|
18
|
-
|
|
19
|
-
group.setup(async () => {
|
|
20
|
-
model = await loader.getGraph('schema-api')
|
|
21
|
-
reader = new ApiMonacoSchemaGenerator()
|
|
22
|
-
})
|
|
23
|
-
|
|
24
|
-
test('creates a schema for an object', async ({ assert }) => {
|
|
25
|
-
const shape = loader.getShape(model, 'SimpleObject')
|
|
26
|
-
const result = reader.generate(shape, parentUri)
|
|
27
|
-
|
|
28
|
-
assert.typeOf(result, 'array', 'result is an array')
|
|
29
|
-
const [object] = result
|
|
30
|
-
assert.equal(object.uri, shape.id, 'has uri')
|
|
31
|
-
assert.deepEqual(object.fileMatch, [parentUri], 'has fileMatch')
|
|
32
|
-
const schema = object.schema as IMonacoObjectProperty
|
|
33
|
-
assert.typeOf(schema, 'object', 'has schema')
|
|
34
|
-
|
|
35
|
-
assert.equal(schema.title, 'SimpleObject', 'has schema.title')
|
|
36
|
-
assert.equal(schema.type, 'object', 'has schema.type')
|
|
37
|
-
assert.typeOf(schema.properties, 'object', 'has schema.properties')
|
|
38
|
-
assert.deepEqual(schema.required, ['id', 'name', 'sex', 'tosAccepted'], 'has schema.required')
|
|
39
|
-
|
|
40
|
-
const id = schema.properties.id as IMonacoScalarProperty
|
|
41
|
-
assert.typeOf(id.$id, 'string', 'id.$id is set')
|
|
42
|
-
assert.equal(id.type, 'string', 'id.type is set')
|
|
43
|
-
assert.equal(id.title, 'id', 'id.title is set')
|
|
44
|
-
|
|
45
|
-
const name = schema.properties.name as IMonacoScalarProperty
|
|
46
|
-
assert.typeOf(name.$id, 'string', 'name.$id is set')
|
|
47
|
-
assert.equal(name.type, 'string', 'name.type is set')
|
|
48
|
-
assert.equal(name.title, 'Name', 'name.title is set')
|
|
49
|
-
|
|
50
|
-
const age = schema.properties.age as IMonacoScalarProperty
|
|
51
|
-
assert.typeOf(age.$id, 'string', 'age.$id is set')
|
|
52
|
-
assert.equal(age.type, 'number', 'age.type is set')
|
|
53
|
-
assert.equal(age.title, 'age', 'age.title is set')
|
|
54
|
-
assert.equal(age.description, 'Optional person age.', 'age.description is set')
|
|
55
|
-
assert.equal(age.minimum, 18, 'age.minimum is set')
|
|
56
|
-
|
|
57
|
-
const sex = schema.properties.sex as IMonacoScalarProperty
|
|
58
|
-
assert.typeOf(sex.$id, 'string', 'sex.$id is set')
|
|
59
|
-
assert.equal(sex.type, 'string', 'sex.type is set')
|
|
60
|
-
assert.equal(sex.title, 'sex', 'sex.title is set')
|
|
61
|
-
assert.equal(sex.description, 'An example of an enum.', 'sex.description is set')
|
|
62
|
-
assert.deepEqual(sex.enum, ['male', 'female'], 'sex.enum is set')
|
|
63
|
-
|
|
64
|
-
const newsletter = schema.properties.newsletter as IMonacoScalarProperty
|
|
65
|
-
assert.typeOf(newsletter.$id, 'string', 'newsletter.$id is set')
|
|
66
|
-
assert.equal(newsletter.type, 'boolean', 'newsletter.type is set')
|
|
67
|
-
assert.equal(newsletter.title, 'newsletter', 'newsletter.title is set')
|
|
68
|
-
assert.equal(
|
|
69
|
-
newsletter.description,
|
|
70
|
-
'Whether the user wants to be added to the newsletter',
|
|
71
|
-
'newsletter.description is set'
|
|
72
|
-
)
|
|
73
|
-
|
|
74
|
-
const tosAccepted = schema.properties.tosAccepted as IMonacoScalarProperty
|
|
75
|
-
assert.typeOf(tosAccepted.$id, 'string', 'tosAccepted.$id is set')
|
|
76
|
-
assert.equal(tosAccepted.type, 'boolean', 'tosAccepted.type is set')
|
|
77
|
-
assert.equal(tosAccepted.title, 'tosAccepted', 'tosAccepted.title is set')
|
|
78
|
-
assert.equal(
|
|
79
|
-
tosAccepted.description,
|
|
80
|
-
'Whether terms of service is accepted by the user.',
|
|
81
|
-
'tosAccepted.description is set'
|
|
82
|
-
)
|
|
83
|
-
assert.equal(tosAccepted.default, 'false', 'tosAccepted.default is set')
|
|
84
|
-
})
|
|
85
|
-
|
|
86
|
-
test('creates a schema for an object with a parent', async ({ assert }) => {
|
|
87
|
-
const shape = loader.getShape(model, 'ObjectWithParent')
|
|
88
|
-
const result = reader.generate(shape, parentUri)
|
|
89
|
-
|
|
90
|
-
assert.typeOf(result, 'array', 'result is an array')
|
|
91
|
-
const [object] = result
|
|
92
|
-
assert.equal(object.uri, shape.id, 'has uri')
|
|
93
|
-
assert.deepEqual(object.fileMatch, [parentUri], 'has fileMatch')
|
|
94
|
-
const schema = object.schema as IMonacoObjectProperty
|
|
95
|
-
assert.typeOf(schema, 'object', 'has schema')
|
|
96
|
-
|
|
97
|
-
assert.equal(schema.title, 'ObjectWithParent', 'has schema.title')
|
|
98
|
-
assert.equal(schema.type, 'object', 'has schema.type')
|
|
99
|
-
assert.typeOf(schema.properties, 'object', 'has schema.properties')
|
|
100
|
-
const required = ['addedProperty', 'age', 'id', 'name', 'sex', 'tosAccepted']
|
|
101
|
-
schema.required.forEach((r) => assert.include(required, r, `required has ${r}`))
|
|
102
|
-
|
|
103
|
-
const id = schema.properties.id
|
|
104
|
-
const name = schema.properties.name
|
|
105
|
-
const sex = schema.properties.sex
|
|
106
|
-
const newsletter = schema.properties.newsletter
|
|
107
|
-
const tosAccepted = schema.properties.tosAccepted
|
|
108
|
-
assert.ok(id, 'has parent id property')
|
|
109
|
-
assert.ok(name, 'has parent name property')
|
|
110
|
-
assert.ok(sex, 'has parent sex property')
|
|
111
|
-
assert.ok(newsletter, 'has parent newsletter property')
|
|
112
|
-
assert.ok(tosAccepted, 'has parent tosAccepted property')
|
|
113
|
-
|
|
114
|
-
const addedProperty = schema.properties.addedProperty as IMonacoScalarProperty
|
|
115
|
-
assert.typeOf(addedProperty.$id, 'string', 'addedProperty.$id is set')
|
|
116
|
-
assert.equal(addedProperty.type, 'string', 'addedProperty.type is set')
|
|
117
|
-
assert.equal(addedProperty.title, 'addedProperty', 'addedProperty.title is set')
|
|
118
|
-
assert.equal(addedProperty.format, 'time', 'addedProperty.format is set')
|
|
119
|
-
|
|
120
|
-
const age = schema.properties.age as IMonacoScalarProperty
|
|
121
|
-
assert.typeOf(age.$id, 'string', 'age.$id is set')
|
|
122
|
-
assert.equal(age.type, 'number', 'age.type is set')
|
|
123
|
-
assert.equal(age.title, 'age', 'age.title is set')
|
|
124
|
-
assert.equal(age.description, 'Age is not optional anymore.', 'age.description is set')
|
|
125
|
-
assert.equal(age.minimum, 18, 'age.minimum is set')
|
|
126
|
-
})
|
|
127
|
-
|
|
128
|
-
test('creates a schema for an object with array values', async ({ assert }) => {
|
|
129
|
-
const shape = loader.getShape(model, 'ObjectWithArray')
|
|
130
|
-
const result = reader.generate(shape, parentUri)
|
|
131
|
-
|
|
132
|
-
assert.typeOf(result, 'array', 'result is an array')
|
|
133
|
-
const [object] = result
|
|
134
|
-
assert.equal(object.uri, shape.id, 'has uri')
|
|
135
|
-
assert.deepEqual(object.fileMatch, [parentUri], 'has fileMatch')
|
|
136
|
-
const schema = object.schema as IMonacoObjectProperty
|
|
137
|
-
assert.typeOf(schema, 'object', 'has schema')
|
|
138
|
-
|
|
139
|
-
const tags = schema.properties.tags as IMonacoArrayProperty
|
|
140
|
-
assert.typeOf(tags.$id, 'string', 'tags.$id is set')
|
|
141
|
-
assert.equal(tags.type, 'array', 'tags.type is set')
|
|
142
|
-
assert.equal(tags.title, 'tags', 'tags.title is set')
|
|
143
|
-
assert.equal(tags.description, 'These are tags', 'tags.description is set')
|
|
144
|
-
assert.deepEqual(tags.required, [], 'tags.required is set')
|
|
145
|
-
assert.isFalse(tags.additionalItems, 'tags.additionalItems is set')
|
|
146
|
-
const { items } = tags
|
|
147
|
-
assert.equal(items.anyOf[0].type, 'string')
|
|
148
|
-
})
|
|
149
|
-
})
|
|
150
|
-
|
|
151
|
-
test.group('schemaTypeToJsonDataType()', (group) => {
|
|
152
|
-
let reader: ApiMonacoSchemaGenerator
|
|
153
|
-
|
|
154
|
-
group.setup(async () => {
|
|
155
|
-
reader = new ApiMonacoSchemaGenerator()
|
|
156
|
-
})
|
|
157
|
-
;[
|
|
158
|
-
[ns.w3.xmlSchema.number, 'number'],
|
|
159
|
-
[ns.aml.vocabularies.shapes.number, 'number'],
|
|
160
|
-
[ns.w3.xmlSchema.integer, 'number'],
|
|
161
|
-
[ns.aml.vocabularies.shapes.integer, 'number'],
|
|
162
|
-
[ns.w3.xmlSchema.float, 'number'],
|
|
163
|
-
[ns.aml.vocabularies.shapes.float, 'number'],
|
|
164
|
-
[ns.w3.xmlSchema.long, 'number'],
|
|
165
|
-
[ns.aml.vocabularies.shapes.long, 'number'],
|
|
166
|
-
[ns.w3.xmlSchema.double, 'number'],
|
|
167
|
-
[ns.aml.vocabularies.shapes.double, 'number'],
|
|
168
|
-
[ns.aml.vocabularies.shapes.boolean, 'boolean'],
|
|
169
|
-
[ns.w3.xmlSchema.boolean, 'boolean'],
|
|
170
|
-
[ns.w3.xmlSchema.date, 'string'],
|
|
171
|
-
[ns.w3.xmlSchema.time, 'string'],
|
|
172
|
-
[ns.w3.xmlSchema.dateTime, 'string'],
|
|
173
|
-
[ns.aml.vocabularies.shapes.dateTimeOnly, 'string'],
|
|
174
|
-
[ns.w3.xmlSchema.string, 'string'],
|
|
175
|
-
[ns.aml.vocabularies.shapes.nil, 'null'],
|
|
176
|
-
[ns.w3.xmlSchema.nil, 'null'],
|
|
177
|
-
].forEach(([key, expected]) => {
|
|
178
|
-
test(`recognizes a type for ${key}`, ({ assert }) => {
|
|
179
|
-
const result = reader.schemaTypeToJsonDataType(key)
|
|
180
|
-
assert.strictEqual(result, expected)
|
|
181
|
-
})
|
|
182
|
-
})
|
|
183
|
-
})
|