I have various methods that I would like to unit test using Visual Studio’s built in unit testing capability for C#. Things have been going pretty smoothly, but I’ve run into a scenario where I want to “stub out” a dependency on a particular function call.
Namely, I have some methods that are in the following format:
public class ClassWithMethodsIWantToUnitTest
{
public void myFcn(object someArg)
{
...
LoggerService.Instance.LogMessage("myMessage");
...
}
}
So basically, I want my unit test to simply verify that the call to “LogMessage” has occurred. I don’t want to actually check a log file or anything. I want a way to see if the LoggerService line has been hit and executed.
LoggerService is a singleton, and if possible, I don’t want to modify the code just for unit testing.
Based on the format of this problem, it seems to me that it should be possible to somehow take control of the code in my unit test. In other words, is there a way for me to make a fake version of LogMessage such that I can use it for my unit test? I don’t want the “real” LogMessage function to be called if possible. I just want to test that the code hit the path that called the function.
Does this make any sense? Is this possible?
Anders’ answer was definitely the “canonical” way of approaching the problem, but in .NET 4.5, there’s a second option:
The Fakes framework.
It lets you add a “fakes” assembly to your unit test project that accepts a delegate to perform in place of the actual implementation of a method. Here’s an example using
File.ReadAllTextWhat that test method is doing is temporarily (within the scope of the
ShimsContext) replacing the implementation ofFile.ReadAllTextwith the lambda I provided. In this case, any timeReadAllTextis called, it returns the string “test 123”.It’s slower than regular DI, but if you’re absolutely tied to a specific implementation of a singleton, it could be exactly what you need. Read more about it here.