summaryrefslogtreecommitdiffstats
path: root/ansible_collections/azure/azcollection/pr-pipelines.yml
diff options
context:
space:
mode:
Diffstat (limited to 'ansible_collections/azure/azcollection/pr-pipelines.yml')
-rw-r--r--ansible_collections/azure/azcollection/pr-pipelines.yml257
1 files changed, 257 insertions, 0 deletions
diff --git a/ansible_collections/azure/azcollection/pr-pipelines.yml b/ansible_collections/azure/azcollection/pr-pipelines.yml
new file mode 100644
index 00000000..a754f5a6
--- /dev/null
+++ b/ansible_collections/azure/azcollection/pr-pipelines.yml
@@ -0,0 +1,257 @@
+parameters:
+- name: PYTHON_VER
+ displayName: 'Python Version'
+ type: string
+ default: "3.8"
+ values:
+ - "2.7"
+ - "3.6"
+ - "3.8"
+ - "3.9"
+ - "3.10"
+- name: ANSIBLE_VER
+ displayName: 'Ansible Version'
+ type: string
+ default: "2.12"
+ values:
+ - "2.9"
+ - "2.10"
+ - "2.11"
+ - "2.12"
+ - "devel"
+- name: MODULE_NAME
+ displayName: 'Test Module'
+ type: string
+ default: 'all'
+ values:
+ - 'all'
+ - 'sanity'
+ - 'azure_rm_adapplication'
+ - "azure_rm_acs"
+ - "azure_rm_adgroup"
+ - "azure_rm_aduser"
+ - "azure_rm_aks"
+ - "azure_rm_aksagentpool"
+ - "azure_rm_apimanagement"
+ - "azure_rm_appgateway"
+ - "azure_rm_appserviceplan"
+ - "azure_rm_automationaccount"
+ - "azure_rm_automationrunbook"
+ - "azure_rm_autoscale"
+ - "azure_rm_availabilityset"
+ - "azure_rm_azurefirewall"
+ - "azure_rm_apimanagementservice"
+ - "azure_rm_batchaccount"
+ - "azure_rm_backuppolicy"
+ - "azure_rm_cdnprofile"
+ - "azure_rm_containerinstance"
+ - "azure_rm_containerregistry"
+ - "azure_rm_containerregistrytag"
+ - "azure_rm_cosmosdbaccount"
+ - "azure_rm_datalakestore"
+ - "azure_rm_ddosprotectionplan"
+ - "azure_rm_deployment"
+ - "azure_rm_diskencryptionset"
+ - "azure_rm_dnsrecordset"
+ - "azure_rm_dnszone"
+ - "azure_rm_eventhub"
+ - "azure_rm_expressroute"
+ - "azure_rm_firewallpolicy"
+ - "azure_rm_functionapp"
+ - "azure_rm_gallery"
+ - "azure_rm_hdinsightcluster"
+ - "azure_rm_hostgroup"
+ - "azure_rm_image"
+ - "azure_rm_iothub"
+ - "azure_rm_ipgroup"
+ - "azure_rm_keyvault"
+ - "azure_rm_keyvaultkey"
+ - "azure_rm_keyvaultsecret"
+ - "azure_rm_loadbalancer"
+ - "azure_rm_loganalyticsworkspace"
+ - "azure_rm_manageddisk"
+ - "azure_rm_managementgroup"
+ - "azure_rm_mariadbserver"
+ - "azure_rm_monitordiagnosticsetting"
+ - "azure_rm_monitorlogprofile"
+ - "azure_rm_mysqlserver"
+ - "azure_rm_natgateway"
+ - "azure_rm_networkinterface"
+ - "azure_rm_notificationhub"
+ - "azure_rm_openshiftmanagedcluster"
+ - "azure_rm_postgresqlserver"
+ - "azure_rm_privatednsrecordset"
+ - "azure_rm_privatednszone"
+ - "azure_rm_privateendpoint"
+ - "azure_rm_privateendpointdnszonegroup"
+ - "azure_rm_privatelinkservice"
+ - "azure_rm_privatednszonelink"
+ - "azure_rm_publicipaddress"
+ - "azure_rm_proximityplacementgroup"
+ - "azure_rm_rediscache"
+ - "azure_rm_resource"
+ - "azure_rm_resourcegroup"
+ - "azure_rm_routetable"
+ - "azure_rm_roleassignment"
+ - "azure_rm_roledefinition"
+ - "azure_rm_registrationassignment"
+ - "azure_rm_registrationdefinition"
+ - "azure_rm_cognitivesearch"
+ - "azure_rm_securitygroup"
+ - "azure_rm_servicebus"
+ - "azure_rm_sqlserver"
+ - "azure_rm_storageaccount"
+ - "azure_rm_storageblob"
+ - "azure_rm_storageshare"
+ - "azure_rm_subnet"
+ - "azure_rm_subscription"
+ - "azure_rm_trafficmanagerprofile"
+ - "azure_rm_virtualmachine"
+ - "azure_rm_virtualmachineextension"
+ - "azure_rm_virtualmachineimage_info"
+ - "azure_rm_virtualmachinescaleset"
+ - "azure_rm_virtualmachinesize_info"
+ - "azure_rm_virtualnetwork"
+ - "azure_rm_virtualnetworkgateway"
+ - "azure_rm_virtualnetworkpeering"
+ - "azure_rm_virtualwan"
+ - "azure_rm_vpnsite"
+ - "azure_rm_virtualhub"
+ - "azure_rm_virtualhubconnection"
+ - "azure_rm_backupazurevm"
+ - "azure_rm_recoveryservicesvault"
+ - "azure_rm_vmbackuppolicy"
+ - "azure_rm_webapp"
+ - "azure_rm_webappvnetconnection"
+ - "azure_rm_webappaccessrestriction"
+ - "azure_rm_workspace"
+ - "azure_rm_datafactory"
+ - "azure_rm_bastionhost"
+ - "inventory_azure"
+ - "setup_azure"
+
+trigger: none
+
+pr:
+- dev
+
+pool:
+ name: pool-ubuntu-2004
+
+jobs:
+ - job: CreateResourceGroups
+ steps:
+ - bash: |
+ echo "##vso[task.setvariable variable=resource_group;isOutput=true]ansibletest-$(uuidgen)"
+ echo "##vso[task.setvariable variable=resource_group_secondary;isOutput=true]ansibletest2-$(uuidgen)"
+ echo "##vso[task.setvariable variable=resource_group_datalake;isOutput=true]ansibletest-$(uuidgen)"
+
+ name: setvar
+ - bash: |
+ echo "Generate test resource group $(setvar.resource_group), $(setvar.resource_group_secondary), $(setvar.resource_group_datalake)"
+ - task: AzureCLI@2
+ inputs:
+ azureSubscription: '$(SUBSCRIPTION_FULL_NAME)'
+ scriptType: 'bash'
+ scriptLocation: 'inlineScript'
+ inlineScript: |
+ az group create -l eastus -n $(setvar.resource_group)
+ az group create -l eastus -n $(setvar.resource_group_secondary)
+ az group create -l eastus2 -n $(setvar.resource_group_datalake)
+
+ - job: RunTests
+ dependsOn: CreateResourceGroups
+ timeoutInMinutes: 120
+ variables:
+ TEST_RESOURCE_GROUP: $[ dependencies.CreateResourceGroups.outputs['setvar.resource_group'] ]
+ TEST_RESOURCE_GROUP_SECONDARY: $[ dependencies.CreateResourceGroups.outputs['setvar.resource_group_secondary'] ]
+ TEST_RESOURCE_GROUP_DATALAKE: $[ dependencies.CreateResourceGroups.outputs['setvar.resource_group_datalake'] ]
+ strategy:
+ matrix:
+ "Python${{ parameters.PYTHON_VER }}_sanity":
+ python.version: '${{ parameters.PYTHON_VER }}'
+ test.key: 'sanity'
+ "Python${{ parameters.PYTHON_VER }}_1":
+ python.version: '${{ parameters.PYTHON_VER }}'
+ test.key: '1'
+ "Python${{ parameters.PYTHON_VER }}_2":
+ python.version: '${{ parameters.PYTHON_VER }}'
+ test.key: '2'
+ "Python${{ parameters.PYTHON_VER }}_3":
+ python.version: '${{ parameters.PYTHON_VER }}'
+ test.key: '3'
+ "Python${{ parameters.PYTHON_VER }}_4":
+ python.version: '${{ parameters.PYTHON_VER }}'
+ test.key: '4'
+ "Python${{ parameters.PYTHON_VER }}_5":
+ python.version: '${{ parameters.PYTHON_VER }}'
+ test.key: '5'
+ "Python${{ parameters.PYTHON_VER }}_6":
+ python.version: '${{ parameters.PYTHON_VER }}'
+ test.key: '6'
+ "Python${{ parameters.PYTHON_VER }}_7":
+ python.version: '${{ parameters.PYTHON_VER }}'
+ test.key: '7'
+ "Python${{ parameters.PYTHON_VER }}_9":
+ python.version: '${{ parameters.PYTHON_VER }}'
+ test.key: '9'
+ "Python${{ parameters.PYTHON_VER }}_10":
+ python.version: '${{ parameters.PYTHON_VER }}'
+ test.key: '10'
+ "Python${{ parameters.PYTHON_VER }}_11":
+ python.version: '${{ parameters.PYTHON_VER }}'
+ test.key: '11'
+ "Python${{ parameters.PYTHON_VER }}_12":
+ python.version: '${{ parameters.PYTHON_VER }}'
+ test.key: '12'
+ "Python${{ parameters.PYTHON_VER }}_13":
+ python.version: '${{ parameters.PYTHON_VER }}'
+ test.key: '13'
+ "Python${{ parameters.PYTHON_VER }}_14":
+ python.version: '${{ parameters.PYTHON_VER }}'
+ test.key: '14'
+ "Python${{ parameters.PYTHON_VER }}_15":
+ python.version: '${{ parameters.PYTHON_VER }}'
+ test.key: '15'
+
+ steps:
+ - task: UsePythonVersion@0
+ displayName: 'Use Python $(python.version)'
+ inputs:
+ versionSpec: '$(python.version)'
+
+ - script: tests/utils/ado/ado.sh $(test.key) ${{ parameters.PYTHON_VER }} ${{ parameters.ANSIBLE_VER }} ${{ parameters.MODULE_NAME }}
+ env:
+ SHIPPABLE_BUILD_DIR: $(Build.Repository.LocalPath)
+ AZURE_CLIENT_ID: $(AZURE_CLIENT_ID)
+ AZURE_SECRET: $(AZURE_SECRET)
+ AZURE_SUBSCRIPTION_ID: $(AZURE_SUBSCRIPTION_ID)
+ AZURE_SUBSCRIPTION_SEC_ID: $(AZURE_SUBSCRIPTION_SEC_ID)
+ AZURE_TENANT: $(AZURE_TENANT)
+ AZURE_PRINCIPAL_ID: $(AZURE_PRINCIPAL_ID)
+ AZURE_MANAGED_BY_TENANT_ID: $(AZURE_MANAGED_BY_TENANT_ID)
+ AZURE_ROLE_DEFINITION_ID: $(AZURE_ROLE_DEFINITION_ID)
+ RESOURCE_GROUP: $(TEST_RESOURCE_GROUP)
+ RESOURCE_GROUP_SECONDARY: $(TEST_RESOURCE_GROUP_SECONDARY)
+ RESOURCE_GROUP_DATALAKE: $(TEST_RESOURCE_GROUP_DATALAKE)
+ displayName: 'Running Tests'
+
+ - job: CleanupResourceGroups
+ dependsOn:
+ - CreateResourceGroups
+ - RunTests
+ condition: always()
+ variables:
+ TEST_RESOURCE_GROUP: $[ dependencies.CreateResourceGroups.outputs['setvar.resource_group'] ]
+ TEST_RESOURCE_GROUP_SECONDARY: $[ dependencies.CreateResourceGroups.outputs['setvar.resource_group_secondary'] ]
+ TEST_RESOURCE_GROUP_DATALAKE: $[ dependencies.CreateResourceGroups.outputs['setvar.resource_group_datalake'] ]
+ steps:
+ - task: AzureCLI@2
+ inputs:
+ azureSubscription: '$(SUBSCRIPTION_FULL_NAME)'
+ scriptType: 'bash'
+ scriptLocation: 'inlineScript'
+ inlineScript: |
+ az group delete -n $(TEST_RESOURCE_GROUP) --yes --no-wait
+ az group delete -n $(TEST_RESOURCE_GROUP_SECONDARY) --yes --no-wait
+ az group delete -n $(TEST_RESOURCE_GROUP_DATALAKE) --yes --no-wait