@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,56 @@
|
|
|
1
|
+
# AuthApiKey REST client library for JavaScript
|
|
2
|
+
|
|
3
|
+
Illustrates clients generated with ApiKey authentication.
|
|
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/auth-apikey)
|
|
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/auth-apikey` package
|
|
22
|
+
|
|
23
|
+
Install the AuthApiKey REST client REST client library for JavaScript with `npm`:
|
|
24
|
+
|
|
25
|
+
```bash
|
|
26
|
+
npm install @msinternal/auth-apikey
|
|
27
|
+
```
|
|
28
|
+
|
|
29
|
+
### Create and authenticate a `AuthApiKeyClient`
|
|
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/src/index.d.ts",
|
|
4
|
+
"docModel": { "enabled": true },
|
|
5
|
+
"apiReport": { "enabled": true, "reportFolder": "./review" },
|
|
6
|
+
"dtsRollup": {
|
|
7
|
+
"enabled": true,
|
|
8
|
+
"untrimmedFilePath": "",
|
|
9
|
+
"publicTrimmedFilePath": "./types/auth-apikey.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,133 @@
|
|
|
1
|
+
// Copyright (c) Microsoft Corporation.
|
|
2
|
+
// Licensed under the MIT license.
|
|
3
|
+
|
|
4
|
+
// https://github.com/karma-runner/karma-chrome-launcher
|
|
5
|
+
process.env.CHROME_BIN = require("puppeteer").executablePath();
|
|
6
|
+
require("dotenv").config();
|
|
7
|
+
const { relativeRecordingsPath } = require("@azure-tools/test-recorder");
|
|
8
|
+
process.env.RECORDINGS_RELATIVE_PATH = relativeRecordingsPath();
|
|
9
|
+
|
|
10
|
+
module.exports = function (config) {
|
|
11
|
+
config.set({
|
|
12
|
+
// base path that will be used to resolve all patterns (eg. files, exclude)
|
|
13
|
+
basePath: "./",
|
|
14
|
+
|
|
15
|
+
// frameworks to use
|
|
16
|
+
// available frameworks: https://npmjs.org/browse/keyword/karma-adapter
|
|
17
|
+
frameworks: ["source-map-support", "mocha"],
|
|
18
|
+
|
|
19
|
+
plugins: [
|
|
20
|
+
"karma-mocha",
|
|
21
|
+
"karma-mocha-reporter",
|
|
22
|
+
"karma-chrome-launcher",
|
|
23
|
+
"karma-firefox-launcher",
|
|
24
|
+
"karma-env-preprocessor",
|
|
25
|
+
"karma-coverage",
|
|
26
|
+
"karma-sourcemap-loader",
|
|
27
|
+
"karma-junit-reporter",
|
|
28
|
+
"karma-source-map-support",
|
|
29
|
+
],
|
|
30
|
+
|
|
31
|
+
// list of files / patterns to load in the browser
|
|
32
|
+
files: [
|
|
33
|
+
"dist-test/index.browser.js",
|
|
34
|
+
{
|
|
35
|
+
pattern: "dist-test/index.browser.js.map",
|
|
36
|
+
type: "html",
|
|
37
|
+
included: false,
|
|
38
|
+
served: true,
|
|
39
|
+
},
|
|
40
|
+
],
|
|
41
|
+
|
|
42
|
+
// list of files / patterns to exclude
|
|
43
|
+
exclude: [],
|
|
44
|
+
|
|
45
|
+
// preprocess matching files before serving them to the browser
|
|
46
|
+
// available preprocessors: https://npmjs.org/browse/keyword/karma-preprocessor
|
|
47
|
+
preprocessors: {
|
|
48
|
+
"**/*.js": ["sourcemap", "env"],
|
|
49
|
+
// IMPORTANT: COMMENT following line if you want to debug in your browsers!!
|
|
50
|
+
// Preprocess source file to calculate code coverage, however this will make source file unreadable
|
|
51
|
+
// "dist-test/index.js": ["coverage"]
|
|
52
|
+
},
|
|
53
|
+
|
|
54
|
+
envPreprocessor: [
|
|
55
|
+
"TEST_MODE",
|
|
56
|
+
"ENDPOINT",
|
|
57
|
+
"AZURE_CLIENT_SECRET",
|
|
58
|
+
"AZURE_CLIENT_ID",
|
|
59
|
+
"AZURE_TENANT_ID",
|
|
60
|
+
"SUBSCRIPTION_ID",
|
|
61
|
+
"RECORDINGS_RELATIVE_PATH",
|
|
62
|
+
],
|
|
63
|
+
|
|
64
|
+
// test results reporter to use
|
|
65
|
+
// possible values: 'dots', 'progress'
|
|
66
|
+
// available reporters: https://npmjs.org/browse/keyword/karma-reporter
|
|
67
|
+
reporters: ["mocha", "coverage", "junit"],
|
|
68
|
+
|
|
69
|
+
coverageReporter: {
|
|
70
|
+
// specify a common output directory
|
|
71
|
+
dir: "coverage-browser/",
|
|
72
|
+
reporters: [
|
|
73
|
+
{ type: "json", subdir: ".", file: "coverage.json" },
|
|
74
|
+
{ type: "lcovonly", subdir: ".", file: "lcov.info" },
|
|
75
|
+
{ type: "html", subdir: "html" },
|
|
76
|
+
{ type: "cobertura", subdir: ".", file: "cobertura-coverage.xml" },
|
|
77
|
+
],
|
|
78
|
+
},
|
|
79
|
+
|
|
80
|
+
junitReporter: {
|
|
81
|
+
outputDir: "", // results will be saved as $outputDir/$browserName.xml
|
|
82
|
+
outputFile: "test-results.browser.xml", // if included, results will be saved as $outputDir/$browserName/$outputFile
|
|
83
|
+
suite: "", // suite will become the package name attribute in xml testsuite element
|
|
84
|
+
useBrowserName: false, // add browser name to report and classes names
|
|
85
|
+
nameFormatter: undefined, // function (browser, result) to customize the name attribute in xml testcase element
|
|
86
|
+
classNameFormatter: undefined, // function (browser, result) to customize the classname attribute in xml testcase element
|
|
87
|
+
properties: {}, // key value pair of properties to add to the <properties> section of the report
|
|
88
|
+
},
|
|
89
|
+
|
|
90
|
+
// web server port
|
|
91
|
+
port: 9876,
|
|
92
|
+
|
|
93
|
+
// enable / disable colors in the output (reporters and logs)
|
|
94
|
+
colors: true,
|
|
95
|
+
|
|
96
|
+
// level of logging
|
|
97
|
+
// possible values: config.LOG_DISABLE || config.LOG_ERROR || config.LOG_WARN || config.LOG_INFO || config.LOG_DEBUG
|
|
98
|
+
logLevel: config.LOG_INFO,
|
|
99
|
+
|
|
100
|
+
// enable / disable watching file and executing tests whenever any file changes
|
|
101
|
+
autoWatch: false,
|
|
102
|
+
|
|
103
|
+
// --no-sandbox allows our tests to run in Linux without having to change the system.
|
|
104
|
+
// --disable-web-security allows us to authenticate from the browser without having to write tests using interactive auth, which would be far more complex.
|
|
105
|
+
browsers: ["ChromeHeadlessNoSandbox"],
|
|
106
|
+
customLaunchers: {
|
|
107
|
+
ChromeHeadlessNoSandbox: {
|
|
108
|
+
base: "ChromeHeadless",
|
|
109
|
+
flags: ["--no-sandbox", "--disable-web-security"],
|
|
110
|
+
},
|
|
111
|
+
},
|
|
112
|
+
|
|
113
|
+
// Continuous Integration mode
|
|
114
|
+
// if true, Karma captures browsers, runs the tests and exits
|
|
115
|
+
singleRun: false,
|
|
116
|
+
|
|
117
|
+
// Concurrency level
|
|
118
|
+
// how many browser should be started simultaneous
|
|
119
|
+
concurrency: 1,
|
|
120
|
+
|
|
121
|
+
browserNoActivityTimeout: 60000000,
|
|
122
|
+
browserDisconnectTimeout: 10000,
|
|
123
|
+
browserDisconnectTolerance: 3,
|
|
124
|
+
|
|
125
|
+
client: {
|
|
126
|
+
mocha: {
|
|
127
|
+
// change Karma's debug.html to the mocha web reporter
|
|
128
|
+
reporter: "html",
|
|
129
|
+
timeout: "600000",
|
|
130
|
+
},
|
|
131
|
+
},
|
|
132
|
+
});
|
|
133
|
+
};
|
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@msinternal/auth-apikey",
|
|
3
|
+
"sdk-type": "client",
|
|
4
|
+
"author": "Microsoft Corporation",
|
|
5
|
+
"version": "1.0.0",
|
|
6
|
+
"description": "Auth api key Test Service",
|
|
7
|
+
"keywords": ["node", "azure", "cloud", "typescript", "browser", "isomorphic"],
|
|
8
|
+
"license": "MIT",
|
|
9
|
+
"main": "dist/index.js",
|
|
10
|
+
"module": "./dist-esm/src/index.js",
|
|
11
|
+
"types": "./types/auth-apikey.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/src/",
|
|
17
|
+
"types/auth-apikey.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": "tsc -p . && cross-env ONLY_BROWSER=true rollup -c 2>&1",
|
|
26
|
+
"build:node": "tsc -p . && cross-env ONLY_NODE=true rollup -c 2>&1",
|
|
27
|
+
"build:samples": "echo skipped.",
|
|
28
|
+
"build:test": "tsc -p . && rollup -c 2>&1",
|
|
29
|
+
"build:debug": "echo skipped.",
|
|
30
|
+
"check-format": "prettier --list-different --config ../../../.prettierrc.json --ignore-path ../../../.prettierignore \"src/**/*.ts\" \"*.{js,json}\" \"test/**/*.ts\"",
|
|
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}\" \"test/**/*.ts\"",
|
|
35
|
+
"generate:client": "echo skipped",
|
|
36
|
+
"integration-test:browser": "karma start --single-run",
|
|
37
|
+
"integration-test:node": "nyc mocha -r esm --require source-map-support/register --reporter ../../../common/tools/mocha-multi-reporter.js --timeout 5000000 --full-trace \"dist-esm/test/{,!(browser)/**/}*.spec.js\"",
|
|
38
|
+
"integration-test": "npm run integration-test:node && npm run integration-test:browser",
|
|
39
|
+
"lint:fix": "eslint package.json api-extractor.json src test --ext .ts --fix --fix-type [problem,suggestion]",
|
|
40
|
+
"lint": "eslint package.json api-extractor.json src test --ext .ts",
|
|
41
|
+
"pack": "npm pack 2>&1",
|
|
42
|
+
"test:browser": "npm run clean && npm run build:test && npm run unit-test:browser",
|
|
43
|
+
"test:node": "npm run clean && npm run build:test && npm run unit-test:node",
|
|
44
|
+
"test": "npm run clean && npm run build:test && npm run unit-test",
|
|
45
|
+
"unit-test": "npm run unit-test:node && npm run unit-test:browser",
|
|
46
|
+
"unit-test:node": "mocha -r esm --require ts-node/register --reporter ../../../common/tools/mocha-multi-reporter.js --timeout 1200000 --full-trace \"test/{,!(browser)/**/}*.spec.ts\"",
|
|
47
|
+
"unit-test:browser": "karma start --single-run",
|
|
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
|
+
"@azure-tools/test-credential": "^1.0.0",
|
|
79
|
+
"@azure/identity": "^2.0.1",
|
|
80
|
+
"@azure-tools/test-recorder": "^3.0.0",
|
|
81
|
+
"mocha": "^7.1.1",
|
|
82
|
+
"@types/mocha": "^7.0.2",
|
|
83
|
+
"mocha-junit-reporter": "^1.18.0",
|
|
84
|
+
"cross-env": "^7.0.2",
|
|
85
|
+
"@types/chai": "^4.2.8",
|
|
86
|
+
"chai": "^4.2.0",
|
|
87
|
+
"karma-chrome-launcher": "^3.0.0",
|
|
88
|
+
"karma-coverage": "^2.0.0",
|
|
89
|
+
"karma-env-preprocessor": "^0.1.1",
|
|
90
|
+
"karma-firefox-launcher": "^1.1.0",
|
|
91
|
+
"karma-junit-reporter": "^2.0.1",
|
|
92
|
+
"karma-mocha-reporter": "^2.2.5",
|
|
93
|
+
"karma-mocha": "^2.0.1",
|
|
94
|
+
"karma-source-map-support": "~1.4.0",
|
|
95
|
+
"karma-sourcemap-loader": "^0.3.8",
|
|
96
|
+
"karma": "^6.2.0",
|
|
97
|
+
"nyc": "^15.0.0"
|
|
98
|
+
},
|
|
99
|
+
"type": "module",
|
|
100
|
+
"browser": {
|
|
101
|
+
"./dist-esm/test/public/utils/env.js": "./dist-esm/test/public/utils/env.browser.js"
|
|
102
|
+
}
|
|
103
|
+
}
|
|
@@ -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,41 @@
|
|
|
1
|
+
// Copyright (c) Microsoft Corporation.
|
|
2
|
+
// Licensed under the MIT license.
|
|
3
|
+
|
|
4
|
+
import { getClient, ClientOptions } from "@azure-rest/core-client";
|
|
5
|
+
import { KeyCredential } from "@azure/core-auth";
|
|
6
|
+
import { AuthApiKeyClient } from "./clientDefinitions";
|
|
7
|
+
|
|
8
|
+
/**
|
|
9
|
+
* Initialize a new instance of `AuthApiKeyClient`
|
|
10
|
+
* @param credentials type: KeyCredential, uniquely identify client credential
|
|
11
|
+
* @param options type: ClientOptions, the parameter for all optional parameters
|
|
12
|
+
*/
|
|
13
|
+
export default function createClient(
|
|
14
|
+
credentials: KeyCredential,
|
|
15
|
+
options: ClientOptions = {}
|
|
16
|
+
): AuthApiKeyClient {
|
|
17
|
+
const baseUrl = options.baseUrl ?? `http://localhost:3000`;
|
|
18
|
+
options.apiVersion = options.apiVersion ?? "1.0.0";
|
|
19
|
+
options = {
|
|
20
|
+
...options,
|
|
21
|
+
credentials: {
|
|
22
|
+
apiKeyHeaderName: "x-ms-api-key",
|
|
23
|
+
},
|
|
24
|
+
};
|
|
25
|
+
|
|
26
|
+
const userAgentInfo = `azsdk-js-auth-apikey-rest/1.0.0`;
|
|
27
|
+
const userAgentPrefix =
|
|
28
|
+
options.userAgentOptions && options.userAgentOptions.userAgentPrefix
|
|
29
|
+
? `${options.userAgentOptions.userAgentPrefix} ${userAgentInfo}`
|
|
30
|
+
: `${userAgentInfo}`;
|
|
31
|
+
options = {
|
|
32
|
+
...options,
|
|
33
|
+
userAgentOptions: {
|
|
34
|
+
userAgentPrefix,
|
|
35
|
+
},
|
|
36
|
+
};
|
|
37
|
+
|
|
38
|
+
const client = getClient(baseUrl, credentials, options) as AuthApiKeyClient;
|
|
39
|
+
|
|
40
|
+
return client;
|
|
41
|
+
}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
// Copyright (c) Microsoft Corporation.
|
|
2
|
+
// Licensed under the MIT license.
|
|
3
|
+
|
|
4
|
+
import { ValidParameters, InvalidParameters } from "./parameters";
|
|
5
|
+
import {
|
|
6
|
+
Valid204Response,
|
|
7
|
+
Invalid204Response,
|
|
8
|
+
Invalid403Response,
|
|
9
|
+
} from "./responses";
|
|
10
|
+
import { Client, StreamableMethod } from "@azure-rest/core-client";
|
|
11
|
+
|
|
12
|
+
export interface Valid {
|
|
13
|
+
/** Check whether client is authenticated */
|
|
14
|
+
get(options?: ValidParameters): StreamableMethod<Valid204Response>;
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
export interface Invalid {
|
|
18
|
+
/** Check whether client is authenticated. */
|
|
19
|
+
get(
|
|
20
|
+
options?: InvalidParameters
|
|
21
|
+
): StreamableMethod<Invalid204Response | Invalid403Response>;
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
export interface Routes {
|
|
25
|
+
/** Resource for '/authentication/api-key/valid' has methods for the following verbs: get */
|
|
26
|
+
(path: "/authentication/api-key/valid"): Valid;
|
|
27
|
+
/** Resource for '/authentication/api-key/invalid' has methods for the following verbs: get */
|
|
28
|
+
(path: "/authentication/api-key/invalid"): Invalid;
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
export type AuthApiKeyClient = Client & {
|
|
32
|
+
path: Routes;
|
|
33
|
+
};
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
// Copyright (c) Microsoft Corporation.
|
|
2
|
+
// Licensed under the MIT license.
|
|
3
|
+
|
|
4
|
+
import AuthApiKeyClient from "./authApiKeyClient";
|
|
5
|
+
|
|
6
|
+
export * from "./authApiKeyClient";
|
|
7
|
+
export * from "./parameters";
|
|
8
|
+
export * from "./responses";
|
|
9
|
+
export * from "./clientDefinitions";
|
|
10
|
+
export * from "./outputModels";
|
|
11
|
+
|
|
12
|
+
export default AuthApiKeyClient;
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
// Copyright (c) Microsoft Corporation.
|
|
2
|
+
// Licensed under the MIT license.
|
|
3
|
+
|
|
4
|
+
import { HttpResponse } from "@azure-rest/core-client";
|
|
5
|
+
import { InvalidAuthOutput } from "./outputModels";
|
|
6
|
+
|
|
7
|
+
/** There is no content to send for this request, but the headers may be useful. */
|
|
8
|
+
export interface Valid204Response extends HttpResponse {
|
|
9
|
+
status: "204";
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
/** There is no content to send for this request, but the headers may be useful. */
|
|
13
|
+
export interface Invalid204Response extends HttpResponse {
|
|
14
|
+
status: "204";
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
/** Access is forbidden */
|
|
18
|
+
export interface Invalid403Response extends HttpResponse {
|
|
19
|
+
status: "403";
|
|
20
|
+
body: InvalidAuthOutput;
|
|
21
|
+
}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
// Copyright (c) Microsoft Corporation.
|
|
2
|
+
// Licensed under the MIT license.
|
|
3
|
+
|
|
4
|
+
import { Recorder } from "@azure-tools/test-recorder";
|
|
5
|
+
import { assert } from "chai";
|
|
6
|
+
import { createRecorder } from "./utils/recordedClient";
|
|
7
|
+
import { Context } from "mocha";
|
|
8
|
+
|
|
9
|
+
describe("My test", () => {
|
|
10
|
+
let recorder: Recorder;
|
|
11
|
+
|
|
12
|
+
beforeEach(async function (this: Context) {
|
|
13
|
+
recorder = await createRecorder(this);
|
|
14
|
+
});
|
|
15
|
+
|
|
16
|
+
afterEach(async function () {
|
|
17
|
+
await recorder.stop();
|
|
18
|
+
});
|
|
19
|
+
|
|
20
|
+
it("sample test", async function () {
|
|
21
|
+
assert.equal(1, 1);
|
|
22
|
+
});
|
|
23
|
+
});
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
// Copyright (c) Microsoft Corporation.
|
|
2
|
+
// Licensed under the MIT license.
|
|
3
|
+
|
|
4
|
+
import { Context } from "mocha";
|
|
5
|
+
import { Recorder, RecorderStartOptions } from "@azure-tools/test-recorder";
|
|
6
|
+
import "./env";
|
|
7
|
+
|
|
8
|
+
const envSetupForPlayback: Record<string, string> = {
|
|
9
|
+
ENDPOINT: "https://endpoint",
|
|
10
|
+
AZURE_CLIENT_ID: "azure_client_id",
|
|
11
|
+
AZURE_CLIENT_SECRET: "azure_client_secret",
|
|
12
|
+
AZURE_TENANT_ID: "88888888-8888-8888-8888-888888888888",
|
|
13
|
+
SUBSCRIPTION_ID: "azure_subscription_id",
|
|
14
|
+
};
|
|
15
|
+
|
|
16
|
+
const recorderEnvSetup: RecorderStartOptions = {
|
|
17
|
+
envSetupForPlayback,
|
|
18
|
+
};
|
|
19
|
+
|
|
20
|
+
/**
|
|
21
|
+
* creates the recorder and reads the environment variables from the `.env` file.
|
|
22
|
+
* Should be called first in the test suite to make sure environment variables are
|
|
23
|
+
* read before they are being used.
|
|
24
|
+
*/
|
|
25
|
+
export async function createRecorder(context: Context): Promise<Recorder> {
|
|
26
|
+
const recorder = new Recorder(context.currentTest);
|
|
27
|
+
await recorder.start(recorderEnvSetup);
|
|
28
|
+
return recorder;
|
|
29
|
+
}
|
|
@@ -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", "./test/**/*.ts"]
|
|
25
|
+
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
emitters:
|
|
2
|
+
"../../../../../../../../../../../packages/typespec-ts/dist/src/index.js":
|
|
3
|
+
azureSdkForJs: false
|
|
4
|
+
addCredentials: false
|
|
5
|
+
isCadlTest: true
|
|
6
|
+
title: AuthApiKeyClient
|
|
7
|
+
packageDetails:
|
|
8
|
+
name: "@msinternal/auth-apikey"
|
|
9
|
+
description: "Auth api key Test Service"
|
|
10
|
+
version: "1.0.0"
|