JsUnit && JUnit之讲解
首先我们定义我们的函数
这里以最简单的加减乘除四个方法来进行测试
建立我们的js文件myjs.js
- function add(num1,num2){
- return num1 + num2;
- }
- function minus(num1,num2){
- return num1 - num2;
- }
- function multiply(num1,num2){
- return num1 * num2;
- }
- function divide(num1,num2){
- return num1 / num2;
- }
建立我们的测试用例,mytest1.html
我们将建立四个测试方法,jsUnit的测试方法必须以test开头。
下面我们对myjs.js中的加减乘除四个函数进行测试,
下面是jsUnit给我们提供的断言方式 [comment] 是可选的 表示断言出错的时候给出的提示
assert([comment], booleanValue)
assertTrue([comment], booleanValue)
assertFalse([comment], booleanValue)
assertEquals([comment], value1, value2)
assertNotEquals([comment], value1, value2)
assertNull([comment], value)
assertNotNull([comment], value)
assertUndefined([comment], value)
assertNotUndefined([comment], value)
assertNaN([comment], value)
assertNotNaN([comment], value)
fail(comment)
- <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
- <HTML>
- <HEAD>
- <TITLE>testHtml</TITLE>
- </HEAD>
- <script type="text/javascript" src="myjs.js"></script>
- <script type="text/javascript" src="jsunit\app\jsUnitCore.js"></script>
- <script type="text/javascript">
- <!--
- function testAdd(){
- var result = add(4,2)
- assertEquals(6,result);
- }
- function testMinus(){
- var result = minus(4,2)
- assertEquals(2,result);
- }
- function testMultiply(){
- var result = multiply(4,2)
- assertEquals(8,result);
- }
- function testDivide(){
- var result = divide(4,2)
- assertEquals("4 divide 2 is 2",2,result);
- }
- //-->
- </SCRIPT>
- <BODY>
- </BODY>
- </HTML>
我们通过jsunit给我们提供的测试运行器testRunner.html来进行测试
2 setUp()与tearDown()
JsUnit也支持setUp()和tearDown()。JsUnit与JUnit有一点是一样的,即setUp()和tearDown()是可选的,而且setUp()会在每个测试之前调用,tearDown()会在每个测试之后调用。
我们可以在测试页面中加入setUp()和tearDown()的方法。
- function setUp(){
- alert("setUp");
- }
- function tearDown(){
- alert("tearDown");
- }
JUnit与JsUnit中setUp()和tearDown()方法的重要区别:
在JUnit中,每次测试运行会导致创建Test类的一个新实例,这说明,声明的所有实例变量在下一次测试运行时会“重置”。
JsUnit有所不同,它不会为每次测试运行重新加载测试页,所以变量状态会在多次测试之间保留。
还有一个重要区别与测试顺序有关,使用JUnit的话,测试执行的顺序是不能保证的。在JsUnit中,测试会按测试页中声明的顺序执行,先从最上面的测试开始。
虽然区别如此,但我们应该了解每个测试用例都是应该相互独立的,不能真的顺序来调整我们的用例
下面是一个具体例子。
这里我们将函数和测试用例都写在一起了,在实际测试中应该避免
- <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
- <HTML>
- <HEAD>
- <TITLE></TITLE>
- <script type="text/javascript" src="jsunit\app\jsUnitCore.js"></script>
- </HEAD>
- <BODY>
- <script language="JavaScript">
- //原函数
- function addTwoNumbers(value1, value2) {
- return parseInt(value1) + parseInt(value2);
- }
- function addNumbers() {
- var val1 = document.getElementById("value1").value;
- var val2 = document.getElementById("value2").value;
- return addTwoNumbers(val1, val2);
- }
- //初始化测试数据
- function setUp() {
- document.getElementById("value1").value = "2";
- document.getElementById("value2").value = "2";
- }
- //测试方法
- function testValidArgs() {
- assertEquals("2 + 2 should equal 4", 4, addNumbers());
- }
- //清空测试数据
- function tearDown() {
- document.getElementById("value1").value = "";
- document.getElementById("value2").value = "";
- }
- </script>
- <form id="test">
- <input type="text" size="3" id="value1"/>
- <input type="text" size="3" id="value2"/>
- <input type="button" value="Add" onclick="addNumbers()"/>
- </form>
- </body>
- </html>
- </BODY>
- </HTML>
3 setUpPage()函数
setUpPage()函数只对每个测试页调用一次,即在所有测试函数调用之前调用。现在,你可能已经发现,这里很适合完成预处理,特别是在运行
测试之前如果需要向页面加载一些数据,setUpPage()函数就非常有用。不同于setUp()和tearDown()函数的是,使用
setUpPage()不只是把处理放在这个函数中就行了的。如果确实选择使用这个特性,一定要保证函数完成时要把setUpPageStatus变量设
置为complete,这就告诉JsUnit可以继续,接下来可以执行测试页上的测试了。
我们更改第一个实例来看看结果
- <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
- <HTML>
- <HEAD>
- <TITLE>testHtml</TITLE>
- </HEAD>
- <script type="text/javascript" src="myjs.js"></script>
- <script type="text/javascript" src="jsunit\app\jsUnitCore.js"></script>
- <script type="text/javascript">
- <!--
- function testAdd(){
- var result = add(arg1,arg2)
- assertEquals(6,result);
- }
- function testMinus(){
- var result = minus(arg1,arg2)
- assertEquals(2,result);
- }
- function testMultiply(){
- var result = multiply(arg1,arg2)
- assertEquals(8,result);
- }
- function testDivide(){
- var result = divide(arg1,arg2)
- assertEquals("4 divide 2 is 2",2,result);
- }
- function setUpPage(){
- arg1 = 4;
- arg2 = 2;
- setUpPageStatus = "complete";
- }
- //-->
- </SCRIPT>
- <BODY>
- </BODY>
- </HTML>
4 exposeTestFunctionNames()函数显示的声明我们的测试方法
JsUnit会自动发现测试函数,就像JUnit会发现所有测试方法一样。
有些操作系统/浏览器不能合作。如果你发现不能如你所愿地发现测试函数,使用exposeTestFunctionNames()方法就能解决这个问题。
在测试页面里定义exposeTestFunctionNames方法,jsunit运行器在执行时会寻找exposeTestFunctionNames方法,只执行在此方法内指定的方法;
我们还是已第一个例子为例
可以变为
- <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
- <HTML>
- <HEAD>
- <TITLE>testHtml</TITLE>
- </HEAD>
- <script type="text/javascript" src="myjs.js"></script>
- <script type="text/javascript" src="jsunit\app\jsUnitCore.js"></script>
- <script type="text/javascript">
- <!--
- function testAdd(){
- var result = add(arg1,arg2)
- assertEquals(6,result);
- }
- function testMinus(){
- var result = minus(arg1,arg2)
- assertEquals(2,result);
- }
- function testMultiply(){
- var result = multiply(arg1,arg2)
- assertEquals(8,result);
- }
- function testDivide(){
- var result = divide(arg1,arg2)
- assertEquals("4 divide 2 is 2",2,result);
- }
- function setUpPage(){
- arg1 = 4;
- arg2 = 2;
- setUpPageStatus = "complete";
- }
- function exposeTestFunctionNames(){
- var tests = new Array();
- tests[0]="testAdd";
- tests[1]="testMinus";
- tests[2]="testMultiply";
- return tests;
- }
- //-->
- </SCRIPT>
- <BODY>
- </BODY>
- </HTML>
5 jsUnit的日志跟踪
jsUuit的日志跟踪有3各级别:warn、info和debug
看下面的例子就知道了
- <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
- <HTML>
- <HEAD>
- <TITLE>testHtml</TITLE>
- </HEAD>
- <script type="text/javascript" src="myjs.js"></script>
- <script type="text/javascript" src="jsunit\app\jsUnitCore.js"></script>
- <script type="text/javascript">
- <!--
- function testAdd(){
- var result = add(arg1,arg2);
- warn("result", result);
- debug("result", result);
- info("result", result);
- assertEquals(6,result);
- }
- function testMinus(){
- var result = minus(arg1,arg2)
- assertEquals(2,result);
- }
- function testMultiply(){
- var result = multiply(arg1,arg2)
- assertEquals(8,result);
- }
- function testDivide(){
- var result = divide(arg1,arg2)
- assertEquals("4 divide 2 is 2",2,result);
- }
- function setUpPage(){
- arg1 = 4;
- arg2 = 2;
- setUpPageStatus = "complete";
- }
- function exposeTestFunctionNames(){
- var tests = new Array();
- tests[0]="testAdd";
- tests[1]="testMinus";
- tests[2]="testMultiply";
- return tests;
- }
- //-->
- </SCRIPT>
- <BODY>
- </BODY>
- </HTML>
在测试运行器中选择Trace level的级别就可以看到相应的日志信息了
6 测试套件(suit test)
测试集是为了把不同的测试页分组组织,其中可以包含测试页或其他测试集,他们会按照顺序执行。
注意点:
测试集中不能包含任何测试函数
必须包含一个返回 jsUnitTestSuite 对象的 suite 函数
有两个方法添加测试页:addTestPage(testPage) addTestSuite(testSuite), 在添加测试页时要注意路径,应是相对于testRunner.html的。
测试集的名称必须是suit()
- <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
- <HTML>
- <HEAD>
- <TITLE>suit test</TITLE>
- </HEAD>
- <script type="text/javascript" src="jsunit\app\jsUnitCore.js"></script>
- <script type="text/javascript">
- <!--
- function suite()
- {
- var testSuite = new top.jsUnitTestSuite();
- //增加的测试页面的路径是相对于测试运行器的路径的(testRunner.html),而不是相对于当前的页面
- testSuite.addTestPage("../mytest1.html");
- //套件里还可以在包含套件
- testSuite.addTestSuite(Suite2());
- return testSuite;
- }
- function Suite2() //需要与suite定义在同一个页面中
- {
- var testSuite = new top.jsUnitTestSuite();
- testSuite.addTestPage("../mytest2.html");
- return testSuite;
- }
- //-->
- </SCRIPT>
- <BODY>
- </BODY>
- </HTML>
7 通过浏览器完成自动测试
file:///D:/mytest/jsunit/testRunner.html?testPage=D:/mytest/mytest1.html&autoRun=true
个人感觉没有实际意义
8 采用ant方式完成自动测试
首先进入jsunit目录,build.xml是junit定义好的模板,我们只需要简单的添加就可以了。
配置property属性
browserFileNames:浏览器地址;多个可以用逗号隔开;
closeBrowsersAfterTestRuns:执行测试后,是否关闭浏览器;默认true
logsDirectory:日志存放目录
url:测试文件地址;如:
file:///c:/jsunit/testRunner.html?testPage=c:/jsunit/tests/jsUnitTestSuite.html
在控制台下进入相关目录运行ant standalone_test 即可。
standalone_test是在单机上行运行测试;
distributed_test:是分布式远程测试;
ant不能执行或者执行出错:
查看环境变量
path下是否有java与ant的bin
是否设置Java_Home
JsUnit && JUnit之讲解的更多相关文章
- 走进JavaWeb技术世界11:单元测试框架Junit
JUnit你不知道的那些事儿 转自 老刘 码农翻身 2016-02-24 话说有一次Eric Gamma 坐飞机的时候偶遇Kent Beck(对,就是极限编程和TDD的发起人) , 两位大牛见面寒暄 ...
- 「译」JUnit 5 系列:条件测试
原文地址:http://blog.codefx.org/libraries/junit-5-conditions/ 原文日期:08, May, 2016 译文首发:Linesh 的博客:「译」JUni ...
- 「译」JUnit 5 系列:环境搭建
原文地址:http://blog.codefx.org/libraries/junit-5-setup/ 原文日期:15, Feb, 2016 译文首发:Linesh 的博客:环境搭建 我的 Gith ...
- 「译」JUnit 5 系列:扩展模型(Extension Model)
原文地址:http://blog.codefx.org/design/architecture/junit-5-extension-model/ 原文日期:11, Apr, 2016 译文首发:Lin ...
- JavaScript单元测试框架JsUnit基本介绍和使用
JavaScript单元测试框架JsUnit基本介绍和使用 XUnit framework XUnit是一套标准化的独立于语言的概念和结构集合,用于编写和运行单元测试(Unit tests). 每一个 ...
- IntelliJ IDEA 教程设置讲解
IntelliJ IDEA 常用设置讲解 说明 IntelliJ在业界被公认为最好的java开发工具之一,尤其在智能代码助手.代码自动提示.重构.J2EE支持.Ant.JUnit.CVS整合.代码审查 ...
- 安卓下如何使用JUnit进行软件测试
软件测试作为程序员必备的一项技能是决定软件开发周期长短以及软件运行成败的关键,可以说好的软件不是代码写得好而是有效的测试决定的.本文将介绍在android下利用eclipse进行开发时如何使用JUni ...
- Maven聚合与继承的实例讲解(一)
概述 在javaweb高速发展的今天,我们软件设计人员往往会用很多种方式对软件划分模块,目的就是为了能有清晰的设计和低耦合性的,高重用性的软件.Maven有很好的依赖管理系统(Dependency M ...
- Java知识积累——单元测试和JUnit(一)
说起单元测试,刚毕业或者没毕业的人可能大多停留在课本讲述的定义阶段,至于具体是怎么定义的,估计也不会有太多人记得.我们的教育总是这样让人“欣 慰”.那么什么是单元测试呢?具体科学的定义咱就不去关心了, ...
随机推荐
- 【转】代码编辑器(一)-TSynCompletionProposal用法
注意,本系列均转载自http://blog.163.com/zom1995@126/ 网上有人给我一个SynEdit这个东西,因为我很喜欢自己编个代码编辑器,但要是用Delphi直接弄的,就我现在这样 ...
- IEnumerable 接口 实现foreach 遍历 实例
额 为啥写着东西? 有次面试去,因为用到的时候特别少 所以没记住, 这个单词 怎么写! 经典的面试题: 能用foreach遍历访问的对象的要求? 答: 该类实现IEnumetable 接口 声明 ...
- Server Tomcat v7.0 Server at localhost failed to start解决办法
今晚搞了下tomcat,在调试的时候发现报了这样一个错误Server Tomcat v7.0 Server at localhost failed to start 首先,确认了端口号8080是不是被 ...
- Requests:Python HTTP Module学习笔记(一)(转)
Requests:Python HTTP Module学习笔记(一) 在学习用python写爬虫的时候用到了Requests这个Http网络库,这个库简单好用并且功能强大,完全可以代替python的标 ...
- (1)c语言学习总结之从关键字到循环结构
一.关键字和标示符 1.关键字:c规定的有特殊含义的单词(也就是系统起的名字),全部是小写,有32个; 由关键字引出数据类型和流程类型 1.分类: (1)数据类型:整型用int标示,字符型用char表 ...
- Android 虚拟机 Davlik
Dalvik虚拟机是Google的用于移动设备的Android平台的一个主要部分.虚拟机可运行Java平台应用程序,这些应用程序被转换成紧凑的Dalvik可执行格式(.dex),该格式适合内存和处理器 ...
- windows 服务 安装 删除 启动 停止
一.停止 sc stop 服务名 二.删除 sc delete 服务名 注意:有时删除不了,报什么“服务为删除标识” ,请将服务窗口关掉就好了. 三.创建 sc create XmlcSendServ ...
- Git 设置别名[alias]
工作中我经常设置一下别名... 别名就在[alias]后面,要删除别名,直接把对应的行删掉即可. 而当前用户的Git配置文件放在用户主目录下的一个隐藏文件.gitconfig中: $ cat .git ...
- jdk 1.6 & 1.7新特性
jdk1.6新特性 1.Desktop类和SystemTray类 2.使用JAXB2来实现对象与XML之间的映射 3.StAX 4.使用Compiler API 5.轻量级Http Server AP ...
- linux php安装zookeeper扩展
linux php安装zookeeper扩展 tags:php zookeeper linux ext 前言: zookeeper提供很犀利的命名服务,并且集群操作具有原子性,所以在我的多个项目中被采 ...