代码之家  ›  专栏  ›  技术社区  ›  Erik van Brakel scottrakes

确保视图存在

  •  7
  • Erik van Brakel scottrakes  · 技术社区  · 16 年前

    我目前正在为我必须创建的新应用程序进行单元测试。我的基本测试进行得很顺利(测试ActionResult类非常好)。不过,我确实想确保的一件事是,我的解决方案中存在一个viewpage。我不是100%确定我的测试是正确的,所以如果有人有建议,请不要犹豫!

    [TestMethod]
    public void Login()
    {
        var authProvider = new Mock<IAuthenticationProvider>();
        var controller = new SecurityController(authProvider.Object);
    
        var result = controller.Login() as ViewResult;
    
        Assert.IsNotNull(result, "ActionResult should be of type ViewResult.");
        Assert.AreEqual(result.ViewName, "login", "Does not render login page.");
    }
    

    我对测试的解释是:

    • 在控制器上调用“Login”方法
    • 确认它正在渲染正确的视图(通过检查viewname)

    我想要的是第三个断言,看看要呈现的视图是否确实存在。

    我的一些次要问题是:

    • 我应该把这次考试分开吗?
    • 我应该重命名它吗(比如,呃,LoginUnderscorRectView或其他什么)

    谢谢


    注意:我明确地试图避免检查文件系统。我有点希望找到一种使用ViewEngine确认视图实际存在的方法。

    5 回复  |  直到 16 年前
        1
  •  9
  •   Jason Livesay    16 年前
    • 不,我认为你不应该把测试分割开来,只要它主要是第三个断言,而不是更多的代码。

    • 既然您已经验证了它具有正确的视图名称,那么简单地成功地呈现视图不就是验证它的存在吗?

        2
  •  5
  •   Craig Stuntz    16 年前

    知道该视图存在于解决方案中并不十分有用。您真正关心的是视图将被部署,因为您的用户(我希望)不会在VisualStudio中运行您的站点。换句话说,您要求的不是单元测试,而是集成测试。因此,您应该为该作业使用适当的工具。考虑一个Web测试框架 Selenium

        3
  •  4
  •   jwheron    11 年前

    我完全同意Jason的观点,但我不认为您所做的实际上有助于提高测试覆盖率。毕竟,呈现它和测试行为已经涵盖了它是否存在。

    许多开发人员在第一次被测试驱动的开发错误所困扰时就已经过火了。他们希望测试失败能够准确地告诉他们出了什么问题,这样他们就不必深入研究和调试。这不是测试的主要目的;测试是为了验证正确的行为,这样您就不会发布坏的软件。当出现问题时,您可以进行调试。没有必要让测试线束如此具体,以至于测试引擎能够准确地知道问题所在。

        4
  •  1
  •   Florin Sabau    16 年前

    您可以尝试使用ViewResult中的ViewEngineCollection对象的FindView方法来检查MVC框架是否可以找到该视图。

    正如其他人所建议的那样,我认为第三个断言(视图实际存在)不会为您的测试增加真正的价值,但是,下面是检查存在性的代码:

    var viewEngineResult = result.ViewEngineCollection.FindView(controller, result.ViewName, result.MasterName);
    if (viewEngineResult == null)
        ... not found ...
    

        5
  •  0
  •   ajma    16 年前

    如果您使用的是beta版,您的代码隐藏文件将为视图创建一个类,您可以检查该类是否使用反射。

    否则,您可以检查文件是否存在于正确的位置。