From 20252b402b78972ea96066ebd5b5a7402f77da65 Mon Sep 17 00:00:00 2001 From: Cory Knox Date: Mon, 11 Mar 2024 11:38:03 -0700 Subject: [PATCH] (#45) Update build process with release findings Update the build process based on the findings of the 1.0.0 release. - Do not publish artifacts on a PR build. - Do not fail build on missing publish tokens, instead print a warning and gracefully exit. - Add icon to the Chocolatey Package. - Update Chocolatey Package encoding to correct display issue on Chocolatey Community Repository. --- .github/ISSUE_TEMPLATE/zNewRelease.md | 4 +++- Chocolatey-AU.build.ps1 | 16 ++++++++++++---- chocolatey/chocolatey-au.nuspec | 3 ++- 3 files changed, 17 insertions(+), 6 deletions(-) diff --git a/.github/ISSUE_TEMPLATE/zNewRelease.md b/.github/ISSUE_TEMPLATE/zNewRelease.md index b257d2b..8adc378 100644 --- a/.github/ISSUE_TEMPLATE/zNewRelease.md +++ b/.github/ISSUE_TEMPLATE/zNewRelease.md @@ -22,7 +22,7 @@ For the steps requiring a Chocolatey Team Member, reach out to one of the team m - [ ] Make sure all issues in the upcoming milestone have only one type label associated (A type label would be labels such as `Feature`, `Improvement`, `Enhancement`, `Bug Fix`, etc). - [ ] If the GitHub milestone issues are still open, confirm that they are done before moving on. If they are in fact done, apply the `Done` label and close the issue. - [ ] Update the GitHub milestones description if there is a need for any custom words that should be part of the release notes. -- [ ] Run the following command to generate release notes `gitreleasemanager.exe -m --token $env:GITRELEASEMANAGER_PAT -o chocolatey-community -r chocolatey-au` +- [ ] Run the following command to generate release notes `gitreleasemanager.exe create -m --token $env:GITRELEASEMANAGER_PAT -o chocolatey-community -r chocolatey-au` - [ ] **NOTE:** This expects that you have GitReleaseManager installed. If you do not, it can be installed with `choco install gitreleasemanager.portable --confirm` - [ ] **NOTE:** If doing an alpha/beta release, don't run this step, instead generate the release notes manually. GitReleaseManager uses labels and milestones to generate the release notes, and therefore won't understand what needs to be done, especially when there are multiple alpha/beta releases. - [ ] Before running the above command, make sure you have set the environment variable `GITRELEASEMANAGER_PAT` to your own access token. This can be set through PowerShell with `$env:GITRELEASEMANAGER_PAT = ""`. This token requires access to the labels, milestones, issues, pull requests and releases API. @@ -37,9 +37,11 @@ For the steps requiring a Chocolatey Team Member, reach out to one of the team m - [ ] `git push origin` - here origin is assumed to be your fork on the above repository - [ ] Assuming everyone is happy, Publish the GitHub release. - [ ] This will trigger a tagged build on a private CI system. **NOTE:** Contact a Chocolatey Team Member about sending you the package artifact once it has been built if you have no access to internal systems. + - [ ] The triggered build from the private CI system will automatically publish to The PowerShell Gallery. - [ ] Save the package acquired from the internal systems, or a Team Member to a local directory on your local system. - [ ] Verify that the package can be installed and that it can be uninstalled. - [ ] Run `choco install chocolatey-au --source="'C:\testing'"` (_replace `C:\testing` with the location you sawed the package to_) and ensure that it successfully installs (_use upgrade if it was already installed_). + - [ ] Run `Import-Module Chocolatey-AU` and ensure that the module imports successfully. - [ ] Run `choco uninstall chocolatey-au` and verify the package was successfully uninstalled. - [ ] Go back to the releases page, and upload the package artifact `chocolatey-au` to the release. - [ ] Push or ask a Chocolatey Team Member to push the previously uploaded artifact to the Chocolatey Community Repository (_Wait on confirmation that this has been pushed, and is pending moderation before moving further_). diff --git a/Chocolatey-AU.build.ps1 b/Chocolatey-AU.build.ps1 index e4e6d27..e930c5d 100644 --- a/Chocolatey-AU.build.ps1 +++ b/Chocolatey-AU.build.ps1 @@ -43,11 +43,11 @@ param( [string] - $ChocolateyNugetApiKey = $env:CHOCOOPSPUSH_API_KEY, + $ChocolateyNugetApiKey = $env:NUGETDEVPUSH_API_KEY, [string] - $ChocolateyPublishUrl = $env:CHOCOOPSPUSH_SOURCE, + $ChocolateyPublishUrl = $env:NUGETDEVPUSH_SOURCE, [string] @@ -64,6 +64,7 @@ $script:SourceFolder = "$PSScriptRoot/src" $script:ReleaseBuild = -not [string]::IsNullOrEmpty((git tag --points-at HEAD 2> $null) -replace '^v') $script:BuildVersion = $null $script:IsPrerelease = $false +$script:IsPullRequest = $false $script:ModuleOutputDir = "$OutputDirectory/$ModuleName" @@ -193,6 +194,7 @@ task Build Clean, InstallGitVersion, ScriptAnalyzer, { $gitversion | Out-String -Width 120 | Write-Host $versionInfo = $gitversion 2>$null | ConvertFrom-Json + $script:IsPullRequest = $versionInfo.BranchName -match '(changes|pull|pull-requests|merge-requests)' $manifestUpdates = @{ Path = $manifest.FullName ModuleVersion = $versionInfo.MajorMinorPatch @@ -335,13 +337,14 @@ task Sign -After Build { } # Synopsis: publish $ModuleName either internally or to the PSGallery -task Publish -If ($script:ReleaseBuild -or $PublishUrl) Build, { +task Publish -If ((-not $script:IsPullRequest) -and ($script:ReleaseBuild -or $PublishUrl)) Build, { if (-not (Test-Path $OutputDirectory)) { throw 'Build the module with `Invoke-Build` or `build.ps1` before attempting to publish the module' } if (-not $NugetApiKey -or -not $ChocolateyNugetApiKey) { - throw 'Please pass the API key for publishing to both the `-NugetApiKey` and `-ChocolateyNugetApiKey` parameter or set $env:POWERSHELLPUSH_API_KEY and $env:CHOCOOPSPUSH_API_KEY before publishing' + Write-Warning 'Please pass the API key for publishing to both the `-NugetApiKey` and `-ChocolateyNugetApiKey` parameter or set $env:POWERSHELLPUSH_API_KEY and $env:NUGETDEVPUSH_API_KEY before publishing.' + return } $psdFile = Resolve-Path $script:ModuleOutputDir @@ -380,6 +383,11 @@ task Publish -If ($script:ReleaseBuild -or $PublishUrl) Build, { } if ($script:ReleaseBuild) { + if ($null -eq $env:POWERSHELLGALLERY_API_KEY) { + Write-Warning "Tagged build, but no API key present. Not publishing build to PowerShell Gallery." + return + } + Write-Verbose "Publishing to PSGallery" $publishParams.NugetApiKey = $env:POWERSHELLGALLERY_API_KEY $publishParams.Repository = 'PSGallery' diff --git a/chocolatey/chocolatey-au.nuspec b/chocolatey/chocolatey-au.nuspec index c8fab31..8a08ff3 100644 --- a/chocolatey/chocolatey-au.nuspec +++ b/chocolatey/chocolatey-au.nuspec @@ -1,4 +1,4 @@ - + @@ -10,6 +10,7 @@ Chocolatey-AU is Powershell module that helps you to automate Chocolatey package updates https://github.com/chocolatey-community/chocolatey-au + https://chocolatey.org/assets/images/nupkg/chocolateyicon.png admin powershell module package chocolatey update Miodrag Milić, Chocolatey Community https://www.gnu.org/licenses/gpl-2.0.txt