@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,147 @@
|
|
|
1
|
+
// Copyright (c) Microsoft Corporation.
|
|
2
|
+
// Licensed under the MIT license.
|
|
3
|
+
|
|
4
|
+
import { RequestParameters } from "@azure-rest/core-client";
|
|
5
|
+
import {
|
|
6
|
+
BooleanProperty,
|
|
7
|
+
StringProperty,
|
|
8
|
+
BytesProperty,
|
|
9
|
+
IntProperty,
|
|
10
|
+
FloatProperty,
|
|
11
|
+
DatetimeProperty,
|
|
12
|
+
DurationProperty,
|
|
13
|
+
EnumProperty,
|
|
14
|
+
ExtensibleEnumProperty,
|
|
15
|
+
ModelProperty,
|
|
16
|
+
CollectionsStringProperty,
|
|
17
|
+
CollectionsIntProperty,
|
|
18
|
+
CollectionsModelProperty,
|
|
19
|
+
DictionaryStringProperty,
|
|
20
|
+
NeverProperty,
|
|
21
|
+
} from "./models";
|
|
22
|
+
|
|
23
|
+
export type BooleanGetParameters = RequestParameters;
|
|
24
|
+
|
|
25
|
+
export interface BooleanPutBodyParam {
|
|
26
|
+
/** body */
|
|
27
|
+
body: BooleanProperty;
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
export type BooleanPutParameters = BooleanPutBodyParam & RequestParameters;
|
|
31
|
+
export type StringGetParameters = RequestParameters;
|
|
32
|
+
|
|
33
|
+
export interface StringPutBodyParam {
|
|
34
|
+
/** body */
|
|
35
|
+
body: StringProperty;
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
export type StringPutParameters = StringPutBodyParam & RequestParameters;
|
|
39
|
+
export type BytesGetParameters = RequestParameters;
|
|
40
|
+
|
|
41
|
+
export interface BytesPutBodyParam {
|
|
42
|
+
/** body */
|
|
43
|
+
body: BytesProperty;
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
export type BytesPutParameters = BytesPutBodyParam & RequestParameters;
|
|
47
|
+
export type IntGetParameters = RequestParameters;
|
|
48
|
+
|
|
49
|
+
export interface IntPutBodyParam {
|
|
50
|
+
/** body */
|
|
51
|
+
body: IntProperty;
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
export type IntPutParameters = IntPutBodyParam & RequestParameters;
|
|
55
|
+
export type FloatGetParameters = RequestParameters;
|
|
56
|
+
|
|
57
|
+
export interface FloatPutBodyParam {
|
|
58
|
+
/** body */
|
|
59
|
+
body: FloatProperty;
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
export type FloatPutParameters = FloatPutBodyParam & RequestParameters;
|
|
63
|
+
export type DatetimeGetParameters = RequestParameters;
|
|
64
|
+
|
|
65
|
+
export interface DatetimePutBodyParam {
|
|
66
|
+
/** body */
|
|
67
|
+
body: DatetimeProperty;
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
export type DatetimePutParameters = DatetimePutBodyParam & RequestParameters;
|
|
71
|
+
export type DurationGetParameters = RequestParameters;
|
|
72
|
+
|
|
73
|
+
export interface DurationPutBodyParam {
|
|
74
|
+
/** body */
|
|
75
|
+
body: DurationProperty;
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
export type DurationPutParameters = DurationPutBodyParam & RequestParameters;
|
|
79
|
+
export type EnumGetParameters = RequestParameters;
|
|
80
|
+
|
|
81
|
+
export interface EnumPutBodyParam {
|
|
82
|
+
/** body */
|
|
83
|
+
body: EnumProperty;
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
export type EnumPutParameters = EnumPutBodyParam & RequestParameters;
|
|
87
|
+
export type ExtensibleEnumGetParameters = RequestParameters;
|
|
88
|
+
|
|
89
|
+
export interface ExtensibleEnumPutBodyParam {
|
|
90
|
+
/** body */
|
|
91
|
+
body: ExtensibleEnumProperty;
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
export type ExtensibleEnumPutParameters = ExtensibleEnumPutBodyParam &
|
|
95
|
+
RequestParameters;
|
|
96
|
+
export type ModelGetParameters = RequestParameters;
|
|
97
|
+
|
|
98
|
+
export interface ModelPutBodyParam {
|
|
99
|
+
/** body */
|
|
100
|
+
body: ModelProperty;
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
export type ModelPutParameters = ModelPutBodyParam & RequestParameters;
|
|
104
|
+
export type CollectionsStringGetParameters = RequestParameters;
|
|
105
|
+
|
|
106
|
+
export interface CollectionsStringPutBodyParam {
|
|
107
|
+
/** body */
|
|
108
|
+
body: CollectionsStringProperty;
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
export type CollectionsStringPutParameters = CollectionsStringPutBodyParam &
|
|
112
|
+
RequestParameters;
|
|
113
|
+
export type CollectionsIntGetParameters = RequestParameters;
|
|
114
|
+
|
|
115
|
+
export interface CollectionsIntPutBodyParam {
|
|
116
|
+
/** body */
|
|
117
|
+
body: CollectionsIntProperty;
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
export type CollectionsIntPutParameters = CollectionsIntPutBodyParam &
|
|
121
|
+
RequestParameters;
|
|
122
|
+
export type CollectionsModelGetParameters = RequestParameters;
|
|
123
|
+
|
|
124
|
+
export interface CollectionsModelPutBodyParam {
|
|
125
|
+
/** body */
|
|
126
|
+
body: CollectionsModelProperty;
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
export type CollectionsModelPutParameters = CollectionsModelPutBodyParam &
|
|
130
|
+
RequestParameters;
|
|
131
|
+
export type DictionaryStringGetParameters = RequestParameters;
|
|
132
|
+
|
|
133
|
+
export interface DictionaryStringPutBodyParam {
|
|
134
|
+
/** body */
|
|
135
|
+
body: DictionaryStringProperty;
|
|
136
|
+
}
|
|
137
|
+
|
|
138
|
+
export type DictionaryStringPutParameters = DictionaryStringPutBodyParam &
|
|
139
|
+
RequestParameters;
|
|
140
|
+
export type NeverGetParameters = RequestParameters;
|
|
141
|
+
|
|
142
|
+
export interface NeverPutBodyParam {
|
|
143
|
+
/** body */
|
|
144
|
+
body: NeverProperty;
|
|
145
|
+
}
|
|
146
|
+
|
|
147
|
+
export type NeverPutParameters = NeverPutBodyParam & RequestParameters;
|
|
@@ -0,0 +1,186 @@
|
|
|
1
|
+
// Copyright (c) Microsoft Corporation.
|
|
2
|
+
// Licensed under the MIT license.
|
|
3
|
+
|
|
4
|
+
import { HttpResponse } from "@azure-rest/core-client";
|
|
5
|
+
import {
|
|
6
|
+
BooleanPropertyOutput,
|
|
7
|
+
StringPropertyOutput,
|
|
8
|
+
BytesPropertyOutput,
|
|
9
|
+
IntPropertyOutput,
|
|
10
|
+
FloatPropertyOutput,
|
|
11
|
+
DatetimePropertyOutput,
|
|
12
|
+
DurationPropertyOutput,
|
|
13
|
+
EnumPropertyOutput,
|
|
14
|
+
ExtensibleEnumPropertyOutput,
|
|
15
|
+
ModelPropertyOutput,
|
|
16
|
+
CollectionsStringPropertyOutput,
|
|
17
|
+
CollectionsIntPropertyOutput,
|
|
18
|
+
CollectionsModelPropertyOutput,
|
|
19
|
+
DictionaryStringPropertyOutput,
|
|
20
|
+
NeverPropertyOutput,
|
|
21
|
+
} from "./outputModels";
|
|
22
|
+
|
|
23
|
+
/** The request has succeeded. */
|
|
24
|
+
export interface BooleanGet200Response extends HttpResponse {
|
|
25
|
+
status: "200";
|
|
26
|
+
body: BooleanPropertyOutput;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
/** There is no content to send for this request, but the headers may be useful. */
|
|
30
|
+
export interface BooleanPut204Response extends HttpResponse {
|
|
31
|
+
status: "204";
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
/** The request has succeeded. */
|
|
35
|
+
export interface StringGet200Response extends HttpResponse {
|
|
36
|
+
status: "200";
|
|
37
|
+
body: StringPropertyOutput;
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
/** There is no content to send for this request, but the headers may be useful. */
|
|
41
|
+
export interface StringPut204Response extends HttpResponse {
|
|
42
|
+
status: "204";
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
/** The request has succeeded. */
|
|
46
|
+
export interface BytesGet200Response extends HttpResponse {
|
|
47
|
+
status: "200";
|
|
48
|
+
body: BytesPropertyOutput;
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
/** There is no content to send for this request, but the headers may be useful. */
|
|
52
|
+
export interface BytesPut204Response extends HttpResponse {
|
|
53
|
+
status: "204";
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
/** The request has succeeded. */
|
|
57
|
+
export interface IntGet200Response extends HttpResponse {
|
|
58
|
+
status: "200";
|
|
59
|
+
body: IntPropertyOutput;
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
/** There is no content to send for this request, but the headers may be useful. */
|
|
63
|
+
export interface IntPut204Response extends HttpResponse {
|
|
64
|
+
status: "204";
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
/** The request has succeeded. */
|
|
68
|
+
export interface FloatGet200Response extends HttpResponse {
|
|
69
|
+
status: "200";
|
|
70
|
+
body: FloatPropertyOutput;
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
/** There is no content to send for this request, but the headers may be useful. */
|
|
74
|
+
export interface FloatPut204Response extends HttpResponse {
|
|
75
|
+
status: "204";
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
/** The request has succeeded. */
|
|
79
|
+
export interface DatetimeGet200Response extends HttpResponse {
|
|
80
|
+
status: "200";
|
|
81
|
+
body: DatetimePropertyOutput;
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
/** There is no content to send for this request, but the headers may be useful. */
|
|
85
|
+
export interface DatetimePut204Response extends HttpResponse {
|
|
86
|
+
status: "204";
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
/** The request has succeeded. */
|
|
90
|
+
export interface DurationGet200Response extends HttpResponse {
|
|
91
|
+
status: "200";
|
|
92
|
+
body: DurationPropertyOutput;
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
/** There is no content to send for this request, but the headers may be useful. */
|
|
96
|
+
export interface DurationPut204Response extends HttpResponse {
|
|
97
|
+
status: "204";
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
/** The request has succeeded. */
|
|
101
|
+
export interface EnumGet200Response extends HttpResponse {
|
|
102
|
+
status: "200";
|
|
103
|
+
body: EnumPropertyOutput;
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
/** There is no content to send for this request, but the headers may be useful. */
|
|
107
|
+
export interface EnumPut204Response extends HttpResponse {
|
|
108
|
+
status: "204";
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
/** The request has succeeded. */
|
|
112
|
+
export interface ExtensibleEnumGet200Response extends HttpResponse {
|
|
113
|
+
status: "200";
|
|
114
|
+
body: ExtensibleEnumPropertyOutput;
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
/** There is no content to send for this request, but the headers may be useful. */
|
|
118
|
+
export interface ExtensibleEnumPut204Response extends HttpResponse {
|
|
119
|
+
status: "204";
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
/** The request has succeeded. */
|
|
123
|
+
export interface ModelGet200Response extends HttpResponse {
|
|
124
|
+
status: "200";
|
|
125
|
+
body: ModelPropertyOutput;
|
|
126
|
+
}
|
|
127
|
+
|
|
128
|
+
/** There is no content to send for this request, but the headers may be useful. */
|
|
129
|
+
export interface ModelPut204Response extends HttpResponse {
|
|
130
|
+
status: "204";
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
/** The request has succeeded. */
|
|
134
|
+
export interface CollectionsStringGet200Response extends HttpResponse {
|
|
135
|
+
status: "200";
|
|
136
|
+
body: CollectionsStringPropertyOutput;
|
|
137
|
+
}
|
|
138
|
+
|
|
139
|
+
/** There is no content to send for this request, but the headers may be useful. */
|
|
140
|
+
export interface CollectionsStringPut204Response extends HttpResponse {
|
|
141
|
+
status: "204";
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
/** The request has succeeded. */
|
|
145
|
+
export interface CollectionsIntGet200Response extends HttpResponse {
|
|
146
|
+
status: "200";
|
|
147
|
+
body: CollectionsIntPropertyOutput;
|
|
148
|
+
}
|
|
149
|
+
|
|
150
|
+
/** There is no content to send for this request, but the headers may be useful. */
|
|
151
|
+
export interface CollectionsIntPut204Response extends HttpResponse {
|
|
152
|
+
status: "204";
|
|
153
|
+
}
|
|
154
|
+
|
|
155
|
+
/** The request has succeeded. */
|
|
156
|
+
export interface CollectionsModelGet200Response extends HttpResponse {
|
|
157
|
+
status: "200";
|
|
158
|
+
body: CollectionsModelPropertyOutput;
|
|
159
|
+
}
|
|
160
|
+
|
|
161
|
+
/** There is no content to send for this request, but the headers may be useful. */
|
|
162
|
+
export interface CollectionsModelPut204Response extends HttpResponse {
|
|
163
|
+
status: "204";
|
|
164
|
+
}
|
|
165
|
+
|
|
166
|
+
/** The request has succeeded. */
|
|
167
|
+
export interface DictionaryStringGet200Response extends HttpResponse {
|
|
168
|
+
status: "200";
|
|
169
|
+
body: DictionaryStringPropertyOutput;
|
|
170
|
+
}
|
|
171
|
+
|
|
172
|
+
/** There is no content to send for this request, but the headers may be useful. */
|
|
173
|
+
export interface DictionaryStringPut204Response extends HttpResponse {
|
|
174
|
+
status: "204";
|
|
175
|
+
}
|
|
176
|
+
|
|
177
|
+
/** The request has succeeded. */
|
|
178
|
+
export interface NeverGet200Response extends HttpResponse {
|
|
179
|
+
status: "200";
|
|
180
|
+
body: NeverPropertyOutput;
|
|
181
|
+
}
|
|
182
|
+
|
|
183
|
+
/** There is no content to send for this request, but the headers may be useful. */
|
|
184
|
+
export interface NeverPut204Response extends HttpResponse {
|
|
185
|
+
status: "204";
|
|
186
|
+
}
|
|
@@ -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/property-types"
|
|
10
|
+
description: "Property Types 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
|
+
}
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
# ModelsUsage REST client library for JavaScript
|
|
2
|
+
|
|
3
|
+
Illustrates usage of Record in different places(Operation parameters, return type or both).
|
|
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/usage)
|
|
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/usage` package
|
|
22
|
+
|
|
23
|
+
Install the ModelsUsage REST client REST client library for JavaScript with `npm`:
|
|
24
|
+
|
|
25
|
+
```bash
|
|
26
|
+
npm install @msinternal/usage
|
|
27
|
+
```
|
|
28
|
+
|
|
29
|
+
### Create and authenticate a `ModelsUsageClient`
|
|
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/usage.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/usage",
|
|
3
|
+
"sdk-type": "client",
|
|
4
|
+
"author": "Microsoft Corporation",
|
|
5
|
+
"version": "1.0.0",
|
|
6
|
+
"description": "Usage 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/usage.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/usage.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"));
|