我对我的标准做一些简单的MS单元测试,没有什么特别的控制器。
当我检查ViewName proprty,从返回的ViewResult对象,它的“”(空)。
我的印象是ViewName是由视图的名称暗示的(作为ASP.NET MVC控制器测试的suggested by this MS article)。
BTW,当我测试的ViewData,它的所有和正确的。
这里是我有的代码…
public ActionResult Index(int? page,string tag) { if (page == null || page <= 0) { page = 1; } var viewData = new IndexViewData { ... my property setters,etc ... }; return View(viewData); } [TestMethod] public void Index_Action_Should_Return_Index_View_For_Default_HomePage() { // Arrange. var controller = PostController; // Wrapper,cause I use D.I. // Act. ViewResult viewResult = controller.Index(null,null) as ViewResult; // Assert. Assert.IsNotNull(viewResult); Assert.AreEqual("Index",viewResult.ViewName); // This is false/fails. var indexViewData = viewResult.ViewData.Model as IndexViewData; Assert.IsNotNull(indexViewData); // This is true. }
解决方法
ViewName仅在您在ViewResult中设置时才存在。如果您的View名称与您的控制器名称匹配,那么我将检查以确保ViewName为空或为空,因为这将是(IMO)正确的行为,因为您不想在视图上设置名称。我只检查ViewName是否设置,当我打算返回的视图不匹配的操作 – 例如,当返回“错误”视图,例如。
编辑:以下是ViewResultBase.cs(从RC1,我没有在我的Macintosh RTW的源)的ExecuteResult的源。正如你可以看到,它检查ViewName是否已被直接设置,如果没有,它从控制器上下文的路由数据中的操作中拉出。这只发生在ExecuteResult,它在控制器的操作完成后被调用。
public override void ExecuteResult(ControllerContext context) { if (context == null) { throw new ArgumentNullException("context"); } if (String.IsNullOrEmpty(ViewName)) { ViewName = context.RouteData.GetrequiredString("action"); } ViewEngineResult result = null; if (View == null) { result = FindView(context); View = result.View; } ViewContext viewContext = new ViewContext(context,View,ViewData,TempData); View.Render(viewContext,context.HttpContext.Response.Output); if (result != null) { result.ViewEngine.ReleaseView(context,View); } }