-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Chris Hunt
committed
Dec 13, 2023
1 parent
e50f586
commit 83610f1
Showing
22 changed files
with
1,421 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,112 @@ | ||
name: PowerShell | ||
|
||
on: | ||
push: | ||
branches: [ "main" ] | ||
paths-ignore: | ||
- 'docs/**' | ||
- 'Changelog.md' | ||
- 'README.md' | ||
- src/internal/Export-HelpToMd.ps1 | ||
pull_request: | ||
branches: [ "main" ] | ||
|
||
permissions: | ||
contents: read | ||
|
||
jobs: | ||
build: | ||
permissions: | ||
contents: read # for actions/checkout to fetch code | ||
security-events: write # for github/codeql-action/upload-sarif to upload SARIF results | ||
actions: read # only required for a private repository by github/codeql-action/upload-sarif to get the Action run status | ||
name: Build | ||
runs-on: ubuntu-latest | ||
|
||
steps: | ||
- uses: actions/checkout@v4 | ||
with: | ||
fetch-depth: 0 # avoid shallow clone so nbgv can do its work. | ||
|
||
- name: Run PSScriptAnalyzer | ||
uses: microsoft/psscriptanalyzer-action@6b2948b1944407914a58661c49941824d149734f | ||
with: | ||
# Check https://github.com/microsoft/action-psscriptanalyzer for more info about the options. | ||
# The below set up runs PSScriptAnalyzer to your entire repository and runs some basic security rules. | ||
path: .\src | ||
recurse: true | ||
# Include your own basic security rules. Removing this option will run all the rules | ||
includeRule: '"PSAvoidGlobalAliases", "PSAvoidUsingConvertToSecureStringWithPlainText"' | ||
output: results.sarif | ||
|
||
# Upload the SARIF file generated in the previous step | ||
- name: Upload SARIF results file | ||
uses: github/codeql-action/upload-sarif@v2 | ||
with: | ||
sarif_file: results.sarif | ||
|
||
- uses: dotnet/nbgv@1801854259a50d987aaa03b99b28cebf49faa779 | ||
id: nbgv | ||
|
||
- name: Build | ||
shell: pwsh | ||
run: ./build.ps1 build ${{ steps.nbgv.outputs.VersionMajor }} ${{ steps.nbgv.outputs.VersionMinor }} ${{ steps.nbgv.outputs.BuildNumber }} ${{ steps.nbgv.outputs.VersionRevision }} ${{ steps.nbgv.outputs.PrereleaseVersionNoLeadingHyphen }} | ||
|
||
- name: Store build output | ||
uses: actions/upload-artifact@v3 | ||
with: | ||
name: build | ||
path: | | ||
publish | ||
retention-days: 1 | ||
|
||
test: | ||
permissions: | ||
contents: read # for actions/checkout to fetch code | ||
actions: read # only required for a private repository by github/codeql-action/upload-sarif to get the Action run status | ||
name: Test | ||
needs: Build | ||
runs-on: ubuntu-latest | ||
container: | ||
image: mcr.microsoft.com/powershell:${{ matrix.pwshv }}-ubuntu-22.04 | ||
strategy: | ||
matrix: | ||
pwshv: ['7.3','7.4'] | ||
|
||
steps: | ||
- uses: actions/checkout@v4 | ||
|
||
- name: Download build output | ||
uses: actions/download-artifact@v3 | ||
with: | ||
name: build | ||
path: publish | ||
|
||
- name: Test | ||
shell: pwsh | ||
run: ./build.ps1 test | ||
|
||
publish: | ||
permissions: | ||
contents: read # for actions/checkout to fetch code | ||
actions: read # only required for a private repository by github/codeql-action/upload-sarif to get the Action run status | ||
name: Publish | ||
needs: Test | ||
runs-on: ubuntu-latest | ||
container: | ||
image: mcr.microsoft.com/dotnet/sdk:8.0 | ||
if: github.ref == 'refs/heads/main' | ||
steps: | ||
- uses: actions/checkout@v4 | ||
|
||
- name: Download build output | ||
uses: actions/download-artifact@v3 | ||
with: | ||
name: build | ||
path: publish | ||
|
||
- name: Publish | ||
shell: pwsh | ||
run: ./build.ps1 publish | ||
env: | ||
PSPublishApiKey: ${{ secrets.NUGETAPIKEY }} |
Oops, something went wrong.