I’m working with a ASP.NET MVC solution in a test driven manner and I want to login a user to my application using forms authentication. The code I would like to end up with in the controller looks something like this:
FormsAuthentication.SetAuthCookie(userName, false);
My question is how do I write a test to justify this code?
Is there a way to check that the SetAuthCookie method was called with the correct parameters?
Is there any way of injecting a fake/mock FormsAuthentication?
I would start by writing an interface and a wrapper class that will encapsulate this logic and then use the interface in my controller:
Now
IAuthcould be easily mocked in a unit test and verify that the controller calls the expected methods on it. I would NOT unit test theFormsAuthWrapperclass because it just delegates the call to theFormsAuthenticationwhich does what it is supposed to do (Microsoft guarantee :-)).