Assert-MockCalled
SYNOPSIS
Checks if a Mocked command has been called a certain number of times and throws an exception if it has not.
SYNTAX
ParameterFilter (Default)
ExclusiveFilter
DESCRIPTION
This command verifies that a mocked command has been called a certain number of times. If the call history of the mocked command does not match the parameters passed to Assert-MockCalled, Assert-MockCalled will throw an exception.
EXAMPLES
EXAMPLE 1
This will throw an exception and cause the test to fail if Set-Content is not called in Some Code.
EXAMPLE 2
This will throw an exception if some code calls Set-Content on $path=$env:temp\test.txt less than 2 times
EXAMPLE 3
This will throw an exception if some code calls Set-Content at all
EXAMPLE 4
This will throw an exception if some code does not call Set-Content Exactly two times.
EXAMPLE 5
Checks for calls only within the current It block.
EXAMPLE 6
Checks for calls to the mock within the SomeModule module. Note that both the Mock and Assert-MockCalled commands use the same module name.
EXAMPLE 7
Checks to make sure that Get-ChildItem was called at least one time with the -Path parameter set to 'C:\', and that it was not called at all with the -Path parameter set to any other value.
PARAMETERS
-CommandName
The mocked command whose call history should be checked.
-Times
The number of times that the mock must be called to avoid an exception from throwing.
-ParameterFilter
An optional filter to qualify which calls should be counted. Only those calls to the mock whose parameters cause this filter to return true will be counted.
-ExclusiveFilter
Like ParameterFilter, except when you use ExclusiveFilter, and there were any calls to the mocked command which do not match the filter, an exception will be thrown. This is a convenient way to avoid needing to have two calls to Assert-MockCalled like this:
Assert-MockCalled SomeCommand -Times 1 -ParameterFilter { $something -eq $true } Assert-MockCalled SomeCommand -Times 0 -ParameterFilter { $something -ne $true }
-ModuleName
The module where the mock being checked was injected. This is optional, and must match the ModuleName that was used when setting up the Mock.
-Scope
An optional parameter specifying the Pester scope in which to check for calls to the mocked command. For RSpec style tests, Assert-MockCalled will find all calls to the mocked command in the current Context block (if present), or the current Describe block (if there is no active Context), by default. Valid values are Describe, Context and It. If you use a scope of Describe or Context, the command will identify all calls to the mocked command in the current Describe / Context block, as well as all child scopes of that block.
For Gherkin style tests, Assert-MockCalled will find all calls to the mocked command in the current Scenario block or the current Feature block (if there is no active Scenario), by default. Valid values for Gherkin style tests are Feature and Scenario. If you use a scope of Feature or Scenario, the command will identify all calls to the mocked command in the current Feature / Scenario block, as well as all child scopes of that block.
-Exactly
If this switch is present, the number specified in Times must match exactly the number of times the mock has been called. Otherwise it must match "at least" the number of times specified. If the value passed to the Times parameter is zero, the Exactly switch is implied.
CommonParameters
This cmdlet supports the common parameters: -Debug, -ErrorAction, -ErrorVariable, -InformationAction, -InformationVariable, -OutVariable, -OutBuffer, -PipelineVariable, -Verbose, -WarningAction, and -WarningVariable. For more information, see about_CommonParameters.
INPUTS
OUTPUTS
NOTES
The parameter filter passed to Assert-MockCalled does not necessarily have to match the parameter filter (if any) which was used to create the Mock. Assert-MockCalled will find any entry in the command history which matches its parameter filter, regardless of how the Mock was created. However, if any calls to the mocked command are made which did not match any mock's parameter filter (resulting in the original command being executed instead of a mock), these calls to the original command are not tracked in the call history. In other words, Assert-MockCalled can only be used to check for calls to the mocked implementation, not to the original.
RELATED LINKS
EDIT THIS PAGE
This page was auto-generated using Pester's comment based help. To edit the content of this page, change the corresponding help in the pester/Pester repository. See our contribution guide for more information.