mirror of
https://github.com/actions/runner-images.git
synced 2025-12-19 08:22:12 +00:00
[Windows] Install AZ 4.3.0 (#1137)
* Install and validate AZ 4.3.0 for Windows images * Move azureModules to toolset * Fix validation * Fix modules root location * Small fix in syntax * Fix in syntax * Fixes for default tool versions
This commit is contained in:
@@ -24,6 +24,7 @@
|
||||
"imagedata_file": "C:\\imagedata.json",
|
||||
"metadata_file": "C:\\image\\metadata.txt",
|
||||
"helper_script_folder": "C:\\Program Files\\WindowsPowerShell\\Modules\\",
|
||||
"psmodules_root_folder": "C:\\Modules",
|
||||
"commit_url": "LATEST",
|
||||
"install_user": "installer",
|
||||
"install_password": null,
|
||||
@@ -550,6 +551,10 @@
|
||||
},
|
||||
{
|
||||
"type": "powershell",
|
||||
"environment_vars":[
|
||||
"TOOLSET_JSON_PATH={{user `toolset_json_path`}}",
|
||||
"PSMODULES_ROOT_FOLDER={{user `psmodules_root_folder`}}"
|
||||
],
|
||||
"scripts":[
|
||||
"{{ template_dir }}/scripts/Installers/Install-AzureModules.ps1"
|
||||
]
|
||||
@@ -676,6 +681,10 @@
|
||||
},
|
||||
{
|
||||
"type": "powershell",
|
||||
"environment_vars":[
|
||||
"TOOLSET_JSON_PATH={{user `toolset_json_path`}}",
|
||||
"PSMODULES_ROOT_FOLDER={{user `psmodules_root_folder`}}"
|
||||
],
|
||||
"scripts":[
|
||||
"{{ template_dir }}/scripts/Installers/Validate-AzureModules.ps1"
|
||||
]
|
||||
|
||||
@@ -24,6 +24,7 @@
|
||||
"imagedata_file": "C:\\imagedata.json",
|
||||
"metadata_file": "C:\\image\\metadata.txt",
|
||||
"helper_script_folder": "C:\\Program Files\\WindowsPowerShell\\Modules\\",
|
||||
"psmodules_root_folder": "C:\\Modules",
|
||||
"commit_id": "LATEST",
|
||||
"install_user": "installer",
|
||||
"install_password": null,
|
||||
@@ -511,6 +512,10 @@
|
||||
},
|
||||
{
|
||||
"type": "powershell",
|
||||
"environment_vars":[
|
||||
"TOOLSET_JSON_PATH={{user `toolset_json_path`}}",
|
||||
"PSMODULES_ROOT_FOLDER={{user `psmodules_root_folder`}}"
|
||||
],
|
||||
"scripts":[
|
||||
"{{ template_dir }}/scripts/Installers/Install-AzureModules.ps1"
|
||||
]
|
||||
@@ -661,6 +666,10 @@
|
||||
},
|
||||
{
|
||||
"type": "powershell",
|
||||
"environment_vars":[
|
||||
"TOOLSET_JSON_PATH={{user `toolset_json_path`}}",
|
||||
"PSMODULES_ROOT_FOLDER={{user `psmodules_root_folder`}}"
|
||||
],
|
||||
"scripts":[
|
||||
"{{ template_dir }}/scripts/Installers/Validate-AzureModules.ps1"
|
||||
]
|
||||
|
||||
@@ -3,58 +3,35 @@
|
||||
## Desc: Install Azure PowerShell modules
|
||||
################################################################################
|
||||
|
||||
$ErrorActionPreference = "Stop"
|
||||
|
||||
Set-PSRepository -InstallationPolicy Trusted -Name PSGallery
|
||||
|
||||
#### NOW The correct Modules need to be saved in C:\Modules
|
||||
$installPSModulePath = 'C:\Modules'
|
||||
# The correct Modules need to be saved in C:\Modules
|
||||
$installPSModulePath = $env:PSMODULES_ROOT_FOLDER
|
||||
if (-not (Test-Path -LiteralPath $installPSModulePath))
|
||||
{
|
||||
Write-Host "Creating '$installPSModulePath' folder to store PowerShell Azure modules"
|
||||
Write-Host "Creating ${installPSModulePath} folder to store PowerShell Azure modules..."
|
||||
$null = New-Item -Path $installPSModulePath -ItemType Directory
|
||||
}
|
||||
|
||||
# Powershell Azure modules to install
|
||||
$psAzureModulesToInstall = @{
|
||||
"azurerm" = @(
|
||||
"2.1.0"
|
||||
"3.8.0"
|
||||
"4.2.1"
|
||||
"5.1.1"
|
||||
"6.7.0"
|
||||
"6.13.1"
|
||||
)
|
||||
# Get modules content from toolset
|
||||
$modules = (Get-ToolsetContent).azureModules
|
||||
|
||||
"azure" = @(
|
||||
"2.1.0"
|
||||
"3.8.0"
|
||||
"4.2.1"
|
||||
"5.1.1"
|
||||
"5.3.0"
|
||||
)
|
||||
$psModuleMachinePath = ""
|
||||
|
||||
"az" = @(
|
||||
"1.0.0"
|
||||
"1.6.0"
|
||||
"2.3.2"
|
||||
"2.6.0"
|
||||
"3.1.0"
|
||||
"3.5.0"
|
||||
"3.8.0"
|
||||
)
|
||||
}
|
||||
|
||||
# Download Azure PowerShell modules
|
||||
foreach($psmoduleName in $psAzureModulesToInstall.Keys)
|
||||
foreach ($module in $modules)
|
||||
{
|
||||
Write-Host "Installing '$psmoduleName' to the '$installPSModulePath' path:"
|
||||
$psmoduleVersions = $psAzureModulesToInstall[$psmoduleName]
|
||||
foreach($psmoduleVersion in $psmoduleVersions)
|
||||
$moduleName = $module.name
|
||||
|
||||
Write-Host "Installing ${moduleName} to the ${installPSModulePath} path..."
|
||||
foreach ($version in $module.versions)
|
||||
{
|
||||
$psmodulePath = Join-Path $installPSModulePath "${psmoduleName}_${psmoduleVersion}"
|
||||
Write-Host " - $psmoduleVersion [$psmodulePath]"
|
||||
$modulePath = Join-Path -Path $installPSModulePath -ChildPath "${moduleName}_${version}"
|
||||
Write-Host " - $version [$modulePath]"
|
||||
try
|
||||
{
|
||||
Save-Module -Path $psmodulePath -Name $psmoduleName -RequiredVersion $psmoduleVersion -Force -ErrorAction Stop
|
||||
Save-Module -Path $modulePath -Name $moduleName -RequiredVersion $version -Force -ErrorAction Stop
|
||||
}
|
||||
catch
|
||||
{
|
||||
@@ -62,8 +39,17 @@ foreach($psmoduleName in $psAzureModulesToInstall.Keys)
|
||||
exit 1
|
||||
}
|
||||
}
|
||||
|
||||
# Append default tool version to machine path
|
||||
if ($null -ne $module.default)
|
||||
{
|
||||
$defaultVersion = $module.default
|
||||
|
||||
Write-Host "Use ${moduleName} ${defaultVersion} as default version..."
|
||||
$psModuleMachinePath += "${installPSModulePath}\${moduleName}_${defaultVersion};"
|
||||
}
|
||||
}
|
||||
|
||||
# Add AzureRM and Azure modules to the PSModulePath
|
||||
$finalModulePath = '{0};{1};{2}' -f "${installPSModulePath}\azurerm_2.1.0", "${installPSModulePath}\azure_2.1.0", $env:PSModulePath
|
||||
[Environment]::SetEnvironmentVariable("PSModulePath", $finalModulePath, "Machine")
|
||||
# Add modules to the PSModulePath
|
||||
$psModuleMachinePath += $env:PSModulePath
|
||||
[Environment]::SetEnvironmentVariable("PSModulePath", $psModuleMachinePath, "Machine")
|
||||
@@ -3,41 +3,42 @@
|
||||
## Desc: Validate Azure PowerShell modules
|
||||
################################################################################
|
||||
|
||||
function Validate-AzureModule
|
||||
{
|
||||
param([String]$ModuleName, [String[]]$ModuleVersions)
|
||||
$ErrorActionPreference = "Stop"
|
||||
|
||||
foreach($moduleVersion in $moduleVersions)
|
||||
$modulesRootPath = $env:PSMODULES_ROOT_FOLDER
|
||||
|
||||
# Get modules content from toolset
|
||||
$modules = (Get-ToolsetContent).azureModules
|
||||
|
||||
foreach ($module in $modules)
|
||||
{
|
||||
$modulePath = "${installPSModulePath}\${moduleName}_${moduleVersion}"
|
||||
# Import each module in PowerShell session
|
||||
$job = Start-Job -ScriptBlock {
|
||||
param($modulePath, $moduleName)
|
||||
foreach ($version in $module.versions)
|
||||
{
|
||||
$moduleName = $module.name
|
||||
$modulePath = Join-Path -Path $modulesRootPath -ChildPath "$($module.name)_${version}"
|
||||
|
||||
Write-Host "Trying to import ${moduleName}_${version}..."
|
||||
$testJob = Start-Job -ScriptBlock {
|
||||
param (
|
||||
$modulePath,
|
||||
$moduleName
|
||||
)
|
||||
|
||||
$env:PsModulePath = "$modulePath;$env:PsModulePath"
|
||||
Import-Module -Name $moduleName
|
||||
Get-Module -Name $moduleName
|
||||
|
||||
} -ArgumentList $modulePath, $moduleName
|
||||
$isError = $job | Wait-Job | Foreach-Object ChildJobs | Where-Object {$_.Error}
|
||||
|
||||
$isError = $testJob | Wait-Job | Foreach-Object ChildJobs | Where-Object { $_.Error }
|
||||
if ($isError)
|
||||
{
|
||||
Write-Host "Required '$moduleName' module '$moduleVersion' version is not present"
|
||||
Write-Host "Required ${moduleName} module ${version} version is not present"
|
||||
|
||||
exit 1
|
||||
}
|
||||
$job | Receive-Job | Select-Object Name,Version,Path
|
||||
Remove-Job $job
|
||||
|
||||
$testJob | Receive-Job | Select-Object Name,Version,Path
|
||||
Remove-Job $testJob
|
||||
}
|
||||
}
|
||||
|
||||
# Modules path
|
||||
$installPSModulePath = 'C:\Modules'
|
||||
|
||||
# Validate Azure modules and versions
|
||||
$azurermVersions = "2.1.0", "3.8.0", "4.2.1", "5.1.1", "6.7.0", "6.13.1"
|
||||
Validate-AzureModule -ModuleName AzureRM -ModuleVersions $azurermVersions
|
||||
|
||||
$azureVersions = "2.1.0", "3.8.0", "4.2.1", "5.1.1", "5.3.0"
|
||||
Validate-AzureModule -ModuleName Azure -ModuleVersions $azureVersions
|
||||
|
||||
$azVersions = "1.0.0", "1.6.0", "2.3.2", "2.6.0", "3.1.0", "3.5.0", "3.8.0"
|
||||
Validate-AzureModule -ModuleName Az -ModuleVersions $azVersions
|
||||
|
||||
@@ -74,5 +74,43 @@
|
||||
"1.72.0"
|
||||
]
|
||||
}
|
||||
],
|
||||
"azureModules": [
|
||||
{
|
||||
"name": "azurerm",
|
||||
"versions": [
|
||||
"2.1.0",
|
||||
"3.8.0",
|
||||
"4.2.1",
|
||||
"5.1.1",
|
||||
"6.7.0",
|
||||
"6.13.1"
|
||||
],
|
||||
"default": "2.1.0"
|
||||
},
|
||||
{
|
||||
"name": "azure",
|
||||
"versions": [
|
||||
"2.1.0",
|
||||
"3.8.0",
|
||||
"4.2.1",
|
||||
"5.1.1",
|
||||
"5.3.0"
|
||||
],
|
||||
"default": "2.1.0"
|
||||
},
|
||||
{
|
||||
"name": "az",
|
||||
"versions": [
|
||||
"1.0.0",
|
||||
"1.6.0",
|
||||
"2.3.2",
|
||||
"2.6.0",
|
||||
"3.1.0",
|
||||
"3.5.0",
|
||||
"3.8.0",
|
||||
"4.3.0"
|
||||
]
|
||||
}
|
||||
]
|
||||
}
|
||||
@@ -83,5 +83,43 @@
|
||||
"1.72.0"
|
||||
]
|
||||
}
|
||||
],
|
||||
"azureModules": [
|
||||
{
|
||||
"name": "azurerm",
|
||||
"versions": [
|
||||
"2.1.0",
|
||||
"3.8.0",
|
||||
"4.2.1",
|
||||
"5.1.1",
|
||||
"6.7.0",
|
||||
"6.13.1"
|
||||
],
|
||||
"default": "2.1.0"
|
||||
},
|
||||
{
|
||||
"name": "azure",
|
||||
"versions": [
|
||||
"2.1.0",
|
||||
"3.8.0",
|
||||
"4.2.1",
|
||||
"5.1.1",
|
||||
"5.3.0"
|
||||
],
|
||||
"default": "2.1.0"
|
||||
},
|
||||
{
|
||||
"name": "az",
|
||||
"versions": [
|
||||
"1.0.0",
|
||||
"1.6.0",
|
||||
"2.3.2",
|
||||
"2.6.0",
|
||||
"3.1.0",
|
||||
"3.5.0",
|
||||
"3.8.0",
|
||||
"4.3.0"
|
||||
]
|
||||
}
|
||||
]
|
||||
}
|
||||
Reference in New Issue
Block a user