使用QUnit结合MVC3来做JavaScript单元测试

2024-08-29 23:38

本文主要是介绍使用QUnit结合MVC3来做JavaScript单元测试,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

关于QUnit

几乎所有的网站都在使用JavaScript,而所有的Javascript开发人员也都想做单元测试,但是一直都为付诸行动,大叔告诫大家,该做了,不然要被别人鄙视了,因为现在是个上网的人都应该用到了JavaScript,而且HTML5来临以后,越来越多的JavaScript代码要去开发。

本文所用到的QUnit是由jQuery team开发的,原本是用于jQuery框架的测试,后来独立发展出来,可以测试任意JavaScript代码,而且提供了非常简单的API让你非常简单的来创建你的Test Case。

先上个简单的代码:

// calculator.js
var Calculator = function(){};Calculator.prototype.add = function(x,y){return x + y;
}// calculator_test.js
module("calculator测试用例");
test("第一组测试用例", function(){var calc = new Calculator();ok(calc, "实例化创建用例通过")equals(calc.add(2,2), 4, "如果不等于4,宇宙规则将被打破了。");
});

module是声明测试用例的模块名称,每一个test提供一个名称和function callback,然后你在里面可以声明多个断言。例子里我们使用了2个最常用的断言函数ok(value, [successMessage])equals(actual, expected, [successMessage]), QUnit还提供了很多,比如:notEqualdeepEqualnotDeepEqual,strictEqualnotStrictEqual, 和raises

按照QUnit的文档,我们最终的代码应该是这种格式:

<!DOCTYPE html>
<html>
<head><title>calculator.js测试</title><link rel="stylesheet" type="text/css" href="/Content/qunit.css" /><script type="text/javascript" src="/Scripts/jquery-1.5.1.min.js"></script><script type="text/javascript" src="/Scripts/qunit.js"></script><script type="text/javascript" src="/scripts/calculator.js"></script><script type="text/javascript" src="/scripts/calculator_test.js"></script></head>
<body><h2>calculator.js测试</h2><h1 id="qunit-header">QUnit example</h1><h2 id="qunit-banner"></h2><h2 id="qunit-userAgent"></h2><ol id="qunit-tests"></ol><a href="/">Back to Tests</a>
</body>
</html>

MVC风格实现

让我们来看看结合MVC如何来做,首先声明一个TestController:

    public class TestsController : Controller{public ActionResult Index(){return View();}public ActionResult Calculator(){return View();}}

然后创建首页使用的index view,在这个view里我们不使用_layout文件,主要是用来显示每个测试用例组的连接:

    <ul>@{var controller = ViewContext.Controller.GetType();var methods = controller.GetMethods().Where(m => m.ReturnType.ToString() == "System.Web.Mvc.ActionResult");foreach (var method in methods){<li>@Html.ActionLink(@method.Name, @method.Name, "Tests")</li>}}</ul>

这样,我们可以访问该Controller下所有的测试用例(我们用每个action代表一个类型的测试),

接着在在Tests目录下,创建_ViewStart视图文件用来设置Layout,Views/Tests/_ViewStart.cshtml:

@{Layout = "_TestsLayout.cshtml";
}

 

Views/Tests/_TestsLayout.cshtml的代码如下:

<!DOCTYPE html>
<html>
<head><title>@ViewBag.Title</title><link rel="stylesheet" type="text/css" href="@(Url.Content("~/Content/qunit.css"))" /><script type="text/javascript" src="@(Url.Content("~/Scripts/jquery-1.5.1.min.js"))"></script><script type="text/javascript" src="@(Url.Content("~/Scripts/qunit.js"))"></script>@RenderSection("Javascript", false)
</head>
<body><h2>@ViewBag.Title</h2><h1 id="qunit-header">QUnit example</h1><h2 id="qunit-banner"></h2><h2 id="qunit-userAgent"></h2><ol id="qunit-tests"></ol>@Html.ActionLink("Back to Tests", "Index", "Tests")
</body>
</html>

 

然后每一个view,也就是每一个测试用例组所对应的action使用的view代码都是和如下类似,不同的只是要测试的js不同:

@{ViewBag.Title = "calculator.js测试";
}
@section Javascript{<script type="text/javascript" src="@(Url.Content("~/scripts/calculator.js"))"></script><script type="text/javascript" src="@(Url.Content("~/scripts/calculator_test.js"))"></script>
}


然后编译运行,你将得到如下结果:


然后你就可以狂加 test case了,你只需要follow下面的步骤即可:

  1. 创建JS和需要测试的JS_Tests文件
  2. 添加对应的Action方法到TestsController
  3. 为新添加的Action添加对应的View
  4. 在View的Javascriptd块里添加JS的引用

这篇关于使用QUnit结合MVC3来做JavaScript单元测试的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1119180

相关文章

SpringBoot多环境配置数据读取方式

《SpringBoot多环境配置数据读取方式》SpringBoot通过环境隔离机制,支持properties/yaml/yml多格式配置,结合@Value、Environment和@Configura... 目录一、多环境配置的核心思路二、3种配置文件格式详解2.1 properties格式(传统格式)1.

Apache Ignite 与 Spring Boot 集成详细指南

《ApacheIgnite与SpringBoot集成详细指南》ApacheIgnite官方指南详解如何通过SpringBootStarter扩展实现自动配置,支持厚/轻客户端模式,简化Ign... 目录 一、背景:为什么需要这个集成? 二、两种集成方式(对应两种客户端模型) 三、方式一:自动配置 Thick

使用Python构建智能BAT文件生成器的完美解决方案

《使用Python构建智能BAT文件生成器的完美解决方案》这篇文章主要为大家详细介绍了如何使用wxPython构建一个智能的BAT文件生成器,它不仅能够为Python脚本生成启动脚本,还提供了完整的文... 目录引言运行效果图项目背景与需求分析核心需求技术选型核心功能实现1. 数据库设计2. 界面布局设计3

使用IDEA部署Docker应用指南分享

《使用IDEA部署Docker应用指南分享》本文介绍了使用IDEA部署Docker应用的四步流程:创建Dockerfile、配置IDEADocker连接、设置运行调试环境、构建运行镜像,并强调需准备本... 目录一、创建 dockerfile 配置文件二、配置 IDEA 的 Docker 连接三、配置 Do

Spring WebClient从入门到精通

《SpringWebClient从入门到精通》本文详解SpringWebClient非阻塞响应式特性及优势,涵盖核心API、实战应用与性能优化,对比RestTemplate,为微服务通信提供高效解决... 目录一、WebClient 概述1.1 为什么选择 WebClient?1.2 WebClient 与

Android Paging 分页加载库使用实践

《AndroidPaging分页加载库使用实践》AndroidPaging库是Jetpack组件的一部分,它提供了一套完整的解决方案来处理大型数据集的分页加载,本文将深入探讨Paging库... 目录前言一、Paging 库概述二、Paging 3 核心组件1. PagingSource2. Pager3.

Java.lang.InterruptedException被中止异常的原因及解决方案

《Java.lang.InterruptedException被中止异常的原因及解决方案》Java.lang.InterruptedException是线程被中断时抛出的异常,用于协作停止执行,常见于... 目录报错问题报错原因解决方法Java.lang.InterruptedException 是 Jav

深入浅出SpringBoot WebSocket构建实时应用全面指南

《深入浅出SpringBootWebSocket构建实时应用全面指南》WebSocket是一种在单个TCP连接上进行全双工通信的协议,这篇文章主要为大家详细介绍了SpringBoot如何集成WebS... 目录前言为什么需要 WebSocketWebSocket 是什么Spring Boot 如何简化 We

java中pdf模版填充表单踩坑实战记录(itextPdf、openPdf、pdfbox)

《java中pdf模版填充表单踩坑实战记录(itextPdf、openPdf、pdfbox)》:本文主要介绍java中pdf模版填充表单踩坑的相关资料,OpenPDF、iText、PDFBox是三... 目录准备Pdf模版方法1:itextpdf7填充表单(1)加入依赖(2)代码(3)遇到的问题方法2:pd

Java Stream流之GroupBy的用法及应用场景

《JavaStream流之GroupBy的用法及应用场景》本教程将详细介绍如何在Java中使用Stream流的groupby方法,包括基本用法和一些常见的实际应用场景,感兴趣的朋友一起看看吧... 目录Java Stream流之GroupBy的用法1. 前言2. 基础概念什么是 GroupBy?Stream