Behavior Verification (Method Was/Not Called, a Specific Number of Times, Getter/Setter Was Called)
Callbacks, void calls and When..Do
Sometimes it is useful to execute some arbitrary code whenever a particular call is made. We have already seen an example of this when passing functions to Returns()
.
The Return from a function topic has more information on the arguments passed to the callback.
Callbacks for void
calls
void
callsReturns()
can be used to get callbacks for members that return a value, but for void
members we need a different technique, because we can’t call a method on a void
return. For these cases we can use the When..Do
syntax.
When called, do this
When..Do
uses two calls to configure our callback. First, When()
is called on the substitute and passed a function. The argument to the function is the substitute itself, and we can call the member we are interested in here, even if it returns void
. We then call Do()
and pass in our callback that will be executed when the substitute’s member is called.
The argument passed to the Do()
method is the same call information passed to the Returns()
callback, which gives us access to the arguments used for the call.
Note that we can also use When..Do
syntax for non-void members, but generally the Returns()
syntax is preferred for brevity and clarity. You may still find it useful for non-voids when you want to execute a function without changing a previous return value.
Per argument callbacks
In cases where we only need callbacks for a particular argument we may be able to use per argument callbacks like Arg.Do()
and Arg.Invoke()
instead of When..Do
.
Argument callbacks give us slightly more concise code in a style that is more in keeping with the rest of the NSubstitute API. See Actions with arguments for more information and examples.
Callback builder for more complex callbacks
The Callback
builder lets us create more complex Do()
scenarios. We can use Callback.First()
followed by Then()
, ThenThrow()
and ThenKeepDoing()
to build chains of callbacks. We can also use Always()
and AlwaysThrow()
to specify callbacks called every time. Note that a callback set by an Always()
method will be called even if other callbacks will throw an exception.
Last updated