A workflow for crafting PowerShell modules using the PSModule framework, which builds, tests and publishes PowerShell modules to the PowerShell Gallery and produces documentation that is published to GitHub Pages. The workflow is used by all PowerShell modules in the PSModule organization.
- Create a repository from the Template-Module.
- Configure the repository:
- Enable GitHub Pages in the repository settings. Set it to deploy from
GitHub Actions
. - This will create an environment called
github-pages
that GitHub deploys your site to. - Create an API key on the PowerShell Gallery. Give it enough permission to manage the module you are working on.
- Create a new secret in the repository called
APIKEY
and set it to the API key for the PowerShell Gallery.
- Enable GitHub Pages in the repository settings. Set it to deploy from
- Create a branch, make your changes, create a PR and let the workflow run.
The workflow is designed to be trigger on pull requests to the repository's default branch. When a pull request is opened, closed, reopened, synchronized (push), or labeled, the workflow will run. Depending on the labels in the pull requests, the workflow will result in different outcomes.
- Get settings
- Reads the settings file from a file in the module repository to configure the workflow.
- Gathers tests and creates test configuration based on the settings and the tests available in the module repository.
- This includes the selection of what OSes to run the tests on.
- Build module
- Compiles the module source code into a PowerShell module.
- Test source code
- Tests the source code in parallel (matrix) using PSModule framework settings for style and standards for source code
- This produces a json based report that is used to later evaluate the results of the tests.
- Lint source code
- Lints the source code in parallel (matrix) using PSScriptAnalyzer rules.
- This produces a json based report that is used to later evaluate the results of the linter.
- Framework test
- Tests and lints the module in parallel (matrix) using PSModule framework settings for style and standards foor modules + PSScriptAnalyzer rules.
- This produces a json based report that is used to later evaluate the results of the tests.
- Test module
- Import and tests the module in parallel (matrix) using Pester tests from the module repository.
- This produces a json based report that is used to later evaluate the results of the tests.
- Get test results
- Gathers the test results from the previous steps and creates a summary of the results.
- If any tests have failed, the workflow will fail here.
- Get code coverage
- Gathers the code coverage from the previous steps and creates a summary of the results.
- If the code coverage is below the target, the workflow will fail here.
- Build docs
- Generates documentation and lints the documentation using super-linter.
- Build site
- Generates a static site using Material for MkDocs.
- Publish site
- Publishes the static site with the module documentationto GitHub Pages.
- Publish module
- Publishes the module to the PowerShell Gallery.
- Creates a release on the GitHub repository.
To use the workflow, create a new file in the .github/workflows
directory of the module repository and add the following content.
Workflow suggestion
name: Process-PSModule
on:
pull_request:
branches:
- main
types:
- closed
- opened
- reopened
- synchronize
- labeled
concurrency:
group: ${{ github.workflow }}-${{ github.ref }}
cancel-in-progress: true
permissions:
contents: write
pull-requests: write
jobs:
Process-PSModule:
uses: PSModule/Process-PSModule/.github/workflows/workflow.yml@v2
secrets:
APIKEY: ${{ secrets.APIKEY }}
The workflow is configured using a settings file in the module repository.
The file can be a JSON
, YAML
or PSD1
file. By default it will look for .github/PSModule.yml
.
The following settings are available in the settings file: Here's a Markdown-formatted table describing your PowerShell object structure clearly and concisely:
Name | Type | Description | Default |
---|---|---|---|
Name |
String |
Name of the module to publish. Defaults to repository name. | null |
Test.Skip |
Boolean |
Skip all tests | false |
Test.Linux.Skip |
Boolean |
Skip tests on Linux | false |
Test.MacOS.Skip |
Boolean |
Skip tests on macOS | false |
Test.Windows.Skip |
Boolean |
Skip tests on Windows | false |
Test.SourceCode.Skip |
Boolean |
Skip source code tests | false |
Test.SourceCode.Linux.Skip |
Boolean |
Skip source code tests on Linux | false |
Test.SourceCode.MacOS.Skip |
Boolean |
Skip source code tests on macOS | false |
Test.SourceCode.Windows.Skip |
Boolean |
Skip source code tests on Windows | false |
Test.PSModule.Skip |
Boolean |
Skip PSModule framework tests | false |
Test.PSModule.Linux.Skip |
Boolean |
Skip PSModule framework tests on Linux | false |
Test.PSModule.MacOS.Skip |
Boolean |
Skip PSModule framework tests on macOS | false |
Test.PSModule.Windows.Skip |
Boolean |
Skip PSModule framework tests on Windows | false |
Test.Module.Skip |
Boolean |
Skip module tests | false |
Test.Module.Linux.Skip |
Boolean |
Skip module tests on Linux | false |
Test.Module.MacOS.Skip |
Boolean |
Skip module tests on macOS | false |
Test.Module.Windows.Skip |
Boolean |
Skip module tests on Windows | false |
Test.TestResults.Skip |
Boolean |
Skip test result processing | false |
Test.CodeCoverage.Skip |
Boolean |
Skip code coverage tests | false |
Test.CodeCoverage.PercentTarget |
Integer |
Target code coverage percentage | 0 |
Test.CodeCoverage.StepSummaryMode |
String |
Step summary mode for code coverage reports | 'Missed, Files' |
Build.Skip |
Boolean |
Skip all build tasks | false |
Build.Module.Skip |
Boolean |
Skip module build | false |
Build.Docs.Skip |
Boolean |
Skip documentation build | false |
Build.Site.Skip |
Boolean |
Skip site build | false |
Publish.Module.Skip |
Boolean |
Skip module publishing | false |
Publish.Module.AutoCleanup |
Boolean |
Automatically cleanup old prerelease module versions | true |
Publish.Module.AutoPatching |
Boolean |
Automatically patch module version | true |
Publish.Module.IncrementalPrerelease |
Boolean |
Use incremental prerelease versioning | true |
Publish.Module.DatePrereleaseFormat |
String |
Format for date-based prerelease (.NET DateTime) | '' |
Publish.Module.VersionPrefix |
String |
Prefix for version tags | 'v' |
Publish.Module.MajorLabels |
String |
Labels indicating a major version bump | 'major, breaking' |
Publish.Module.MinorLabels |
String |
Labels indicating a minor version bump | 'minor, feature' |
Publish.Module.PatchLabels |
String |
Labels indicating a patch version bump | 'patch, fix' |
Publish.Module.IgnoreLabels |
String |
Labels indicating no release | 'NoRelease' |
`PSModule.yml` with all defaults
Name: null
Build:
Skip: false
Module:
Skip: false
Docs:
Skip: false
Site:
Skip: false
Test:
Skip: false
Linux:
Skip: false
MacOS:
Skip: false
Windows:
Skip: false
SourceCode:
Skip: false
Linux:
Skip: false
MacOS:
Skip: false
Windows:
Skip: false
PSModule:
Skip: false
Linux:
Skip: false
MacOS:
Skip: false
Windows:
Skip: false
Module:
Skip: false
Linux:
Skip: false
MacOS:
Skip: false
Windows:
Skip: false
TestResults:
Skip: false
CodeCoverage:
Skip: false
PercentTarget: 0
StepSummaryMode: 'Missed, Files'
Publish:
Module:
Skip: false
AutoCleanup: true
AutoPatching: true
IncrementalPrerelease: true
DatePrereleaseFormat: ''
VersionPrefix: 'v'
MajorLabels: 'major, breaking'
MinorLabels: 'minor, feature'
PatchLabels: 'patch, fix'
IgnoreLabels: 'NoRelease'
This example runs all steps and will require that code coverage is 80% before passing.
Test:
CodeCoverage:
PercentTarget: 80
This example ends up running Get-Settings, Build-Module and Test-Module (tests from the module repo) on ubuntu-latest.
Test:
SourceCode:
Skip: true
PSModule:
Skip: true
Module:
MacOS:
Skip: true
Windows:
Skip: true
TestResults:
Skip: true
CodeCoverage:
Skip: true
Build:
Docs:
Skip: true
Name | Type | Description | Required | Default |
---|---|---|---|---|
Name |
string |
The name of the module to process. This defaults to the repository name if nothing is specified. | false |
N/A |
SettingsPath |
string |
The path to the settings file. Settings in the settings file take precedence over the action inputs. | false |
.github/PSModule.yml |
Version |
string |
Specifies the version of the GitHub module to be installed. The value must be an exact version. | false |
'' |
Prerelease |
boolean |
Whether to use a prerelease version of the 'GitHub' module. | false |
false |
Debug |
boolean |
Whether to enable debug output. Adds a debug step to every job. |
false |
false |
Verbose |
boolean |
Whether to enable verbose output. | false |
false |
WorkingDirectory |
string |
The path to the root of the repo. | false |
. |
The following secrets are used by the workflow. They can be automatically provided (if available) by setting the secrets: inherit
in the workflow file.
Name | Location | Description | Default |
---|---|---|---|
APIKEY |
GitHub secrets | The API key for the PowerShell Gallery. | N/A |
TEST_APP_ENT_CLIENT_ID |
GitHub secrets | The client ID of an Enterprise GitHub App for running tests. | N/A |
TEST_APP_ENT_PRIVATE_KEY |
GitHub secrets | The private key of an Enterprise GitHub App for running tests. | N/A |
TEST_APP_ORG_CLIENT_ID |
GitHub secrets | The client ID of an Organization GitHub App for running tests. | N/A |
TEST_APP_ORG_PRIVATE_KEY |
GitHub secrets | The private key of an Organization GitHub App for running tests. | N/A |
TEST_USER_ORG_FG_PAT |
GitHub secrets | The fine-grained personal access token with org access for running tests. | N/A |
TEST_USER_USER_FG_PAT |
GitHub secrets | The fine-grained personal access token with user account access for running tests. | N/A |
TEST_USER_PAT |
GitHub secrets | The classic personal access token for running tests. | N/A |
The action requires the following permissions:
If running the action in a restrictive mode, the following permissions needs to be granted to the action:
permissions:
contents: write # Create releases
pull-requests: write # Create comments on the PRs
statuses: write # Update the status of the PRs from the linter
To publish the documentation to GitHub Pages, the action requires the following permissions:
permissions:
pages: write # Deploy to Pages
id-token: write # Verify the deployment originates from an appropriate source
For more info see Deploy GitHub Pages site.
Process-PSModule follows: