running powershell scripts against azure through visual studio team services
I had a need to run some PowerShell scripts that made use of the Azure PowerShell cmdlets on the tool formerly known as Visual Studio Team Services. I initially tried using the PowerShell task, but had great difficulty getting it to authenticate properly to Azure. I did a lot of searching, and eventually found out that the answer was really easy.
Pre-requisites
You’ll need the following things ready to follow through:
-
A build or release pipeline. I’ve set up a blank release pipeline for this post.
-
A PowerShell script that you want to run which contains some Azure cmdlets. The demo script I’m going to use simply logs a list of virtual machines in the subscription. note that I don’t need to do anything inside the script to login to Azure - we’ll take care of that in the pipeline.
$VM = Get-AzureRmVm
Write-Output $VM
Step by step
The first thing we need to do is create an Azure Service Principal, which is essentially an account in your Azure Active Directory that VSTS/AzDO with use to login to Azure. Go to the project settings menu (the little cog) and click Services.
In the Services page, click New Service Connection, and select Azure Resource Manager (you can also select Azure Classic if you need to use the classic cmdlets).
Give the service connection a suitable name, and optionally select a resource group to restrict it to if that’s useful for you. Click OK.
You should now be able to see your new service connection in the list on the left.
Back in your pipeline, add a task and select Azure PowerShell from the list. This differs from the PowerShell task in that it lets us make use of the service connection that we’ve set up to automatically authenticate to Azure. Note that this still runs on the VSTS agent - it is not a Cloud Shell instance.
In the task options, select your new service connection from the Azure Subscription drop-down and your script to run from the Script Path control. You can also specify which version of Azure PowerShell you need to run; I don’t need any old behaviour, so I’ve just gone with Latest installed version.
Finally, save and run your pipeline. You can then take a look in the logs and see that the script has run succesfully and given us the output we wanted!