-
Notifications
You must be signed in to change notification settings - Fork 3.9k
How to On Board New RP with Azure PowerShell Generator
- Prerequisite
- Code Generation
- Customization
- Examples
- Design Review
- Test
- Code Review
- Troubleshooting
- References
The audience of this guide should be Azure service owners including both Microsoft internal teams and Microsoft’s partners, who want to on-board their services on Az 4.0 by leveraging Azure PowerShell generator.
Note: Currently, we only support on-boarding new services, for legacy services already existed in Az 3.0, Process has not been ready yet.
The content of the guide will try to cover the whole process to on-board a new service to Az PowerShell, which includes prerequisite, code generation, customization, examples, design review, test, code review.
- Service design is finalized, and the integration test should pass
- Swagger API review should pass
- See https://dev.azure.com/azure-sdk/internal/_wiki/wikis/internal.wiki/10/Welcome-and-Onboarding for the detailed process of the swagger review
- Some best practice when naming the operationId in the swagger
- The operationId format is ‘<Resource>_<Verb>’
- Please see the bottom of https://github.com/Azure/autorest.powershell/blob/master/powershell/autorest-configuration.md for the verb mapping between the <Verb> used in operationId and the <Verb> used in PowerShell, and the left part is the <Verb> used in operationId. Please try to select the verbs in the list.
- We will only provide New-* and Update-* cmdlets for a resource
- So it is better the operationId for your PUT API should be named as ‘<resource>_Create’, which will prevent the Set-* cmdlets from being generated.
- If you do not have a fully functional PATCH API for a resource, you may need to implement it through customization.
- Using “GET” and “PUT” to implement the Update-* cmdlet
- Install Docker
- For Windows, you should find how-to in https://docs.docker.com/docker-for-windows/install/
- Create a folder with your service name in https://github.com/Azure/azure-powershell/tree/generation/src
- Create a readme.md under the folder you just created and following is the template of the readme.md you may get started from. See https://github.com/Azure/azure-powershell/blob/generation/src/Databricks/readme.md for a full example.
require:
# readme.azure.noprofile.md is the common configuration file
- $(this-folder)/../readme.azure.noprofile.md
input-file:
# You need to specify your swagger files here.
- $(repo)/specification/databricks/resource-manager/Microsoft.Databricks/stable/2018-04-01/databricks.json
# If the swagger has not been put in the repo, you may uncomment the following line and refer to it locally
# - (this-folder)/relative-path-to-your-swagger
module-version: 0.0.1
# Normally, title is the service name
title: Databricks
subject-prefix: $(service-name)
# If there are post APIs for some kinds of actions in the RP, you may need to
# uncomment following line to support viaIdentity for these post APIs
# identity-correction-for-post: true
directive:
# Following is two common directive which are normally required in all the RPs
# 1. Remove the unexpanded parameter set
# 2. For New-* cmdlets, ViaIdentity is not required, so CreateViaIdentityExpanded is removed as well
- where:
variant: ^Create$|^CreateViaIdentity$|^CreateViaIdentityExpanded$|^Update$|^UpdateViaIdentity$
remove: true
# Remove the set-* cmdlet
- where:
verb: Set
remove: true
Follow the link https://github.com/Azure/autorest.powershell/tree/master/tools/docker to generate, build and run your service within a docker container.
Guide is located at https://github.com/Azure/autorest.powershell/blob/master/docs/directives.md.
Guide is located at https://github.com/Azure/autorest.powershell/blob/master/docs/customization.md
In some cases, you may need to call cmdlets in other RP modules to complete a complex operation, and we put these common cmdlets in the helper, which may be required in your RP module. There are three common modules listed as below.
- AppInsights
- MSI
- Storage You just need to add following code in the readme.md to require them.
require:
- $(this-folder)/../helpers/Storage/readme.noprofile.md
- $(this-folder)/../helpers/AppInsights/readme.noprofile.md
- $(this-folder)/../helpers/ManagedIdentity/readme.noprofile.md
After you complete coding, you may need to add some examples for help and design review. You need to add the examples manually based on the generated example stubs under the example folder. And Ideally, you need to provide one example per parameter set.
When all above steps are completed, you may create an issue in https://github.com/Azure/azure-powershell-cmdlet-review-pr for design review. Please provides following information in the issue.
- Link to the speclet of the RP if there is
- Cmdlet syntax and examples (you may copy them from the docs folder)
- Link to docs folder in your fork repo
If the RP is complex, a review meeting will be scheduled. Otherwise, review will be done through comments in the issue/email.
During the build (‘./build-module.ps1’), we will generate stubs and some utilities for test, which are located at the folder test. Considering before test, users may need to create some resources to be used in the test, we have integrated a simplified version of the Resource module. And you will find it in under $Home.PSSharedModules\Resources as a result of running ‘./test-module.ps1' the first time. You may get available cmdlets through the following commands.
PS C:\Users\xidi\.PSSharedModules\Resources> .\run-module.ps1
PS C:\Users\xidi\.PSSharedModules\Resources [Az.Resources.TestSupport]> Get-Command -Module Az.Resources.TestSupport
And in the test folder, there is a test file called utils.ps1. And in the file, there are two functions you may need to customize.
- setupEnv
- You can create resources for your test here
- You can create some random strings for your test
- Strongly recommend you to create resources with New-AzDeployment with a template file
- cleanupEnv
- Clean the test resources when the test is completed, normally you just need to delete the test group
Regarding to the Pester test stubs, we will generate one test case per parameter set, and you should implement the test logic accordingly.
After you have completed the test cases, you may run ‘test-module.ps1’ to run the test. Test supports 3 modes.
- Live
- Switch is ‘-Live’
- Run a live test
- Record
- Switch is ‘-Record’
- Run a live test and meanwhile record the response from server in a local json file
- Playback
- Switch Is ‘-Playback’
- Run a mock test and data is from the json file generated in the record mode
Source code files needs to be checked in.
- readme.md
- custom/*
- examples/*
- test/*
- docs/* Please file a PR containing the source code above in https://github.com/Azure/azure-powershell/tree/generation/src.
Please follow steps below to debug if you run into any issues.
- Add ‘-Break’ switch when executing the cmdlet
- In Visual Studio Code, set break point and then press ‘F5’
- autorest.powershell doc -- https://github.com/Azure/autorest.powershell/tree/master/docs
- Examples
- See https://github.com/Azure/azure-powershell/tree/generation/src/Databricks for a simple example
- See https://github.com/Azure/azure-powershell/tree/generation/src for more complex examples