Skip to content

docs: update CHANGELOG.md #4

docs: update CHANGELOG.md

docs: update CHANGELOG.md #4

Workflow file for this run

name: Release
on:
push:
tags:
- "v[0-9]+.[0-9]+.[0-9]+*"
permissions:
contents: write
jobs:
create-release:
runs-on: ubuntu-latest
steps:
- name: Checkout Repository
uses: actions/checkout@8ade135a41bc03ea155e62e844d188df1ea18608 # v4.1.0
with:
fetch-depth: 0
- name: Check Version
shell: pwsh
if: startsWith(github.ref, 'refs/tags/v')
run: |
$tag = $env:GITHUB_REF.Replace('refs/tags/v', '')
$manifestName = (Get-ChildItem -Path $env:GITHUB_WORKSPACE -Filter *.psd1).Name
$moduleVersion = [regex]::Match((Get-Content -Path ./$manifestName -Raw), '(?<=ModuleVersion\s*=\s*'')[^'']+(?='')').Value
$version = $moduleVersion -split '\.' | Select-Object -First 3 | Join-String -Separator '.'
$release = ($tag -replace '^v') -split '\.' | Select-Object -First 3 | Join-String -Separator '.'
if ($version -ne $release) {
Write-Error "FAILED: Comparing module version '$version' with release tag 'v$tag'."
exit 1
} else {
Write-Output "SUCCESS: Comparing module version '$version' with release tag 'v$tag'."
}
- name: Check Changelog
shell: pwsh
run: |
$version = $env:GITHUB_REF.Replace('refs/tags/', '')
$changelog = Get-Content -Path CHANGELOG.md
$foundVersion = $false
foreach ($line in $changelog) {
if ($line -match "^## $version$") {
$foundVersion = $true
continue
}
if ($foundVersion -and $line -match "^## ") {
break
}
}
if ($foundVersion) {
Write-Output "SUCCESS: Locating release in the changelog for version '$version'."
} else {
Write-Error "FAILED: Locating release in the changelog for version '$version'."
exit 1
}
- name: Create Release Branch
shell: pwsh
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
run: |
$version = $env:GITHUB_REF.Replace('refs/tags/', '')
$releaseBranch = "release/$version"
$git = Get-Command git | Select-Object -ExpandProperty Definition
& $git config --global user.name "github-actions[bot]"
& $git config --global user.email "41898282+github-actions[bot]@users.noreply.github.com"
& $git checkout -b $releaseBranch
& $git push origin $releaseBranch
if ($LASTEXITCODE -ne 0) {
Write-Error "FAILED: Creating release branch '$releaseBranch'."
} else {
Write-Output "SUCCESS: Creating release branch '$releaseBranch'."
}
- name: Rebase Main Branch
shell: pwsh
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
run: |
$version = $env:GITHUB_REF.Replace('refs/tags/', '')
$releaseBranch = "release/$version"
$git = Get-Command git | Select-Object -ExpandProperty Definition
& $git config --global user.name "github-actions[bot]"
& $git config --global user.email "41898282+github-actions[bot]@users.noreply.github.com"
& $git checkout $releaseBranch
& $git pull origin $releaseBranch
& $git checkout main
& $git pull origin main
& $git rebase $releaseBranch
& $git push origin main
if ($LASTEXITCODE -ne 0) {
Write-Error "FAILED: Rebasing main branch from release branch '$releaseBranch'."
} else {
Write-Output "SUCCESS: Rebasing main branch from release branch '$releaseBranch'."
}
- name: Install GitHub CLI
run: |
type -p curl >/dev/null || (sudo apt update && sudo apt install curl -y)
curl -fsSL https://cli.github.com/packages/githubcli-archive-keyring.gpg | sudo dd of=/usr/share/keyrings/githubcli-archive-keyring.gpg \
&& sudo chmod go+r /usr/share/keyrings/githubcli-archive-keyring.gpg \
&& echo "deb [arch=$(dpkg --print-architecture) signed-by=/usr/share/keyrings/githubcli-archive-keyring.gpg] https://cli.github.com/packages stable main" | sudo tee /etc/apt/sources.list.d/github-cli.list > /dev/null \
&& sudo apt update \
&& sudo apt install gh -y
- name: Create Release
shell: pwsh
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
run: |
$version = $env:GITHUB_REF.Replace('refs/tags/', '')
$changelog = Get-Content -Path CHANGELOG.md
$releaseNotes = $null
$foundVersion = $false
foreach ($line in $changelog) {
if ($line -match "^## $version$") {
$foundVersion = $true
continue
}
if ($foundVersion -and $line -match "^## ") {
break
}
if ($foundVersion) {
$releaseNotes += $line + "`n"
}
}
$gh = Get-Command gh | Select-Object -ExpandProperty Definition
& $gh release create $version --title "$version" --notes "$releaseNotes" --target "release/$version"
if ($LASTEXITCODE -ne 0) {
Write-Error "FAILED: Creating GitHub release '$version'."
} else {
Write-Output "SUCCESS: Creating GitHub release '$version'."
}
publish-docs:
needs: create-release
runs-on: ubuntu-latest
steps:
- name: Checkout Repository
uses: actions/checkout@3df4ab11eba7bda6032a0b82a6bb43b11571feac # v4.0.0
with:
ref: ${{ github.event.release.tag_name }}
fetch-depth: 0
- name: Setup Python
uses: actions/setup-python@0a5c61591373683505ea898e09a3ea4f39ef2b9c # v5.0.0
with:
python-version: 3.x
- name: Install Dependencies
run: |
pip install mkdocs-material
pip install --requirement docs/requirements.txt
- name: Publish Documentation
run: |
mkdocs gh-deploy --force
if: ${{ success() }}
publish-module:
needs: [create-release, publish-docs]
runs-on: ubuntu-latest
steps:
- name: Checkout Repository
uses: actions/checkout@8ade135a41bc03ea155e62e844d188df1ea18608 # v4.1.0
with:
ref: ${{ github.event.release.tag_name }}
fetch-depth: 0
- name: Publish Module to PowerShell Gallery
shell: pwsh
env:
PSGALLERY_API_KEY: ${{ secrets.PSGALLERY_API_KEY }}
run: |
Write-Output "INFO: Preparing Ubuntu-based GitHub runner for publishing module to the PowerShell Gallery."
Write-Output "INFO: Setting the PowerShell Gallery as a trusted repository."
Set-PSRepository psgallery -InstallationPolicy trusted
Write-Output "INFO: Locating module manifest in '$env:GITHUB_WORKSPACE'."
$moduleManifest = (Get-ChildItem -Path $env:GITHUB_WORKSPACE -Filter *.psd1).Name
if ($moduleManifest) {
Write-Output "SUCCESS: Manifest '$moduleManifest' found in '$env:GITHUB_WORKSPACE'."
} else {
Write-Output "FAILURE: Manifest not found in '$env:GITHUB_WORKSPACE'."
}
if ($moduleManifest -match '^(.*)\.psd1$') {
$moduleName = $Matches[1]
Write-Output "SUCCESS: Determining module name from manifest '$moduleManifest'."
} else {
Write-Error "FAILED: Determining module name from manifest '$moduleManifest'."
}
Write-Output "INFO: Reading module manifest '$moduleManifest'."
$moduleManifestData = Import-PowerShellDataFile -Path $moduleManifest
Write-Output "INFO: Determining module dependencies."
$requiredModules = $moduleManifestData.RequiredModules
if ($requiredModules) {
Write-Output "SUCCESS: Module dependencies were found."
Write-Output "INFO: Required modules are $($requiredModules.ModuleName -join ', ')."
Write-Output "INFO: Setting location to the PowerShell modules location on a Ubuntu-based GitHub runner."
Set-Location '/home/runner/.local/share/powershell/Modules/'
foreach ($module in $requiredModules) {
$requiredModuleName = $module.ModuleName
New-Item $requiredModuleName -ItemType Directory
Write-Output "INFO: Performing workaround for github.com/PowerShell/PowerShell/issues/7722."
Write-Output "INFO: Creating placeholder manifest for $requiredModuleName at $((Get-Location).Path)/$requiredModuleName/$requiredModuleName.psd1"
New-Item "./$requiredModuleName/$requiredModuleName.psd1" -ItemType File
}
} else {
Write-Output "INFO: No module dependencies were found."
}
Write-Output "INFO: Setting location to the GitHub workspace at '$env:GITHUB_WORKSPACE'."
Set-Location $env:GITHUB_WORKSPACE
Write-Output "INFO: Publishing module to the PowerShell Gallery."
$remove = @('.ci', '.dependencies', '.git', '.github', '.gitignore', '.vscode', 'docs', 'CODEOWNERS', 'CODE_OF_CONDUCT.md', 'CONTRIBUTING.md', 'Makefile', 'mkdocs.yml')
$random = Get-Random -Count 1
$destinationPath = Join-Path -Path $env:GITHUB_WORKSPACE -ChildPath $random
$manifestName = (Get-ChildItem -Path $env:GITHUB_WORKSPACE -Filter *.psd1).Name
$moduleVersion = [regex]::Match((Get-Content -Path ./$manifestName -Raw), '(?<=ModuleVersion\s*=\s*'')[^'']+(?='')').Value
if ($manifestName -match '^(.*)\.psd1$') {
$moduleName = $Matches[1]
Write-Output "SUCCESS: Determining module name from manifest file name '$moduleName'."
} else {
Write-Error "FAILED: Determining module name from manifest file name '$moduleName'."
}
$modulePath = Join-Path -Path $destinationPath -ChildPath $moduleName
$createModulePath = New-Item -Path $modulePath -ItemType Directory -Force
if ($createModulePath) {
Write-Output "SUCCESS: Creating staging path '$modulePath'."
} else {
Write-Error "FAILED: Creating staging path '$modulePath'."
}
Get-ChildItem -Force | Where-Object { $_.Name -notin $remove -and $_.Name -ne $random } | Copy-Item -Destination $modulePath -Recurse
Get-ChildItem -Depth 5 -Path $modulePath | Format-Table -AutoSize
$moduleManifest = Join-Path -Path $modulePath -ChildPath "$moduleName.psd1"
if (Test-Path -Path $moduleManifest) {
Publish-Module -Path $modulePath -NuGetApiKey $env:PSGALLERY_API_KEY
Start-Sleep -Seconds 30
$module = Find-Module -Name $moduleName -RequiredVersion "$moduleVersion"
if ($module) {
Write-Output "SUCCESS: Publishing module '$moduleName' version '$moduleVersion' to PowerShell Gallery."
} else {
Write-Error "FAILED: Publishing module '$moduleName' version '$moduleVersion' to PowerShell Gallery."
}
} else {
Write-Error "FAILED: Module manifest file not found at path '$moduleManifest'."
}