对简单视图进行太多测试?

时间:2012-04-17 07:18:13

标签: c# asp.net-mvc testing integration-testing

您好我正在整理我的网站,虽然很简单但我决定尽可能多地测试它。使用只编写有用测试的精神,可以解释我可以想象的情况(重命名脚本或css文件等)

我正在使用Steve Sanderson的MVC集成测试框架,我的测试如下。

我的问题有两个,这个级别的测试“太多”,如果没有,你能想到的其他场景(开发人员相关,如重命名或其他任何事情)。

using System.Web;
using System.Web.Mvc;
using MvcIntegrationTestFramework.Hosting;
using NUnit.Framework;
using website.Properties;

namespace website.tests
{
    [TestFixture]
    public class HomeControllerIndexTests
    {
        [TestFixtureSetUp]
        public void Setup()
        {
            appHost = AppHost.Simulate("Website");
        }

        [Test]
        public void HomeControllerIndexReturnsTheIndexView()
        {
            appHost.Start(session =>
            {
                var result = session.Get("/Home/Index");
                Assert.AreEqual("Index", ((ViewResult)result.ActionExecutedContext.Result).ViewName);
            });
        }

        [Test]
        public void HomeControllerIndexReturnsCorrectRouteData()
        {
            appHost.Start(session =>
            {
                var result = session.Get("/Home/Index");
                Assert.AreEqual("Home", result.ActionExecutedContext.RouteData.Values["controller"]);
            });
        }

        [Test]
        public void HomeControllerIndexReturnsViewResult()
        {
            appHost.Start(session =>
            {
                var result = session.Get("/Home/Index");
                Assert.IsInstanceOf(typeof(ViewResult), result.ActionExecutedContext.Result);
            });
        }

        [Test]
        public void HomeControllerIndexReturnsNoError()
        {
            appHost.Start(session =>
            {
                var result = session.Get("/Home/Index");
                Assert.IsNull(result.ResultExecutedContext.Exception);
            });
        }

        [Test]
        public void HomeControllerIndexReturnsViewWithSiteCssFile()
        {
            appHost.Start(session =>
            {
                var result = session.Get("/Home/Index");
                Assert.IsTrue(result.ResponseText.Contains("/Content/Site.css"));
            });
        }

        [Test]
        public void HomeControllerIndexReturnsViewWithCorrectTitle()
        {
            appHost.Start(session =>
            {
                var result = session.Get("/Home/Index");
                Assert.IsTrue(result.ResponseText.ToLowerInvariant().Contains("<title>{ me: danielelliott.info(); }</title>"));
            });
        }

        [Test]
        public void HomeControllerIndexReturnsViewContainingBanner()
        {
            appHost.Start(session =>
            {
                var result = session.Get("/Home/Index");
                var expected = HttpUtility.HtmlEncode(Resources.SiteName);
                Assert.IsTrue(result.ResponseText.Contains(expected));
            });
        }

        [Test]
        public void HomeControllerIndexViewIncludesBioParagraph()
        {
            appHost.Start(session =>
            {
                var result = session.Get("/Home/Index");
                var expected = HttpUtility.HtmlEncode(Resources.Bio.ToLowerInvariant());
                Assert.IsTrue(result.ResponseText.ToLowerInvariant().Contains(expected));
            });
        }

        [Test]
        public void HomeControllerIndexViewIncludesServicesParagraph()
        {
            appHost.Start(session =>
            {
                var result = session.Get("/Home/Index");
                var expected = HttpUtility.HtmlEncode(Resources.Services.ToLowerInvariant());
                Assert.IsTrue(result.ResponseText.ToLowerInvariant().Contains(expected));
            });
        }

        [Test]
        public void HomeControllerIndexViewIncludesHistoryParagraph()
        {
            appHost.Start(session =>
            {
                var result = session.Get("/Home/Index");
                var expected = HttpUtility.HtmlEncode(Resources.History.ToLowerInvariant());
                Assert.IsTrue(result.ResponseText.ToLowerInvariant().Contains(expected));
            });
        }

        private AppHost appHost;
    }
}

2 个答案:

答案 0 :(得分:1)

测试始终取决于上下文,您看到的风险应该指导测试的数量。

  • 如果某些部分在某些变化后无效,会有多重要?
  • 你认为当某些事情发生变化时这些部分会破裂吗?
  • 如果页面结构发生变化,维护这些测试的任务有多大?
  • 您认为这些部件会经常变化吗?它能自动化吗?
  • 当金额增长时,运行测试需要多长时间?您是否准备好经常等待最新的变化没有破坏任何东西?

如果页面不经常更改,这个数量似乎非常多。您还可以考虑是否仅仅测试一些事物就足够了。例如,您似乎在页面中包含多个部分。如果它们来自相同的位置并且包含在相同的机制中,那么如果其他人在那里,那么包括一个人就不会失败。

另一方面,减少金额总是更容易。您可以在学习时从这开始,然后看看是否需要稍后更改方法。

答案 1 :(得分:1)

当我看到您的测试时,我的反应是他们主要验证实施细节。我建议你专注于行为。测试最终用户与站点的交互。验证信息是否存在,而不是如何呈现。