[转载]JavaScript单元测试工具Qunit

[转载]JS单元测试工具Qunit – 前端组qianduanzu.com – 博客园.

随着html5的普及和客户端脚本引擎的强大,之前由后端进行的页面渲染和部分业务逻辑逐渐移至到前端,照成前端逻辑和代码迅速复杂 化。如果没有一款合适的单元测试工具保证前端单元模块的正确功能,对后期的代码调试和维护会造成很大的麻烦,今天就介绍一款单元测试框架 — Qunit

Qunit刚开始属于JQuery项目,专门用于测试JQuery单元模块。现在已经从JQuery项目中独立出来,你可以在https://github.com/jquery/qunit下载到最新版的Qunit,解压后里面有很多目录,对我们有用的其实只有qunit目录下的qunit.js和qunit.css。

 

下面来个简单的示例:
新建一个html文档,贴入以下代码:




<!-- 这里引用的是jQuery官网上的Qunit,项目中为了加快下载可以放到本地 -->
<script type="text/javascript" src="http://code.jquery.com/qunit/git/qunit.js"></script>

<h1 id="qunit-header">QUnit example</h1>

&nbsp;

&nbsp;

<h2 id="qunit-banner"></h2>

&nbsp;

<div id="qunit-testrunner-toolbar"></div>

&nbsp;

<h2 id="qunit-userAgent"></h2>

&nbsp;

&nbsp;

<div id="qunit-fixture">test markup, will be hidden</div>

<script type="text/javascript">// <![CDATA[
             test("a basic test example", function () {
                 ok(true, "this test is fine");
                 var value = "hello";
                 equal(value, "hello", "We expect value to be hello");
             });

             module("Module A");

             test("first test within module", function () {
                 ok(true, "all pass");
             });

             test("second test within module", function () {
                 ok(true, "all pass");
             });

             module("Module B");

             test("some other test", function () {
                 expect(2);
                 equal(true, false, "failing test");
                 equal(true, true, "passing test");
             });

// ]]></script>

&nbsp;

&nbsp;

用浏览器打开这个html你将会看到如下情况:

1,2,3模块通过测试,4模块出现异常,我们需求预期是false,但却返回了true,未能符合需求,那么下面不用说你也知道该如何了

Qunit的API这里就不在做细致介绍,你可以去http://docs.jquery.com/QUnit下面去找,里面有官方API,绝对详细!祝还在纠结的前端童鞋早日摆脱痛苦

文章作者:前端组-Newton

 

赞(0) 打赏
分享到: 更多 (0)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

微信扫一扫打赏