-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathbuild.ps1
127 lines (125 loc) · 4.38 KB
/
build.ps1
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
[CmdletBinding()]
Param(
# Process-specific parameters
[Parameter()]
[string]
$ModuleName = 'PSProfile',
[Parameter()]
[hashtable]
$Dependencies = @{
Configuration = '1.3.1'
PackageManagement = '1.3.1'
PowerShellGet = '2.1.2'
InvokeBuild = '5.5.2'
},
#region: Invoke-Build parameters
[Parameter()]
[ValidateSet('Init','Clean','Build','Test','Deploy')]
[string[]]
$Task,
[Parameter()]
[object]
$File,
[Parameter()]
[switch]
$Safe,
[Parameter()]
[switch]
$Summary
#endregion: Invoke-Build parameters
)
#region: Import Azure Pipeline Helper functions from Gist or cached version if already pulled.
# Gist is specified via Commit SHA so future Gist updates cannot introduce breaking changes to
# scripts pinned to the specific commit.
$helperUri = @(
'https://gist.githubusercontent.com'
'scrthq' # User
'a99cc06e75eb31769d01b2adddc6d200' # Gist ID
'raw'
'10d6ab6de6aa3f35c94acb7707970fe0ee755aa6' # Commit SHA
'AzurePipelineHelpers.ps1' # Filename
) -join '/'
$fileUri = $helperUri -replace "[$([RegEx]::Escape("$(([System.IO.Path]::GetInvalidFileNameChars() + [System.IO.Path]::GetInvalidPathChars()) -join '')"))]","_"
$ciPath = [System.IO.Path]::Combine($PSScriptRoot,'ci')
$localGistPath = [System.IO.Path]::Combine($ciPath,$fileUri)
if (Test-Path $localGistPath) {
Write-Host -ForegroundColor Cyan "##[section] Importing Azure Pipelines Helper from Cached Gist: $localGistPath"
$helperContent = Get-Content $localGistPath -Raw
}
else {
Write-Host -ForegroundColor Cyan "##[section] Cleaning out stale Gist scripts from the CI Path"
Get-ChildItem $ciPath -Filter 'https___gist.githubusercontent.com_scrthq*.ps1' | Remove-Item -Force
Write-Host -ForegroundColor Cyan "##[section] Importing Azure Pipelines Helper from Gist: $helperUri"
$helperContent = Invoke-RestMethod -Uri $helperUri
$helperContent | Set-Content $localGistPath -Force
}
.([scriptblock]::Create($helperContent))($ModuleName)
Set-BuildVariables
#endregion
Add-Heading "Setting PSGallery InstallationPolicy to 'Trusted'"
if ((Get-PSRepository -Name PSGallery).InstallationPolicy -ne 'Trusted') {
Set-PSRepository -Name PSGallery -InstallationPolicy Trusted -Verbose:$false
}
Add-Heading "Setting `$PSDefaultParameterValues for *-Module functions"
$PSDefaultParameterValues = @{
'*-Module:Verbose' = $false
'*-Module:Force' = $true
'Import-Module:ErrorAction' = 'Stop'
'Install-Module:AcceptLicense' = $true
'Install-Module:AllowClobber' = $true
'Install-Module:Confirm' = $false
'Install-Module:ErrorAction' = 'Stop'
'Install-Module:Repository' = 'PSGallery'
'Install-Module:Scope' = 'CurrentUser'
'Install-Module:SkipPublisherCheck' = $true
}
Add-Heading "Resolving module dependencies"
$moduleDependencies = @()
foreach ($module in $Dependencies.Keys) {
$moduleDependencies += @{
Name = $module
MinimumVersion = $Dependencies[$module]
}
}
(Import-PowerShellDataFile ([System.IO.Path]::Combine($PSScriptRoot,$ModuleName,"$ModuleName.psd1"))).RequiredModules | ForEach-Object {
$item = $_
if ($item -is [hashtable]) {
$hash = @{
Name = $item['ModuleName']
}
if ($_.ContainsKey('ModuleVersion')) {
$hash['RequiredVersion'] = $item['ModuleVersion']
}
$moduleDependencies += $hash
}
else {
if ($Dependencies.Keys -notcontains $item) {
$moduleDependencies += @{
Name = $item
}
}
}
}
try {
$null = Get-PackageProvider -Name Nuget -ForceBootstrap -Verbose:$false -ErrorAction Stop
}
catch {
throw
}
foreach ($item in $moduleDependencies) {
Write-BuildLog "[$($item['Name'])] Resolving"
try {
if ($imported = Get-Module $item['Name']) {
Write-BuildLog "[$($item['Name'])] Removing imported module"
$imported | Remove-Module
}
Import-Module @item
}
catch {
Write-BuildLog "[$($item['Name'])] Installing missing module"
Install-Module @item
Import-Module @item
}
}
Add-Heading "Executing Invoke-Build"
Invoke-Build -ModuleName $ModuleName @PSBoundParameters