Merge pull request #29 from Ben-m-s/vNext #2
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
name: PowerShell | |
on: | |
push: | |
branches: [ "main" ] | |
paths-ignore: | |
- 'docs/**' | |
- 'Changelog.md' | |
- 'README.md' | |
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 -Package | |
- name: Store build output | |
uses: actions/upload-artifact@v4 | |
with: | |
name: build | |
path: | | |
publish | |
retention-days: 1 | |
test7: | |
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 PowerShell 7 | |
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@v4 | |
with: | |
name: build | |
path: publish | |
- name: Install Utils | |
shell: pwsh | |
run: | | |
apt-get update | |
apt-get install curl jq -y | |
- uses: testspace-com/setup-testspace@v1 | |
with: | |
domain: ${{github.repository_owner}} | |
- name: Test | |
shell: pwsh | |
run: ./build.ps1 -Test | |
- name: Publish Results to Testspace | |
run: testspace "[v${{ matrix.pwshv }}]testResults.xml" | |
if: always() | |
test5: | |
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 PowerShell 5 | |
needs: Build | |
runs-on: windows-latest | |
steps: | |
- uses: actions/checkout@v4 | |
with: | |
fetch-depth: 0 | |
- name: Download build output | |
uses: actions/download-artifact@v4 | |
with: | |
name: build | |
path: publish | |
- uses: testspace-com/setup-testspace@v1 | |
with: | |
domain: ${{github.repository_owner}} | |
- name: Test | |
shell: powershell | |
run: ./build.ps1 -Test | |
- name: Publish Results to Testspace | |
run: testspace "[v5.1]testResults.xml" | |
if: always() | |
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: [test7, test5] | |
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@v4 | |
with: | |
name: build | |
path: publish | |
- name: Publish | |
shell: pwsh | |
run: ./build.ps1 -Publish | |
env: | |
PSPublishApiKey: ${{ secrets.NUGETAPIKEY }} |