@azure-tools/typespec-ts 0.11.0
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/.eslintrc.json +23 -0
- package/.prettierignore +1 -0
- package/.prettierrc +7 -0
- package/.rush/temp/package-deps_build.json +303 -0
- package/.rush/temp/shrinkwrap-deps.json +469 -0
- package/CHANGELOG.md +65 -0
- package/CONTRIBUTING.md +134 -0
- package/README.md +150 -0
- package/dist/src/emitUtil.d.ts +6 -0
- package/dist/src/emitUtil.d.ts.map +1 -0
- package/dist/src/emitUtil.js +45 -0
- package/dist/src/emitUtil.js.map +1 -0
- package/dist/src/index.d.ts +3 -0
- package/dist/src/index.d.ts.map +1 -0
- package/dist/src/index.js +59 -0
- package/dist/src/index.js.map +1 -0
- package/dist/src/lib.d.ts +159 -0
- package/dist/src/lib.d.ts.map +1 -0
- package/dist/src/lib.js +189 -0
- package/dist/src/lib.js.map +1 -0
- package/dist/src/modelUtils.d.ts +12 -0
- package/dist/src/modelUtils.d.ts.map +1 -0
- package/dist/src/modelUtils.js +812 -0
- package/dist/src/modelUtils.js.map +1 -0
- package/dist/src/operationUtil.d.ts +16 -0
- package/dist/src/operationUtil.d.ts.map +1 -0
- package/dist/src/operationUtil.js +142 -0
- package/dist/src/operationUtil.js.map +1 -0
- package/dist/src/transform/transform.d.ts +8 -0
- package/dist/src/transform/transform.d.ts.map +1 -0
- package/dist/src/transform/transform.js +131 -0
- package/dist/src/transform/transform.js.map +1 -0
- package/dist/src/transform/transformAnnotationDetails.d.ts +6 -0
- package/dist/src/transform/transformAnnotationDetails.d.ts.map +1 -0
- package/dist/src/transform/transformAnnotationDetails.js +188 -0
- package/dist/src/transform/transformAnnotationDetails.js.map +1 -0
- package/dist/src/transform/transformApiVersionParam.d.ts +5 -0
- package/dist/src/transform/transformApiVersionParam.d.ts.map +1 -0
- package/dist/src/transform/transformApiVersionParam.js +76 -0
- package/dist/src/transform/transformApiVersionParam.js.map +1 -0
- package/dist/src/transform/transformParameters.d.ts +14 -0
- package/dist/src/transform/transformParameters.d.ts.map +1 -0
- package/dist/src/transform/transformParameters.js +315 -0
- package/dist/src/transform/transformParameters.js.map +1 -0
- package/dist/src/transform/transformPaths.d.ts +10 -0
- package/dist/src/transform/transformPaths.d.ts.map +1 -0
- package/dist/src/transform/transformPaths.js +124 -0
- package/dist/src/transform/transformPaths.js.map +1 -0
- package/dist/src/transform/transformResponses.d.ts +5 -0
- package/dist/src/transform/transformResponses.d.ts.map +1 -0
- package/dist/src/transform/transformResponses.js +136 -0
- package/dist/src/transform/transformResponses.js.map +1 -0
- package/dist/src/transform/transformSchemas.d.ts +4 -0
- package/dist/src/transform/transformSchemas.d.ts.map +1 -0
- package/dist/src/transform/transformSchemas.js +175 -0
- package/dist/src/transform/transformSchemas.js.map +1 -0
- package/dist/src/transform/transfromRLCOptions.d.ts +10 -0
- package/dist/src/transform/transfromRLCOptions.d.ts.map +1 -0
- package/dist/src/transform/transfromRLCOptions.js +156 -0
- package/dist/src/transform/transfromRLCOptions.js.map +1 -0
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/package.json +73 -0
- package/src/emitUtil.ts +63 -0
- package/src/index.ts +106 -0
- package/src/lib.ts +207 -0
- package/src/modelUtils.ts +961 -0
- package/src/operationUtil.ts +203 -0
- package/src/transform/transform.ts +224 -0
- package/src/transform/transformAnnotationDetails.ts +231 -0
- package/src/transform/transformApiVersionParam.ts +104 -0
- package/src/transform/transformParameters.ts +480 -0
- package/src/transform/transformPaths.ts +187 -0
- package/src/transform/transformResponses.ts +190 -0
- package/src/transform/transformSchemas.ts +209 -0
- package/src/transform/transfromRLCOptions.ts +202 -0
- package/test/commands/cadl-ranch-list.ts +83 -0
- package/test/commands/check-clean-tree.ts +55 -0
- package/test/commands/childProcessOnExit.ts +16 -0
- package/test/commands/gen-cadl-ranch.ts +21 -0
- package/test/commands/run.ts +41 -0
- package/test/integration/arrayItemTypes.spec.ts +93 -0
- package/test/integration/authApiKey.spec.ts +38 -0
- package/test/integration/authOauth2.spec.ts +65 -0
- package/test/integration/authUnion.spec.ts +72 -0
- package/test/integration/dictionary.spec.ts +102 -0
- package/test/integration/extensibleEnums.spec.ts +61 -0
- package/test/integration/fixedEnums.spec.ts +52 -0
- package/test/integration/generated/arrays/itemTypes/src/arrayItemTypesClient.ts +31 -0
- package/test/integration/generated/arrays/itemTypes/src/clientDefinitions.ts +150 -0
- package/test/integration/generated/arrays/itemTypes/src/index.ts +13 -0
- package/test/integration/generated/arrays/itemTypes/src/models.ts +9 -0
- package/test/integration/generated/arrays/itemTypes/src/outputModels.ts +9 -0
- package/test/integration/generated/arrays/itemTypes/src/parameters.ts +78 -0
- package/test/integration/generated/arrays/itemTypes/src/responses.ts +104 -0
- package/test/integration/generated/arrays/itemTypes/tspconfig.yaml +12 -0
- package/test/integration/generated/authentication/apiKey/.eslintrc.json +11 -0
- package/test/integration/generated/authentication/apiKey/README.md +56 -0
- package/test/integration/generated/authentication/apiKey/api-extractor.json +18 -0
- package/test/integration/generated/authentication/apiKey/karma.conf.js +133 -0
- package/test/integration/generated/authentication/apiKey/package.json +103 -0
- package/test/integration/generated/authentication/apiKey/rollup.config.js +118 -0
- package/test/integration/generated/authentication/apiKey/src/authApiKeyClient.ts +41 -0
- package/test/integration/generated/authentication/apiKey/src/clientDefinitions.ts +33 -0
- package/test/integration/generated/authentication/apiKey/src/index.ts +12 -0
- package/test/integration/generated/authentication/apiKey/src/outputModels.ts +6 -0
- package/test/integration/generated/authentication/apiKey/src/parameters.ts +7 -0
- package/test/integration/generated/authentication/apiKey/src/responses.ts +21 -0
- package/test/integration/generated/authentication/apiKey/test/public/sampleTest.spec.ts +23 -0
- package/test/integration/generated/authentication/apiKey/test/public/utils/env.browser.ts +2 -0
- package/test/integration/generated/authentication/apiKey/test/public/utils/env.ts +6 -0
- package/test/integration/generated/authentication/apiKey/test/public/utils/recordedClient.ts +29 -0
- package/test/integration/generated/authentication/apiKey/tsconfig.json +25 -0
- package/test/integration/generated/authentication/apiKey/tspconfig.yaml +10 -0
- package/test/integration/generated/authentication/oauth2/karma.conf.js +133 -0
- package/test/integration/generated/authentication/oauth2/src/authOauth2Client.ts +41 -0
- package/test/integration/generated/authentication/oauth2/src/clientDefinitions.ts +33 -0
- package/test/integration/generated/authentication/oauth2/src/index.ts +12 -0
- package/test/integration/generated/authentication/oauth2/src/outputModels.ts +6 -0
- package/test/integration/generated/authentication/oauth2/src/parameters.ts +7 -0
- package/test/integration/generated/authentication/oauth2/src/responses.ts +21 -0
- package/test/integration/generated/authentication/oauth2/test/public/sampleTest.spec.ts +23 -0
- package/test/integration/generated/authentication/oauth2/test/public/utils/env.browser.ts +2 -0
- package/test/integration/generated/authentication/oauth2/test/public/utils/env.ts +6 -0
- package/test/integration/generated/authentication/oauth2/test/public/utils/recordedClient.ts +29 -0
- package/test/integration/generated/authentication/oauth2/tspconfig.yaml +12 -0
- package/test/integration/generated/authentication/union/karma.conf.js +133 -0
- package/test/integration/generated/authentication/union/src/authUnionClient.ts +42 -0
- package/test/integration/generated/authentication/union/src/clientDefinitions.ts +27 -0
- package/test/integration/generated/authentication/union/src/index.ts +11 -0
- package/test/integration/generated/authentication/union/src/parameters.ts +7 -0
- package/test/integration/generated/authentication/union/src/responses.ts +14 -0
- package/test/integration/generated/authentication/union/test/public/sampleTest.spec.ts +23 -0
- package/test/integration/generated/authentication/union/test/public/utils/env.browser.ts +2 -0
- package/test/integration/generated/authentication/union/test/public/utils/env.ts +6 -0
- package/test/integration/generated/authentication/union/test/public/utils/recordedClient.ts +29 -0
- package/test/integration/generated/authentication/union/tspconfig.yaml +12 -0
- package/test/integration/generated/dictionary/.eslintrc.json +11 -0
- package/test/integration/generated/dictionary/README.md +56 -0
- package/test/integration/generated/dictionary/api-extractor.json +18 -0
- package/test/integration/generated/dictionary/package.json +80 -0
- package/test/integration/generated/dictionary/rollup.config.js +118 -0
- package/test/integration/generated/dictionary/src/clientDefinitions.ts +165 -0
- package/test/integration/generated/dictionary/src/dictClient.ts +29 -0
- package/test/integration/generated/dictionary/src/index.ts +13 -0
- package/test/integration/generated/dictionary/src/models.ts +9 -0
- package/test/integration/generated/dictionary/src/outputModels.ts +9 -0
- package/test/integration/generated/dictionary/src/parameters.ts +86 -0
- package/test/integration/generated/dictionary/src/responses.ts +115 -0
- package/test/integration/generated/dictionary/tsconfig.json +25 -0
- package/test/integration/generated/dictionary/tspconfig.yaml +12 -0
- package/test/integration/generated/enums/extensible/.eslintrc.json +11 -0
- package/test/integration/generated/enums/extensible/README.md +56 -0
- package/test/integration/generated/enums/extensible/api-extractor.json +18 -0
- package/test/integration/generated/enums/extensible/package.json +80 -0
- package/test/integration/generated/enums/extensible/rollup.config.js +118 -0
- package/test/integration/generated/enums/extensible/src/clientDefinitions.ts +45 -0
- package/test/integration/generated/enums/extensible/src/enumsExtensible.ts +31 -0
- package/test/integration/generated/enums/extensible/src/index.ts +11 -0
- package/test/integration/generated/enums/extensible/src/parameters.ts +23 -0
- package/test/integration/generated/enums/extensible/src/responses.ts +26 -0
- package/test/integration/generated/enums/extensible/tsconfig.json +25 -0
- package/test/integration/generated/enums/extensible/tspconfig.yaml +11 -0
- package/test/integration/generated/enums/fixed/.eslintrc.json +11 -0
- package/test/integration/generated/enums/fixed/README.md +56 -0
- package/test/integration/generated/enums/fixed/api-extractor.json +18 -0
- package/test/integration/generated/enums/fixed/package.json +80 -0
- package/test/integration/generated/enums/fixed/rollup.config.js +118 -0
- package/test/integration/generated/enums/fixed/src/clientDefinitions.ts +43 -0
- package/test/integration/generated/enums/fixed/src/enumsFixed.ts +31 -0
- package/test/integration/generated/enums/fixed/src/index.ts +11 -0
- package/test/integration/generated/enums/fixed/src/parameters.ts +36 -0
- package/test/integration/generated/enums/fixed/src/responses.ts +27 -0
- package/test/integration/generated/enums/fixed/tsconfig.json +25 -0
- package/test/integration/generated/enums/fixed/tspconfig.yaml +11 -0
- package/test/integration/generated/hello/.eslintrc.json +11 -0
- package/test/integration/generated/hello/README.md +56 -0
- package/test/integration/generated/hello/api-extractor.json +18 -0
- package/test/integration/generated/hello/package.json +80 -0
- package/test/integration/generated/hello/rollup.config.js +118 -0
- package/test/integration/generated/hello/src/clientDefinitions.ts +19 -0
- package/test/integration/generated/hello/src/hello.ts +29 -0
- package/test/integration/generated/hello/src/index.ts +11 -0
- package/test/integration/generated/hello/src/parameters.ts +6 -0
- package/test/integration/generated/hello/src/responses.ts +10 -0
- package/test/integration/generated/hello/tsconfig.json +25 -0
- package/test/integration/generated/hello/tspconfig.yaml +11 -0
- package/test/integration/generated/lro/lroBasic/.eslintrc.json +11 -0
- package/test/integration/generated/lro/lroBasic/README.md +56 -0
- package/test/integration/generated/lro/lroBasic/api-extractor.json +18 -0
- package/test/integration/generated/lro/lroBasic/package.json +82 -0
- package/test/integration/generated/lro/lroBasic/rollup.config.js +118 -0
- package/test/integration/generated/lro/lroBasic/src/azureLro.ts +31 -0
- package/test/integration/generated/lro/lroBasic/src/clientDefinitions.ts +37 -0
- package/test/integration/generated/lro/lroBasic/src/index.ts +12 -0
- package/test/integration/generated/lro/lroBasic/src/parameters.ts +8 -0
- package/test/integration/generated/lro/lroBasic/src/pollingHelper.ts +75 -0
- package/test/integration/generated/lro/lroBasic/src/responses.ts +22 -0
- package/test/integration/generated/lro/lroBasic/tsconfig.json +25 -0
- package/test/integration/generated/lro/lroBasic/tspconfig.yaml +11 -0
- package/test/integration/generated/models/inheritance/.eslintrc.json +11 -0
- package/test/integration/generated/models/inheritance/README.md +56 -0
- package/test/integration/generated/models/inheritance/api-extractor.json +18 -0
- package/test/integration/generated/models/inheritance/package.json +80 -0
- package/test/integration/generated/models/inheritance/rollup.config.js +118 -0
- package/test/integration/generated/models/inheritance/src/clientDefinitions.ts +79 -0
- package/test/integration/generated/models/inheritance/src/index.ts +13 -0
- package/test/integration/generated/models/inheritance/src/models.ts +52 -0
- package/test/integration/generated/models/inheritance/src/modelsInheritance.ts +31 -0
- package/test/integration/generated/models/inheritance/src/outputModels.ts +52 -0
- package/test/integration/generated/models/inheritance/src/parameters.ts +35 -0
- package/test/integration/generated/models/inheritance/src/responses.ts +56 -0
- package/test/integration/generated/models/inheritance/tsconfig.json +25 -0
- package/test/integration/generated/models/inheritance/tspconfig.yaml +11 -0
- package/test/integration/generated/models/propertyOptional/.eslintrc.json +11 -0
- package/test/integration/generated/models/propertyOptional/README.md +56 -0
- package/test/integration/generated/models/propertyOptional/api-extractor.json +18 -0
- package/test/integration/generated/models/propertyOptional/package.json +80 -0
- package/test/integration/generated/models/propertyOptional/rollup.config.js +118 -0
- package/test/integration/generated/models/propertyOptional/src/clientDefinitions.ts +263 -0
- package/test/integration/generated/models/propertyOptional/src/index.ts +13 -0
- package/test/integration/generated/models/propertyOptional/src/models.ts +46 -0
- package/test/integration/generated/models/propertyOptional/src/modelsPropertyOptional.ts +31 -0
- package/test/integration/generated/models/propertyOptional/src/outputModels.ts +46 -0
- package/test/integration/generated/models/propertyOptional/src/parameters.ts +124 -0
- package/test/integration/generated/models/propertyOptional/src/responses.ts +169 -0
- package/test/integration/generated/models/propertyOptional/tsconfig.json +25 -0
- package/test/integration/generated/models/propertyOptional/tspconfig.yaml +11 -0
- package/test/integration/generated/models/propertyTypes/.eslintrc.json +11 -0
- package/test/integration/generated/models/propertyTypes/README.md +56 -0
- package/test/integration/generated/models/propertyTypes/api-extractor.json +18 -0
- package/test/integration/generated/models/propertyTypes/package.json +80 -0
- package/test/integration/generated/models/propertyTypes/rollup.config.js +118 -0
- package/test/integration/generated/models/propertyTypes/src/clientDefinitions.ts +234 -0
- package/test/integration/generated/models/propertyTypes/src/index.ts +13 -0
- package/test/integration/generated/models/propertyTypes/src/models.ts +99 -0
- package/test/integration/generated/models/propertyTypes/src/modelsPropertyTypes.ts +31 -0
- package/test/integration/generated/models/propertyTypes/src/outputModels.ts +99 -0
- package/test/integration/generated/models/propertyTypes/src/parameters.ts +147 -0
- package/test/integration/generated/models/propertyTypes/src/responses.ts +186 -0
- package/test/integration/generated/models/propertyTypes/tsconfig.json +25 -0
- package/test/integration/generated/models/propertyTypes/tspconfig.yaml +11 -0
- package/test/integration/generated/models/usage/.eslintrc.json +11 -0
- package/test/integration/generated/models/usage/README.md +56 -0
- package/test/integration/generated/models/usage/api-extractor.json +18 -0
- package/test/integration/generated/models/usage/package.json +80 -0
- package/test/integration/generated/models/usage/rollup.config.js +118 -0
- package/test/integration/generated/models/usage/src/clientDefinitions.ts +41 -0
- package/test/integration/generated/models/usage/src/index.ts +13 -0
- package/test/integration/generated/models/usage/src/models.ts +12 -0
- package/test/integration/generated/models/usage/src/modelsUsage.ts +31 -0
- package/test/integration/generated/models/usage/src/outputModels.ts +12 -0
- package/test/integration/generated/models/usage/src/parameters.ts +19 -0
- package/test/integration/generated/models/usage/src/responses.ts +22 -0
- package/test/integration/generated/models/usage/tsconfig.json +25 -0
- package/test/integration/generated/models/usage/tspconfig.yaml +11 -0
- package/test/integration/generated/models/visibility/.eslintrc.json +11 -0
- package/test/integration/generated/models/visibility/README.md +56 -0
- package/test/integration/generated/models/visibility/api-extractor.json +18 -0
- package/test/integration/generated/models/visibility/package.json +80 -0
- package/test/integration/generated/models/visibility/rollup.config.js +118 -0
- package/test/integration/generated/models/visibility/src/clientDefinitions.ts +40 -0
- package/test/integration/generated/models/visibility/src/index.ts +13 -0
- package/test/integration/generated/models/visibility/src/models.ts +14 -0
- package/test/integration/generated/models/visibility/src/modelsVisibilityAutomatic.ts +31 -0
- package/test/integration/generated/models/visibility/src/outputModels.ts +16 -0
- package/test/integration/generated/models/visibility/src/parameters.ts +41 -0
- package/test/integration/generated/models/visibility/src/responses.ts +36 -0
- package/test/integration/generated/models/visibility/tsconfig.json +25 -0
- package/test/integration/generated/models/visibility/tspconfig.yaml +11 -0
- package/test/integration/generated/resiliency/devDriven/.eslintrc.json +11 -0
- package/test/integration/generated/resiliency/devDriven/README.md +56 -0
- package/test/integration/generated/resiliency/devDriven/api-extractor.json +18 -0
- package/test/integration/generated/resiliency/devDriven/package.json +81 -0
- package/test/integration/generated/resiliency/devDriven/rollup.config.js +118 -0
- package/test/integration/generated/resiliency/devDriven/src/clientDefinitions.ts +75 -0
- package/test/integration/generated/resiliency/devDriven/src/index.ts +15 -0
- package/test/integration/generated/resiliency/devDriven/src/isUnexpected.ts +117 -0
- package/test/integration/generated/resiliency/devDriven/src/models.ts +8 -0
- package/test/integration/generated/resiliency/devDriven/src/outputModels.ts +25 -0
- package/test/integration/generated/resiliency/devDriven/src/paginateHelper.ts +154 -0
- package/test/integration/generated/resiliency/devDriven/src/parameters.ts +17 -0
- package/test/integration/generated/resiliency/devDriven/src/resiliencyDevDriven.ts +31 -0
- package/test/integration/generated/resiliency/devDriven/src/responses.ts +62 -0
- package/test/integration/generated/resiliency/devDriven/tsconfig.json +25 -0
- package/test/integration/generated/resiliency/devDriven/tspconfig.yaml +11 -0
- package/test/integration/generated/resiliency/srvDriven1/.eslintrc.json +11 -0
- package/test/integration/generated/resiliency/srvDriven1/README.md +56 -0
- package/test/integration/generated/resiliency/srvDriven1/api-extractor.json +18 -0
- package/test/integration/generated/resiliency/srvDriven1/package.json +80 -0
- package/test/integration/generated/resiliency/srvDriven1/rollup.config.js +118 -0
- package/test/integration/generated/resiliency/srvDriven1/src/clientDefinitions.ts +70 -0
- package/test/integration/generated/resiliency/srvDriven1/src/index.ts +13 -0
- package/test/integration/generated/resiliency/srvDriven1/src/models.ts +6 -0
- package/test/integration/generated/resiliency/srvDriven1/src/outputModels.ts +6 -0
- package/test/integration/generated/resiliency/srvDriven1/src/parameters.ts +51 -0
- package/test/integration/generated/resiliency/srvDriven1/src/resiliencyServiceDriven1.ts +31 -0
- package/test/integration/generated/resiliency/srvDriven1/src/responses.ts +34 -0
- package/test/integration/generated/resiliency/srvDriven1/tsconfig.json +25 -0
- package/test/integration/generated/resiliency/srvDriven1/tspconfig.yaml +11 -0
- package/test/integration/generated/resiliency/srvDriven2/.eslintrc.json +11 -0
- package/test/integration/generated/resiliency/srvDriven2/README.md +56 -0
- package/test/integration/generated/resiliency/srvDriven2/api-extractor.json +18 -0
- package/test/integration/generated/resiliency/srvDriven2/package.json +80 -0
- package/test/integration/generated/resiliency/srvDriven2/rollup.config.js +118 -0
- package/test/integration/generated/resiliency/srvDriven2/src/clientDefinitions.ts +93 -0
- package/test/integration/generated/resiliency/srvDriven2/src/index.ts +13 -0
- package/test/integration/generated/resiliency/srvDriven2/src/models.ts +6 -0
- package/test/integration/generated/resiliency/srvDriven2/src/outputModels.ts +6 -0
- package/test/integration/generated/resiliency/srvDriven2/src/parameters.ts +68 -0
- package/test/integration/generated/resiliency/srvDriven2/src/resiliencyServiceDriven2.ts +31 -0
- package/test/integration/generated/resiliency/srvDriven2/src/responses.ts +45 -0
- package/test/integration/generated/resiliency/srvDriven2/tsconfig.json +25 -0
- package/test/integration/generated/resiliency/srvDriven2/tspconfig.yaml +11 -0
- package/test/integration/generated/specialWords/src/clientDefinitions.ts +61 -0
- package/test/integration/generated/specialWords/src/index.ts +13 -0
- package/test/integration/generated/specialWords/src/models.ts +17 -0
- package/test/integration/generated/specialWords/src/outputModels.ts +17 -0
- package/test/integration/generated/specialWords/src/parameters.ts +37 -0
- package/test/integration/generated/specialWords/src/responses.ts +31 -0
- package/test/integration/generated/specialWords/src/specialWordsClient.ts +31 -0
- package/test/integration/generated/specialWords/tspconfig.yaml +11 -0
- package/test/integration/generated/unions/src/clientDefinitions.ts +53 -0
- package/test/integration/generated/unions/src/index.ts +12 -0
- package/test/integration/generated/unions/src/models.ts +27 -0
- package/test/integration/generated/unions/src/parameters.ts +34 -0
- package/test/integration/generated/unions/src/responses.ts +24 -0
- package/test/integration/generated/unions/src/unionsClient.ts +31 -0
- package/test/integration/generated/unions/tspconfig.yaml +11 -0
- package/test/integration/helloWorld.spec.ts +20 -0
- package/test/integration/lroBasic.spec.ts +25 -0
- package/test/integration/modelInheritance.spec.ts +192 -0
- package/test/integration/modelPropertyOptional.spec.ts +362 -0
- package/test/integration/modelPropertyType.spec.ts +119 -0
- package/test/integration/modelUsage.spec.ts +47 -0
- package/test/integration/resiliencyDpgCustomization.spec.ts +52 -0
- package/test/integration/specialWords.spec.ts +73 -0
- package/test/integration/unions.spec.ts +69 -0
- package/test/tsconfig.json +4 -0
- package/test/unit/azureCoreOperationsGenerator.spec.ts +71 -0
- package/test/unit/clientDefinitionGenerator.spec.ts +73 -0
- package/test/unit/clientFactoryGenerator.spec.ts +507 -0
- package/test/unit/docsGenerator.spec.ts +201 -0
- package/test/unit/modelsGenerator.spec.ts +1319 -0
- package/test/unit/parametersGenerator.spec.ts +561 -0
- package/test/unit/responsesGenerator.spec.ts +462 -0
- package/test/unit/spreadAndAlias.spec.ts +200 -0
- package/test/unit/util/emitUtil.ts +156 -0
- package/test/unit/util/testUtil.ts +83 -0
- package/test/util/customBearerTokenTestingPolicy.ts +78 -0
- package/test/util/matrix.ts +48 -0
- package/tsconfig.json +36 -0
- package/tsconfig.test.json +7 -0
- package/typespec-ts.build.log +2 -0
|
@@ -0,0 +1,115 @@
|
|
|
1
|
+
// Copyright (c) Microsoft Corporation.
|
|
2
|
+
// Licensed under the MIT license.
|
|
3
|
+
|
|
4
|
+
import { HttpResponse } from "@azure-rest/core-client";
|
|
5
|
+
import { InnerModelOutput } from "./outputModels";
|
|
6
|
+
|
|
7
|
+
/** The request has succeeded. */
|
|
8
|
+
export interface Int32ValueGet200Response extends HttpResponse {
|
|
9
|
+
status: "200";
|
|
10
|
+
body: Record<string, number>;
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
/** There is no content to send for this request, but the headers may be useful. */
|
|
14
|
+
export interface Int32ValuePut204Response extends HttpResponse {
|
|
15
|
+
status: "204";
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
/** The request has succeeded. */
|
|
19
|
+
export interface Int64ValueGet200Response extends HttpResponse {
|
|
20
|
+
status: "200";
|
|
21
|
+
body: Record<string, number>;
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
/** There is no content to send for this request, but the headers may be useful. */
|
|
25
|
+
export interface Int64ValuePut204Response extends HttpResponse {
|
|
26
|
+
status: "204";
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
/** The request has succeeded. */
|
|
30
|
+
export interface BooleanValueGet200Response extends HttpResponse {
|
|
31
|
+
status: "200";
|
|
32
|
+
body: Record<string, boolean>;
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
/** There is no content to send for this request, but the headers may be useful. */
|
|
36
|
+
export interface BooleanValuePut204Response extends HttpResponse {
|
|
37
|
+
status: "204";
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
/** The request has succeeded. */
|
|
41
|
+
export interface StringValueGet200Response extends HttpResponse {
|
|
42
|
+
status: "200";
|
|
43
|
+
body: Record<string, string>;
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
/** There is no content to send for this request, but the headers may be useful. */
|
|
47
|
+
export interface StringValuePut204Response extends HttpResponse {
|
|
48
|
+
status: "204";
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
/** The request has succeeded. */
|
|
52
|
+
export interface Float32ValueGet200Response extends HttpResponse {
|
|
53
|
+
status: "200";
|
|
54
|
+
body: Record<string, number>;
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
/** There is no content to send for this request, but the headers may be useful. */
|
|
58
|
+
export interface Float32ValuePut204Response extends HttpResponse {
|
|
59
|
+
status: "204";
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
/** The request has succeeded. */
|
|
63
|
+
export interface DatetimeValueGet200Response extends HttpResponse {
|
|
64
|
+
status: "200";
|
|
65
|
+
body: Record<string, string>;
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
/** There is no content to send for this request, but the headers may be useful. */
|
|
69
|
+
export interface DatetimeValuePut204Response extends HttpResponse {
|
|
70
|
+
status: "204";
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
/** The request has succeeded. */
|
|
74
|
+
export interface DurationValueGet200Response extends HttpResponse {
|
|
75
|
+
status: "200";
|
|
76
|
+
body: Record<string, string>;
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
/** There is no content to send for this request, but the headers may be useful. */
|
|
80
|
+
export interface DurationValuePut204Response extends HttpResponse {
|
|
81
|
+
status: "204";
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
/** The request has succeeded. */
|
|
85
|
+
export interface UnknownValueGet200Response extends HttpResponse {
|
|
86
|
+
status: "200";
|
|
87
|
+
body: Record<string, any>;
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
/** There is no content to send for this request, but the headers may be useful. */
|
|
91
|
+
export interface UnknownValuePut204Response extends HttpResponse {
|
|
92
|
+
status: "204";
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
/** The request has succeeded. */
|
|
96
|
+
export interface ModelValueGet200Response extends HttpResponse {
|
|
97
|
+
status: "200";
|
|
98
|
+
body: Record<string, InnerModelOutput>;
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
/** There is no content to send for this request, but the headers may be useful. */
|
|
102
|
+
export interface ModelValuePut204Response extends HttpResponse {
|
|
103
|
+
status: "204";
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
/** The request has succeeded. */
|
|
107
|
+
export interface RecursiveModelValueGet200Response extends HttpResponse {
|
|
108
|
+
status: "200";
|
|
109
|
+
body: Record<string, InnerModelOutput>;
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
/** There is no content to send for this request, but the headers may be useful. */
|
|
113
|
+
export interface RecursiveModelValuePut204Response extends HttpResponse {
|
|
114
|
+
status: "204";
|
|
115
|
+
}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
{
|
|
2
|
+
"compilerOptions": {
|
|
3
|
+
"target": "ES2017",
|
|
4
|
+
"module": "es6",
|
|
5
|
+
"lib": [],
|
|
6
|
+
"declaration": true,
|
|
7
|
+
"declarationMap": true,
|
|
8
|
+
"inlineSources": true,
|
|
9
|
+
"sourceMap": true,
|
|
10
|
+
"importHelpers": true,
|
|
11
|
+
"strict": true,
|
|
12
|
+
"alwaysStrict": true,
|
|
13
|
+
"noUnusedLocals": true,
|
|
14
|
+
"noUnusedParameters": true,
|
|
15
|
+
"noImplicitReturns": true,
|
|
16
|
+
"noFallthroughCasesInSwitch": true,
|
|
17
|
+
"forceConsistentCasingInFileNames": true,
|
|
18
|
+
"moduleResolution": "node",
|
|
19
|
+
"allowSyntheticDefaultImports": true,
|
|
20
|
+
"esModuleInterop": true,
|
|
21
|
+
"outDir": "./dist-esm",
|
|
22
|
+
"declarationDir": "./types"
|
|
23
|
+
},
|
|
24
|
+
"include": ["./src/**/*.ts"]
|
|
25
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
emitters:
|
|
2
|
+
"../../../../../../../../../../packages/typespec-ts/dist/src/index.js":
|
|
3
|
+
generateMetadata: true
|
|
4
|
+
generateTest: false
|
|
5
|
+
addCredentials: false
|
|
6
|
+
azureSdkForJs: false
|
|
7
|
+
isCadlTest: true
|
|
8
|
+
title: DictClient
|
|
9
|
+
packageDetails:
|
|
10
|
+
name: "@msinternal/dictionary"
|
|
11
|
+
description: "Dictionary Test Service"
|
|
12
|
+
version: "1.0.0"
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
{
|
|
2
|
+
"plugins": ["@azure/azure-sdk"],
|
|
3
|
+
"extends": ["plugin:@azure/azure-sdk/azure-sdk-base"],
|
|
4
|
+
"rules": {
|
|
5
|
+
"@azure/azure-sdk/ts-modules-only-named": "warn",
|
|
6
|
+
"@azure/azure-sdk/ts-apiextractor-json-types": "warn",
|
|
7
|
+
"@azure/azure-sdk/ts-package-json-types": "warn",
|
|
8
|
+
"@azure/azure-sdk/ts-package-json-engine-is-present": "warn",
|
|
9
|
+
"tsdoc/syntax": "warn"
|
|
10
|
+
}
|
|
11
|
+
}
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
# EnumsExtensible REST client library for JavaScript
|
|
2
|
+
|
|
3
|
+
Extensible Enums Test Service
|
|
4
|
+
|
|
5
|
+
**Please rely heavily on our [REST client docs](https://github.com/Azure/azure-sdk-for-js/blob/main/documentation/rest-clients.md) to use this library**
|
|
6
|
+
|
|
7
|
+
Key links:
|
|
8
|
+
|
|
9
|
+
- [Package (NPM)](https://www.npmjs.com/package/@msinternal/extensible-enums)
|
|
10
|
+
|
|
11
|
+
## Getting started
|
|
12
|
+
|
|
13
|
+
### Currently supported environments
|
|
14
|
+
|
|
15
|
+
- LTS versions of Node.js
|
|
16
|
+
|
|
17
|
+
### Prerequisites
|
|
18
|
+
|
|
19
|
+
- You must have an [Azure subscription](https://azure.microsoft.com/free/) to use this package.
|
|
20
|
+
|
|
21
|
+
### Install the `@msinternal/extensible-enums` package
|
|
22
|
+
|
|
23
|
+
Install the EnumsExtensible REST client REST client library for JavaScript with `npm`:
|
|
24
|
+
|
|
25
|
+
```bash
|
|
26
|
+
npm install @msinternal/extensible-enums
|
|
27
|
+
```
|
|
28
|
+
|
|
29
|
+
### Create and authenticate a `EnumsExtensibleClient`
|
|
30
|
+
|
|
31
|
+
To use an [Azure Active Directory (AAD) token credential](https://github.com/Azure/azure-sdk-for-js/blob/main/sdk/identity/identity/samples/AzureIdentityExamples.md#authenticating-with-a-pre-fetched-access-token),
|
|
32
|
+
provide an instance of the desired credential type obtained from the
|
|
33
|
+
[@azure/identity](https://github.com/Azure/azure-sdk-for-js/tree/main/sdk/identity/identity#credentials) library.
|
|
34
|
+
|
|
35
|
+
To authenticate with AAD, you must first `npm` install [`@azure/identity`](https://www.npmjs.com/package/@azure/identity)
|
|
36
|
+
|
|
37
|
+
After setup, you can choose which type of [credential](https://github.com/Azure/azure-sdk-for-js/tree/main/sdk/identity/identity#credentials) from `@azure/identity` to use.
|
|
38
|
+
As an example, [DefaultAzureCredential](https://github.com/Azure/azure-sdk-for-js/tree/main/sdk/identity/identity#defaultazurecredential)
|
|
39
|
+
can be used to authenticate the client.
|
|
40
|
+
|
|
41
|
+
Set the values of the client ID, tenant ID, and client secret of the AAD application as environment variables:
|
|
42
|
+
AZURE_CLIENT_ID, AZURE_TENANT_ID, AZURE_CLIENT_SECRET
|
|
43
|
+
|
|
44
|
+
## Troubleshooting
|
|
45
|
+
|
|
46
|
+
### Logging
|
|
47
|
+
|
|
48
|
+
Enabling logging may help uncover useful information about failures. In order to see a log of HTTP requests and responses, set the `AZURE_LOG_LEVEL` environment variable to `info`. Alternatively, logging can be enabled at runtime by calling `setLogLevel` in the `@azure/logger`:
|
|
49
|
+
|
|
50
|
+
```javascript
|
|
51
|
+
const { setLogLevel } = require("@azure/logger");
|
|
52
|
+
|
|
53
|
+
setLogLevel("info");
|
|
54
|
+
```
|
|
55
|
+
|
|
56
|
+
For more detailed instructions on how to enable logs, you can look at the [@azure/logger package docs](https://github.com/Azure/azure-sdk-for-js/tree/main/sdk/core/logger).
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "https://developer.microsoft.com/json-schemas/api-extractor/v7/api-extractor.schema.json",
|
|
3
|
+
"mainEntryPointFilePath": "./types/index.d.ts",
|
|
4
|
+
"docModel": { "enabled": true },
|
|
5
|
+
"apiReport": { "enabled": true, "reportFolder": "./review" },
|
|
6
|
+
"dtsRollup": {
|
|
7
|
+
"enabled": true,
|
|
8
|
+
"untrimmedFilePath": "",
|
|
9
|
+
"publicTrimmedFilePath": "./types/extensible-enums.d.ts"
|
|
10
|
+
},
|
|
11
|
+
"messages": {
|
|
12
|
+
"tsdocMessageReporting": { "default": { "logLevel": "none" } },
|
|
13
|
+
"extractorMessageReporting": {
|
|
14
|
+
"ae-missing-release-tag": { "logLevel": "none" },
|
|
15
|
+
"ae-unresolved-link": { "logLevel": "none" }
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
}
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@msinternal/extensible-enums",
|
|
3
|
+
"sdk-type": "client",
|
|
4
|
+
"author": "Microsoft Corporation",
|
|
5
|
+
"version": "1.0.0",
|
|
6
|
+
"description": "Extensible Enums Test Service",
|
|
7
|
+
"keywords": ["node", "azure", "cloud", "typescript", "browser", "isomorphic"],
|
|
8
|
+
"license": "MIT",
|
|
9
|
+
"main": "dist/index.js",
|
|
10
|
+
"module": "./dist-esm/index.js",
|
|
11
|
+
"types": "./types/extensible-enums.d.ts",
|
|
12
|
+
"repository": "github:Azure/azure-sdk-for-js",
|
|
13
|
+
"bugs": { "url": "https://github.com/Azure/azure-sdk-for-js/issues" },
|
|
14
|
+
"files": [
|
|
15
|
+
"dist/",
|
|
16
|
+
"dist-esm/",
|
|
17
|
+
"types/extensible-enums.d.ts",
|
|
18
|
+
"README.md",
|
|
19
|
+
"LICENSE",
|
|
20
|
+
"review/*"
|
|
21
|
+
],
|
|
22
|
+
"engines": { "node": ">=14.0.0" },
|
|
23
|
+
"scripts": {
|
|
24
|
+
"audit": "node ../../../common/scripts/rush-audit.js && rimraf node_modules package-lock.json && npm i --package-lock-only 2>&1 && npm audit",
|
|
25
|
+
"build:browser": "echo skipped.",
|
|
26
|
+
"build:node": "echo skipped.",
|
|
27
|
+
"build:samples": "echo skipped.",
|
|
28
|
+
"build:test": "echo skipped.",
|
|
29
|
+
"build:debug": "echo skipped.",
|
|
30
|
+
"check-format": "prettier --list-different --config ../../../.prettierrc.json --ignore-path ../../../.prettierignore \"src/**/*.ts\" \"*.{js,json}\" ",
|
|
31
|
+
"clean": "rimraf dist dist-browser dist-esm test-dist temp types *.tgz *.log",
|
|
32
|
+
"execute:samples": "echo skipped",
|
|
33
|
+
"extract-api": "rimraf review && mkdirp ./review && api-extractor run --local",
|
|
34
|
+
"format": "prettier --write --config ../../../.prettierrc.json --ignore-path ../../../.prettierignore \"src/**/*.ts\" \"*.{js,json}\" ",
|
|
35
|
+
"generate:client": "echo skipped",
|
|
36
|
+
"integration-test:browser": "echo skipped",
|
|
37
|
+
"integration-test:node": "echo skipped",
|
|
38
|
+
"integration-test": "echo skipped",
|
|
39
|
+
"lint:fix": "eslint package.json api-extractor.json src --ext .ts --fix --fix-type [problem,suggestion]",
|
|
40
|
+
"lint": "eslint package.json api-extractor.json src --ext .ts",
|
|
41
|
+
"pack": "npm pack 2>&1",
|
|
42
|
+
"test:browser": "echo skipped",
|
|
43
|
+
"test:node": "echo skipped",
|
|
44
|
+
"test": "echo \"Error: no test specified\" && exit 1",
|
|
45
|
+
"unit-test": "echo skipped",
|
|
46
|
+
"unit-test:node": "echo skipped",
|
|
47
|
+
"unit-test:browser": "echo skipped",
|
|
48
|
+
"build": "npm run clean && tsc && rollup -c 2>&1 && npm run minify && mkdirp ./review && npm run extract-api",
|
|
49
|
+
"minify": "uglifyjs -c -m --comments --source-map \"content='./dist/index.js.map'\" -o ./dist/index.min.js ./dist/index.js"
|
|
50
|
+
},
|
|
51
|
+
"sideEffects": false,
|
|
52
|
+
"autoPublish": false,
|
|
53
|
+
"dependencies": {
|
|
54
|
+
"@azure/core-auth": "^1.3.0",
|
|
55
|
+
"@azure-rest/core-client": "^1.1.0",
|
|
56
|
+
"@azure/core-rest-pipeline": "^1.8.0",
|
|
57
|
+
"@azure/logger": "^1.0.0",
|
|
58
|
+
"tslib": "^2.2.0"
|
|
59
|
+
},
|
|
60
|
+
"devDependencies": {
|
|
61
|
+
"@microsoft/api-extractor": "^7.31.1",
|
|
62
|
+
"autorest": "latest",
|
|
63
|
+
"@types/node": "^14.0.0",
|
|
64
|
+
"dotenv": "^16.0.0",
|
|
65
|
+
"eslint": "^8.0.0",
|
|
66
|
+
"mkdirp": "^2.1.2",
|
|
67
|
+
"prettier": "^2.5.1",
|
|
68
|
+
"rimraf": "^3.0.0",
|
|
69
|
+
"source-map-support": "^0.5.9",
|
|
70
|
+
"typescript": "~4.8.0",
|
|
71
|
+
"@rollup/plugin-commonjs": "^24.0.0",
|
|
72
|
+
"@rollup/plugin-json": "^6.0.0",
|
|
73
|
+
"@rollup/plugin-multi-entry": "^6.0.0",
|
|
74
|
+
"@rollup/plugin-node-resolve": "^13.1.3",
|
|
75
|
+
"rollup": "^2.66.1",
|
|
76
|
+
"rollup-plugin-sourcemaps": "^0.6.3",
|
|
77
|
+
"uglify-js": "^3.4.9"
|
|
78
|
+
},
|
|
79
|
+
"type": "module"
|
|
80
|
+
}
|
|
@@ -0,0 +1,118 @@
|
|
|
1
|
+
// Copyright (c) Microsoft Corporation.
|
|
2
|
+
// Licensed under the MIT license.
|
|
3
|
+
|
|
4
|
+
import nodeResolve from "@rollup/plugin-node-resolve";
|
|
5
|
+
import cjs from "@rollup/plugin-commonjs";
|
|
6
|
+
import sourcemaps from "rollup-plugin-sourcemaps";
|
|
7
|
+
import multiEntry from "@rollup/plugin-multi-entry";
|
|
8
|
+
import json from "@rollup/plugin-json";
|
|
9
|
+
|
|
10
|
+
import nodeBuiltins from "builtin-modules";
|
|
11
|
+
|
|
12
|
+
// #region Warning Handler
|
|
13
|
+
|
|
14
|
+
/**
|
|
15
|
+
* A function that can determine whether a rollup warning should be ignored. If
|
|
16
|
+
* the function returns `true`, then the warning will not be displayed.
|
|
17
|
+
*/
|
|
18
|
+
|
|
19
|
+
function ignoreNiseSinonEval(warning) {
|
|
20
|
+
return (
|
|
21
|
+
warning.code === "EVAL" &&
|
|
22
|
+
warning.id &&
|
|
23
|
+
(warning.id.includes("node_modules/nise") ||
|
|
24
|
+
warning.id.includes("node_modules/sinon")) === true
|
|
25
|
+
);
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
function ignoreChaiCircularDependency(warning) {
|
|
29
|
+
return (
|
|
30
|
+
warning.code === "CIRCULAR_DEPENDENCY" &&
|
|
31
|
+
warning.importer &&
|
|
32
|
+
warning.importer.includes("node_modules/chai") === true
|
|
33
|
+
);
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
const warningInhibitors = [ignoreChaiCircularDependency, ignoreNiseSinonEval];
|
|
37
|
+
|
|
38
|
+
/**
|
|
39
|
+
* Construct a warning handler for the shared rollup configuration
|
|
40
|
+
* that ignores certain warnings that are not relevant to testing.
|
|
41
|
+
*/
|
|
42
|
+
function makeOnWarnForTesting() {
|
|
43
|
+
return (warning, warn) => {
|
|
44
|
+
// If every inhibitor returns false (i.e. no inhibitors), then show the warning
|
|
45
|
+
if (warningInhibitors.every((inhib) => !inhib(warning))) {
|
|
46
|
+
warn(warning);
|
|
47
|
+
}
|
|
48
|
+
};
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
// #endregion
|
|
52
|
+
|
|
53
|
+
function makeBrowserTestConfig() {
|
|
54
|
+
const config = {
|
|
55
|
+
input: {
|
|
56
|
+
include: ["dist-esm/test/**/*.spec.js"],
|
|
57
|
+
exclude: ["dist-esm/test/**/node/**"],
|
|
58
|
+
},
|
|
59
|
+
output: {
|
|
60
|
+
file: `dist-test/index.browser.js`,
|
|
61
|
+
format: "umd",
|
|
62
|
+
sourcemap: true,
|
|
63
|
+
},
|
|
64
|
+
preserveSymlinks: false,
|
|
65
|
+
plugins: [
|
|
66
|
+
multiEntry({ exports: false }),
|
|
67
|
+
nodeResolve({
|
|
68
|
+
mainFields: ["module", "browser"],
|
|
69
|
+
}),
|
|
70
|
+
cjs(),
|
|
71
|
+
json(),
|
|
72
|
+
sourcemaps(),
|
|
73
|
+
//viz({ filename: "dist-test/browser-stats.html", sourcemap: true })
|
|
74
|
+
],
|
|
75
|
+
onwarn: makeOnWarnForTesting(),
|
|
76
|
+
// Disable tree-shaking of test code. In rollup-plugin-node-resolve@5.0.0,
|
|
77
|
+
// rollup started respecting the "sideEffects" field in package.json. Since
|
|
78
|
+
// our package.json sets "sideEffects=false", this also applies to test
|
|
79
|
+
// code, which causes all tests to be removed by tree-shaking.
|
|
80
|
+
treeshake: false,
|
|
81
|
+
};
|
|
82
|
+
|
|
83
|
+
return config;
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
const defaultConfigurationOptions = {
|
|
87
|
+
disableBrowserBundle: false,
|
|
88
|
+
};
|
|
89
|
+
|
|
90
|
+
export function makeConfig(pkg, options) {
|
|
91
|
+
options = {
|
|
92
|
+
...defaultConfigurationOptions,
|
|
93
|
+
...(options || {}),
|
|
94
|
+
};
|
|
95
|
+
|
|
96
|
+
const baseConfig = {
|
|
97
|
+
// Use the package's module field if it has one
|
|
98
|
+
input: pkg["module"] || "dist-esm/src/index.js",
|
|
99
|
+
external: [
|
|
100
|
+
...nodeBuiltins,
|
|
101
|
+
...Object.keys(pkg.dependencies),
|
|
102
|
+
...Object.keys(pkg.devDependencies),
|
|
103
|
+
],
|
|
104
|
+
output: { file: "dist/index.js", format: "cjs", sourcemap: true },
|
|
105
|
+
preserveSymlinks: false,
|
|
106
|
+
plugins: [sourcemaps(), nodeResolve()],
|
|
107
|
+
};
|
|
108
|
+
|
|
109
|
+
const config = [baseConfig];
|
|
110
|
+
|
|
111
|
+
if (!options.disableBrowserBundle) {
|
|
112
|
+
config.push(makeBrowserTestConfig());
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
return config;
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
export default makeConfig(require("./package.json"));
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
// Copyright (c) Microsoft Corporation.
|
|
2
|
+
// Licensed under the MIT license.
|
|
3
|
+
|
|
4
|
+
import {
|
|
5
|
+
GetKnownValueParameters,
|
|
6
|
+
PutKnownValueParameters,
|
|
7
|
+
GetUnknownValueParameters,
|
|
8
|
+
PutUnknownValueParameters,
|
|
9
|
+
} from "./parameters";
|
|
10
|
+
import {
|
|
11
|
+
GetKnownValue200Response,
|
|
12
|
+
PutKnownValue204Response,
|
|
13
|
+
GetUnknownValue200Response,
|
|
14
|
+
PutUnknownValue204Response,
|
|
15
|
+
} from "./responses";
|
|
16
|
+
import { Client, StreamableMethod } from "@azure-rest/core-client";
|
|
17
|
+
|
|
18
|
+
export interface GetKnownValue {
|
|
19
|
+
get(
|
|
20
|
+
options?: GetKnownValueParameters
|
|
21
|
+
): StreamableMethod<GetKnownValue200Response>;
|
|
22
|
+
put(
|
|
23
|
+
options: PutKnownValueParameters
|
|
24
|
+
): StreamableMethod<PutKnownValue204Response>;
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
export interface GetUnknownValue {
|
|
28
|
+
get(
|
|
29
|
+
options?: GetUnknownValueParameters
|
|
30
|
+
): StreamableMethod<GetUnknownValue200Response>;
|
|
31
|
+
put(
|
|
32
|
+
options: PutUnknownValueParameters
|
|
33
|
+
): StreamableMethod<PutUnknownValue204Response>;
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
export interface Routes {
|
|
37
|
+
/** Resource for '/enums/extensible/string/known-value' has methods for the following verbs: get, put */
|
|
38
|
+
(path: "/enums/extensible/string/known-value"): GetKnownValue;
|
|
39
|
+
/** Resource for '/enums/extensible/string/unknown-value' has methods for the following verbs: get, put */
|
|
40
|
+
(path: "/enums/extensible/string/unknown-value"): GetUnknownValue;
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
export type EnumsExtensibleClient = Client & {
|
|
44
|
+
path: Routes;
|
|
45
|
+
};
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
// Copyright (c) Microsoft Corporation.
|
|
2
|
+
// Licensed under the MIT license.
|
|
3
|
+
|
|
4
|
+
import { getClient, ClientOptions } from "@azure-rest/core-client";
|
|
5
|
+
import { EnumsExtensibleClient } from "./clientDefinitions";
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* Initialize a new instance of `EnumsExtensibleClient`
|
|
9
|
+
* @param options type: ClientOptions, the parameter for all optional parameters
|
|
10
|
+
*/
|
|
11
|
+
export default function createClient(
|
|
12
|
+
options: ClientOptions = {}
|
|
13
|
+
): EnumsExtensibleClient {
|
|
14
|
+
const baseUrl = options.baseUrl ?? `http://localhost:3000`;
|
|
15
|
+
options.apiVersion = options.apiVersion ?? "1.0.0";
|
|
16
|
+
const userAgentInfo = `azsdk-js-extensible-enums-rest/1.0.0`;
|
|
17
|
+
const userAgentPrefix =
|
|
18
|
+
options.userAgentOptions && options.userAgentOptions.userAgentPrefix
|
|
19
|
+
? `${options.userAgentOptions.userAgentPrefix} ${userAgentInfo}`
|
|
20
|
+
: `${userAgentInfo}`;
|
|
21
|
+
options = {
|
|
22
|
+
...options,
|
|
23
|
+
userAgentOptions: {
|
|
24
|
+
userAgentPrefix,
|
|
25
|
+
},
|
|
26
|
+
};
|
|
27
|
+
|
|
28
|
+
const client = getClient(baseUrl, options) as EnumsExtensibleClient;
|
|
29
|
+
|
|
30
|
+
return client;
|
|
31
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
// Copyright (c) Microsoft Corporation.
|
|
2
|
+
// Licensed under the MIT license.
|
|
3
|
+
|
|
4
|
+
import EnumsExtensible from "./enumsExtensible";
|
|
5
|
+
|
|
6
|
+
export * from "./enumsExtensible";
|
|
7
|
+
export * from "./parameters";
|
|
8
|
+
export * from "./responses";
|
|
9
|
+
export * from "./clientDefinitions";
|
|
10
|
+
|
|
11
|
+
export default EnumsExtensible;
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
// Copyright (c) Microsoft Corporation.
|
|
2
|
+
// Licensed under the MIT license.
|
|
3
|
+
|
|
4
|
+
import { RequestParameters } from "@azure-rest/core-client";
|
|
5
|
+
|
|
6
|
+
export type GetKnownValueParameters = RequestParameters;
|
|
7
|
+
export type GetUnknownValueParameters = RequestParameters;
|
|
8
|
+
|
|
9
|
+
export interface PutKnownValueBodyParam {
|
|
10
|
+
/** Possible values: Monday, Tuesday, Wednesday, Thursday, Friday, Saturday, Sunday */
|
|
11
|
+
body: string;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
export type PutKnownValueParameters = PutKnownValueBodyParam &
|
|
15
|
+
RequestParameters;
|
|
16
|
+
|
|
17
|
+
export interface PutUnknownValueBodyParam {
|
|
18
|
+
/** Possible values: Monday, Tuesday, Wednesday, Thursday, Friday, Saturday, Sunday */
|
|
19
|
+
body: string;
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
export type PutUnknownValueParameters = PutUnknownValueBodyParam &
|
|
23
|
+
RequestParameters;
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
// Copyright (c) Microsoft Corporation.
|
|
2
|
+
// Licensed under the MIT license.
|
|
3
|
+
|
|
4
|
+
import { HttpResponse } from "@azure-rest/core-client";
|
|
5
|
+
|
|
6
|
+
/** The request has succeeded. */
|
|
7
|
+
export interface GetKnownValue200Response extends HttpResponse {
|
|
8
|
+
status: "200";
|
|
9
|
+
body: string;
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
/** The request has succeeded. */
|
|
13
|
+
export interface GetUnknownValue200Response extends HttpResponse {
|
|
14
|
+
status: "200";
|
|
15
|
+
body: string;
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
/** There is no content to send for this request, but the headers may be useful. */
|
|
19
|
+
export interface PutKnownValue204Response extends HttpResponse {
|
|
20
|
+
status: "204";
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
/** There is no content to send for this request, but the headers may be useful. */
|
|
24
|
+
export interface PutUnknownValue204Response extends HttpResponse {
|
|
25
|
+
status: "204";
|
|
26
|
+
}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
{
|
|
2
|
+
"compilerOptions": {
|
|
3
|
+
"target": "ES2017",
|
|
4
|
+
"module": "es6",
|
|
5
|
+
"lib": [],
|
|
6
|
+
"declaration": true,
|
|
7
|
+
"declarationMap": true,
|
|
8
|
+
"inlineSources": true,
|
|
9
|
+
"sourceMap": true,
|
|
10
|
+
"importHelpers": true,
|
|
11
|
+
"strict": true,
|
|
12
|
+
"alwaysStrict": true,
|
|
13
|
+
"noUnusedLocals": true,
|
|
14
|
+
"noUnusedParameters": true,
|
|
15
|
+
"noImplicitReturns": true,
|
|
16
|
+
"noFallthroughCasesInSwitch": true,
|
|
17
|
+
"forceConsistentCasingInFileNames": true,
|
|
18
|
+
"moduleResolution": "node",
|
|
19
|
+
"allowSyntheticDefaultImports": true,
|
|
20
|
+
"esModuleInterop": true,
|
|
21
|
+
"outDir": "./dist-esm",
|
|
22
|
+
"declarationDir": "./types"
|
|
23
|
+
},
|
|
24
|
+
"include": ["./src/**/*.ts"]
|
|
25
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
emitters:
|
|
2
|
+
"../../../../../../../../../../../packages/typespec-ts/dist/src/index.js":
|
|
3
|
+
generateMetadata: true
|
|
4
|
+
generateTest: false
|
|
5
|
+
addCredentials: false
|
|
6
|
+
azureSdkForJs: false
|
|
7
|
+
isCadlTest: true
|
|
8
|
+
packageDetails:
|
|
9
|
+
name: "@msinternal/extensible-enums"
|
|
10
|
+
description: "Extensible Enums Test Service"
|
|
11
|
+
version: "1.0.0"
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
{
|
|
2
|
+
"plugins": ["@azure/azure-sdk"],
|
|
3
|
+
"extends": ["plugin:@azure/azure-sdk/azure-sdk-base"],
|
|
4
|
+
"rules": {
|
|
5
|
+
"@azure/azure-sdk/ts-modules-only-named": "warn",
|
|
6
|
+
"@azure/azure-sdk/ts-apiextractor-json-types": "warn",
|
|
7
|
+
"@azure/azure-sdk/ts-package-json-types": "warn",
|
|
8
|
+
"@azure/azure-sdk/ts-package-json-engine-is-present": "warn",
|
|
9
|
+
"tsdoc/syntax": "warn"
|
|
10
|
+
}
|
|
11
|
+
}
|