Skip to main content
Version: v6 (preview) 🚧

Skip

Skip on everything​

-Skip is now available on Describe and Context. This allows you to skip all the tests in that block and every child block.

Describe "describe1" {
Context "with one skipped test" {
It "test 1" -Skip {
1 | Should -Be 2
}

It "test 2" {
1 | Should -Be 1
}
}

Describe "that is skipped" -Skip {
It "test 3" {
1 | Should -Be 2
}
}

Context "that is skipped and has skipped test" -Skip {
It "test 3" -Skip {
1 | Should -Be 2
}

It "test 3" {
1 | Should -Be 2
}
}
}
Starting test discovery in 1 files.
Found 5 tests. 117ms
Test discovery finished. 418ms
Describing describe1
Context with one skipped test
[!] test 1, is skipped 18ms (0ms|18ms)
[+] test 2 52ms (29ms|22ms)
Describing that is skipped
[!] test 3, is skipped 12ms (0ms|12ms)
Context that is skipped and has skipped test
[!] test 3, is skipped 10ms (0ms|10ms)
[!] test 3, is skipped 10ms (0ms|10ms)
Tests completed in 1.03s
Tests Passed: 1, Failed: 0, Skipped: 4, Total: 5, NotRun: 0

Conditional skip​

Evaluation of the skip-parameter is done as part of the Discovery-phase. This means you can also dynamically skip tests based on values available in that phase. Either as logic done in BeforeDiscovery or based on values passed into a parametrized test.

$sb = {
param($SkipFirst)

Describe 'My Describe Block' {
BeforeDiscovery {
$skipSecond = 1
}

It 'First Test' -Skip:$SkipFirst {
1 | Should -Be 1
}

It 'Second Test' -Skip:($skipSecond -eq 1) {
1 | Should -Be 1
}

It 'Third Test' {
1 | Should -Be 1
}
}
}

$container = New-PesterContainer -ScriptBlock $sb -Data @{ SkipFirst = $true }
$configuration = New-PesterConfiguration
$configuration.Run.Container = $container
$configuration.Output.Verbosity = 'Detailed'

Invoke-Pester -Configuration $configuration
Starting discovery in 1 files.
Discovering in
param($SkipFirst)

Describe 'My Describe Block' {
BeforeDiscovery {
$skipSecond = 1
}

It 'First Test' -Skip:$SkipFirst {
1 | Should -Be 1
}

It 'Second Test' -Skip:($skipSecond -eq 1) {
1 | Should -Be 1
}

It 'Third Test' {
1 | Should -Be 1
}
}
.
Found 3 tests. 37ms
Discovery finished in 97ms.
Running tests.
Describing My Describe Block
[!] First Test 3ms (0ms|3ms)
[!] Second Test 2ms (0ms|2ms)
[+] Third Test 18ms (16ms|3ms)
Tests completed in 206ms
Tests Passed: 1, Failed: 0, Skipped: 2 NotRun: 0
Skipping during Run-phase

In certain scenarios you might need to mark a test as skipped or inconclusive during execution. This is possible using Set-ItResult. Be aware that setup and teardown-blocks will be executed, so use -Skip whenever possible.