Skip to content

Merge pull request #722 from aaronparker/apps #66

Merge pull request #722 from aaronparker/apps

Merge pull request #722 from aaronparker/apps #66

Workflow file for this run

name: 'Validate main branch'
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
on:
workflow_dispatch:
push:
branches: [ "main" ]
paths:
- 'Evergreen/**.ps1'
- 'Evergreen/**.psm1'
jobs:
psscriptanalyzer:
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: Run PSScriptAnalyzer
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: Run PSScriptAnalyzer (main push)
uses: microsoft/psscriptanalyzer-action@6b2948b1944407914a58661c49941824d149734f
with:
path: "./Evergreen"
recurse: true
output: results.sarif
# Upload the SARIF file generated in the previous step
- name: Upload SARIF results file
uses: github/codeql-action/upload-sarif@v3
with:
sarif_file: results.sarif
pestertest5:
name: "Run Pester tests on Windows PowerShell (main push)"
needs: psscriptanalyzer
runs-on: windows-latest
steps:
- uses: actions/checkout@v4
- name: Pester tests
shell: powershell
working-directory: "${{ github.workspace }}"
run: |
.\tests\Install-Pester.ps1
Import-Module -Name "Pester" -Force -ErrorAction "Stop"
Import-Module -Name "$env:GITHUB_WORKSPACE\Evergreen" -Force
$Config = [PesterConfiguration]::Default
$Config.Run.Path = "$env:GITHUB_WORKSPACE\tests"
$Config.Run.PassThru = $true
$Config.CodeCoverage.Enabled = $true
$Config.CodeCoverage.Path = "$env:GITHUB_WORKSPACE\Evergreen"
$Config.CodeCoverage.OutputFormat = "JaCoCo"
$Config.CodeCoverage.OutputPath = "$env:GITHUB_WORKSPACE\CodeCoverage.xml"
$Config.Output.Verbosity = "Detailed"
$Config.TestResult.Enabled = $true
$Config.TestResult.OutputFormat = "NUnitXml"
$Config.TestResult.OutputPath = "$env:GITHUB_WORKSPACE\tests\TestResults.xml"
Invoke-Pester -Configuration $Config
# Upload test results
- name: Upload Pester test results
uses: actions/upload-artifact@v4
if: always()
with:
name: test-results
path: "${{ github.workspace }}\\tests\\TestResults.xml"
- name: Upload code coverage results
uses: actions/upload-artifact@v4
if: always()
with:
name: codecov-results
path: "${{ github.workspace }}\\CodeCoverage.xml"
# pestertest7:
# name: "Run Pester tests on PowerShell Core (main push)"
# needs: psscriptanalyzer
# runs-on: ubuntu-latest
# steps:
# - uses: actions/checkout@v4
# - name: Install module DnsClient-PS
# shell: pwsh
# working-directory: "${{ github.workspace }}"
# run: |
# [System.Net.ServicePointManager]::SecurityProtocol = [System.Net.ServicePointManager]::SecurityProtocol -bor 3072
# Install-PackageProvider -Name "NuGet" -MinimumVersion "2.8.5.208" -Force -ErrorAction "SilentlyContinue"
# Install-PackageProvider -Name "PowerShellGet" -MinimumVersion "2.2.5" -Force -ErrorAction "SilentlyContinue"
# Set-PSRepository -Name "PSGallery" -InstallationPolicy "Trusted" -ErrorAction "SilentlyContinue"
# $params = @{
# Name = "DnsClient-PS"
# SkipPublisherCheck = $true
# Force = $true
# ErrorAction = "Stop"
# }
# Install-Module @params
# - name: Pester tests
# shell: pwsh
# working-directory: "${{ github.workspace }}"
# run: |
# [System.Net.ServicePointManager]::SecurityProtocol = [System.Net.ServicePointManager]::SecurityProtocol -bor 3072
# Install-PackageProvider -Name "NuGet" -MinimumVersion "2.8.5.208" -Force -ErrorAction "SilentlyContinue"
# Install-PackageProvider -Name "PowerShellGet" -MinimumVersion "2.2.5" -Force -ErrorAction "SilentlyContinue"
# Set-PSRepository -Name "PSGallery" -InstallationPolicy "Trusted" -ErrorAction "SilentlyContinue"
# $params = @{
# Name = "Pester"
# SkipPublisherCheck = $true
# ErrorAction = "Stop"
# }
# Install-Module @params
# Import-Module -Name "Pester" -Force
# Import-Module -Name "$env:GITHUB_WORKSPACE/Evergreen"
# $Config = [PesterConfiguration]::Default
# $Config.Run.Path = "$env:GITHUB_WORKSPACE/tests"
# $Config.Run.PassThru = $true
# $Config.CodeCoverage.Enabled = $true
# $Config.CodeCoverage.Path = "$env:GITHUB_WORKSPACE/Evergreen"
# $Config.CodeCoverage.OutputFormat = "JaCoCo"
# $Config.CodeCoverage.OutputPath = "$env:GITHUB_WORKSPACE/CodeCoverage7.xml"
# $Config.Output.Verbosity = "Detailed"
# $Config.TestResult.Enabled = $true
# $Config.TestResult.OutputFormat = "NUnitXml"
# $Config.TestResult.OutputPath = "$env:GITHUB_WORKSPACE/tests/TestResults7.xml"
# Invoke-Pester -Configuration $Config
# # Upload test results
# - name: Upload Pester test results
# uses: actions/upload-artifact@v4
# if: always()
# with:
# name: test-results
# path: "${{ github.workspace }}//tests//TestResults7.xml"
# - name: Upload code coverage results
# uses: actions/upload-artifact@v4
# if: always()
# with:
# name: codecov-results
# path: "${{ github.workspace }}//CodeCoverage7.xml"
publish-test-results:
name: "Publish Tests Results"
needs: [ "pestertest5"]
runs-on: ubuntu-latest
if: always()
permissions:
checks: write
# only needed unless run with comment_mode: off
pull-requests: write
steps:
- name: Download Pester Test Result Artifacts
uses: actions/download-artifact@v4
with:
name: test-results
path: test-results
- name: Publish Pester Test Results
uses: EnricoMi/publish-unit-test-result-action@v2
with:
nunit_files: "test-results/**/*.xml"
- name: Download Code Coverage Result Artifacts
uses: actions/download-artifact@v4
if: always()
with:
name: codecov-results
path: codecov-results
- name: Upload to Codecov
id: codecov
uses: codecov/codecov-action@v4
with:
token: ${{ secrets.CODECOV_TOKEN }}
files: "codecov-results/**/*.xml"
verbose: true