2010-12-02 10 views
6

Ich habe gerade angefangen zu lernen und usingASP.NET MVC 2 und auch immer mehr in Unit-Test mein Code beteiligt. Meine Frage ist weitgehend, wie man ein Benutzer-Login simuliert, indem ich die Zugangsdaten innerhalb meines Tests übergebe.Wie fälsche ich einen Benutzer anmelden für Unit-Testzwecke mit fakeiteinasy innerhalb von asp.net mvc 2

Ich benutze MSpec und versuche, meinen Kopf um fakeiteasy zu bekommen, um meinen Test zu schreiben. Bisher glaube ich, dass ich einen Test korrekt geschrieben habe (Er besteht die Testbedingung), wenn ein nicht authentifizierter Benutzer versucht, auf eine Seite zuzugreifen.

Subject(typeof(HomeController))] 
public class context_for_a_home_controller_for_not_logged_user 
{ 
    protected static HomeController HomeController; 

    Establish context =() => 
    { 
     // Create controller 
     HomeController = new HomeController(); 

     HomeController.ControllerContext = A.Fake<ControllerContext>(); 
    }; 
} 

[Subject(typeof(HomeController))] 
public class when_the_home_page_is_requested : context_for_a_home_controller_for_not_logged_user 
{ 
    static ActionResult result; 

    Because of =() => 
     result = HomeController.Index(); 

    It should_return_the_log_in_page_if_user_not_logged_in =() => 
     { result.ShouldBeAView().And().ShouldUseDefaultView(); }; 
} 

So weit so gut. Ich möchte jedoch auf das Szenario testen, in dem ein authentifizierter Benutzer den Home Controller trifft. Ich bin fest, wie man einen authentifizierten Benutzer simuliert und jede Hilfe oder Beratung wäre willkommen.

TIA,

David

Antwort

3

Nachdem mit Patrik Hagne, der Schöpfer von FakeItEasy in Verbindung zu setzen, kam er mit dem Follow-up:

[Subject(typeof(HomeController))] 
public class context_for_a_home_controller_for_logged_user 
{ 
    protected static HomeController HomeController; 

    Establish context =() => 
    { 
     // Create controller 
     HomeController = new HomeController(); 

     HomeController.ControllerContext = A.Fake<ControllerContext>(); 
     var fakePrincipal = A.Fake<IPrincipal>(); 
     var fakeIdentity = new GenericIdentity("username"); 
     A.CallTo(() => fakePrincipal.Identity).Returns(fakeIdentity); 
     A.CallTo(() => HomeController.ControllerContext.HttpContext.User).Returns(fakePrincipal); 
    }; 
} 

, die den Trick tat! Danke Patrik!

2

Hier ist, wie tou konnte Fälschung der Identität:

Subject(typeof(HomeController))] 
public class context_for_a_home_controller_for_a_logged_user 
{ 
    protected static HomeController HomeController; 

    Establish context =() => 
    { 
     // Create controller 
     HomeController = new HomeController(); 

     var fakeControllerContext = A.Fake<ControllerContext>(); 
     var fakeHttpContext = A.Fake<HttpContextBase>(); 
     var fakePrincipal = A.Fake<IPrincipal>(); 
     var fakeIdentity = new GenericIdentity("someusername"); 

     HomeController.ControllerContext = fakeControllerContext; 
     A.CallTo(() => fakeControllerContext.HttpContext).Returns(fakeHttpContext); 
     A.CallTo(() => fakeHttpContext.User).Returns(fakePrincipal);   
     A.CallTo(() => fakePrincipal.Identity).Returns(fakeIdentity); 
    }; 
} 

Wenn Sie jetzt HomeController.User Eigenschaft verwenden, um es den falschen Hauptpunkt wird die zur Verfügung gestellt wurde.

+0

Hallo Danke, danke für das Posten dieser Antwort. Leider die Zeile A.CallTo (() => HomeController.User) .Returns (fakePrincipal); verursacht Fehler, weil HomeController das zu testende Objekt ist und kein falsches Objekt ist. Hättest du weitere Vorschläge, um den Code zu erhalten? – DavidS

+0

Ja, Sie haben Recht. Ich habe meinen Code aktualisiert. –

+0

Das funktioniert auch! – DavidS