tests/pester.ps1
param ( $Show = "None" ) Write-Host "Starting Tests" -ForegroundColor Green if ($env:BUILD_BUILDURI -like "vstfs*") { Write-Host "Installing Pester" -ForegroundColor Cyan Install-Module Pester -Force -SkipPublisherCheck Write-Host "Installing PSFramework" -ForegroundColor Cyan Install-Module PSFramework -Force -SkipPublisherCheck } Write-PSFMessage -Level Important -Message "Importing Module" Remove-Module PSUtil -ErrorAction Ignore Import-Module "$PSScriptRoot\..\PSUtil.psd1" Import-Module "$PSScriptRoot\..\PSUtil.psm1" -Force $totalFailed = 0 $totalRun = 0 $testresults = @() Write-PSFMessage -Level Important -Message "Modules imported, proceeding with general tests" foreach ($file in (Get-ChildItem "$PSScriptRoot\general" -Filter "*.Tests.ps1")) { Write-PSFMessage -Level Significant -Message " Executing <c='em'>$($file.Name)</c>" $results = Invoke-Pester -Script $file.FullName -Show $Show -PassThru foreach ($result in $results) { $totalRun += $result.TotalCount $totalFailed += $result.FailedCount $result.TestResult | Where-Object { -not $_.Passed } | ForEach-Object { $name = $_.Name $testresults += [pscustomobject]@{ Describe = $_.Describe Context = $_.Context Name = "It $name" Result = $_.Result Message = $_.FailureMessage } } } } Write-PSFMessage -Level Important -Message "Proceeding with individual tests" foreach ($file in (Get-ChildItem "$PSScriptRoot\functions" -Recurse -File -Filter "*Tests.ps1")) { Write-PSFMessage -Level Significant -Message " Executing $($file.Name)" $results = Invoke-Pester -Script $file.FullName -Show None -PassThru foreach ($result in $results) { $totalRun += $result.TotalCount $totalFailed += $result.FailedCount $result.TestResult | Where-Object { -not $_.Passed } | ForEach-Object { $name = $_.Name $testresults += [pscustomobject]@{ Describe = $_.Describe Context = $_.Context Name = "It $name" Result = $_.Result Message = $_.FailureMessage } } } } $testresults | Sort-Object Describe, Context, Name, Result, Message | Format-List if ($totalFailed -eq 0) { Write-PSFMessage -Level Critical -Message "All <c='em'>$totalRun</c> tests executed without a single failure!" } else { Write-PSFMessage -Level Critical -Message "<c='em'>$totalFailed tests</c> out of <c='sub'>$totalRun</c> tests failed!" } if ($totalFailed -gt 0) { throw "$totalFailed / $totalRun tests failed!" } |