3 回答
TA贡献2065条经验 获得超14个赞
一般的测试,尤其是逻辑处理代码的测试,JUnit就足够了。但是一些特殊的测试,譬如需要连接数据库, 使用浏览器,这些测试单单使用JUnit还不能够很好地完成任务,于是会偷懒的牛人又发明了DbUnit、HTTPUnit这些测试框架,使得重复劳动大大减少。
但是对于界面测试,到现在为止还没有一个框架能够使得界面测试完全地自动化起来。
根据马克思主义哲学原理,这是由事物的内因来决定的。由于界面的复杂性以及界面元素的不确定性,界面的测试只有在它实实在在地呈现在测试人员的眼里时,测试才能得出结果,接着测试才能继续下去。即使现在已经有了不少界面测试的框架,但是这些所谓的框架还是不能够称之为框架,只能称之为工具,因为使用这些工具仍然得做很多重复的工作,而且能够自动化测试的程度有限。
下文介绍的是进行界面测试的一种技术,或者说是一种方法,也或者说是一种思想。虽然我在前言部分声明不谈方法和思想,只谈技术,但在这里还是得谈一下方法和思想,实际上,在界面测试中,技术、思想、方法的概念是挺模糊的。相信不久的将来,当出现一个很牛的框架来进行界面测试时,这几个概念就会越来越清晰。
先来把被测界面代码写出来:
1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071 | /************************************************************ * 项目名称:lhjTest * 文件名称:CoolUiClass.java * 文件描述:CoolUiClass.java * 作者:Administrator * 创建日期:2007-3-24 * 修改记录: ***********************************************************/ package org.lhj.cool.uiunit; import java.awt.Dimension; import java.awt.GridBagConstraints; import java.awt.GridBagLayout; import java.awt.Insets; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; import javax.swing.JButton; import javax.swing.JFrame; import javax.swing.JPanel; import javax.swing.JScrollPane; import javax.swing.JTextArea; /** * @author Administrator */ public class CoolUiClass extends JPanel { private JTextArea msgTxt = new JTextArea( 400 , 320 ); private JButton coolBtn = new JButton( "Cool" ); public CoolUiClass() { this .setLayout( new GridBagLayout()); this .setMinimumSize( new Dimension( 400 , 350 )); this .setPreferredSize( new Dimension( 400 , 350 )); coolBtn.setMinimumSize( new Dimension( 80 , 21 )); coolBtn.setPreferredSize( new Dimension( 80 , 21 )); JScrollPane scrollPane = new JScrollPane(msgTxt); scrollPane.setMinimumSize( new Dimension( 400 , 320 )); scrollPane.setPreferredSize( new Dimension( 400 , 320 )); this .add(scrollPane, new GridBagConstraints( 0 , 0 , 1 , 1 , 0.0 , 0.0 , GridBagConstraints.CENTER, GridBagConstraints.BOTH, new Insets( 5 , 5 , 5 , 5 ), 0 , 0 )); this .add(coolBtn, new GridBagConstraints( 0 , 1 , 1 , 1 , 0.0 , 0.0 , GridBagConstraints.CENTER, GridBagConstraints.NONE, new Insets( 5 , 5 , 5 , 5 ), 0 , 0 )); coolBtn.addActionListener( new ActionListener() { public void actionPerformed(ActionEvent arg0) { appendText(); } }); } protected void appendText() { msgTxt.append( "cool " ); } /** * test the calss in main,use your eye to test. * @param args */ public static void main(String[] args) { JFrame frm = new JFrame( "CoolUiClass" ); frm.getContentPane().add( new CoolUiClass()); frm.setDefaultCloseOperation(JFrame.DISPOSE_ON_CLOSE); frm.pack(); frm.setVisible( true ); } } |
简单地运行以下main方法,界面如下:
这其实已经在测试界面了,我在main函数里头写的就是测试代码,对于界面显示的测试,就这几行代码就足够了。你这时候是不是觉得:这也忒容易了,没什么难度。但我得告诉你,这才是刚刚开始。
界面除了显示,更复杂的是要进行事件处理,每一个界面控件都有可能是事件源,一个事件得引起一系列的操作,而且是对于界面的操作。这就跟一般的函数的测试相差甚大了,一般来说,函数的测试就是输入一个参数,然后判断输出参数,输出参数无非就那几种情况,要么抛异常、要么返回空、要么返回具体值。而界面的事件处理一般会改变很多个控件的显示,而且控件处于不同的状态时改变的情况也不一定是一样的,所以要测试处理是否正确,得判断多个值,而且得根据控件之前的状态来判断当前显示是否正确。看到这,你似乎感觉无从下手了是吧。幸亏,界面测试有其方便性,我们可以直接拿眼睛判断界面上显示是否正确了,虽然这样的测试方法无法保证完全正确,但是却很高效。在界面测试中,拿眼睛进行判断比拿机器进行判断肯定效率要高的多。
如果紧紧是界面逻辑的测试,用眼睛来测(我称之为目测法)已经足够了,可以很高效地发现问题。但是如果界面上用到的数据是来自于其它地方(譬如说是后台),那么在main方法里还不能够写出完整的测试代码。这时候我们就需要一种方法来满足这种需求,其实下面的方法才是目测法的精髓:将与界面处理逻辑无关的代码抽出来,例如上面appendText(这里仅仅举个例子,appendText实际上包含了界面处理逻辑,实际上只需要把非界面处理逻辑代码抽出来,例如文件操作,访问后台,数据库操作这些情况就应该这样做)的形式,然后使用继承的方式,将非界面处理逻辑代码给替换成自己需要的数据(俗称假数据),这样一来,界面处理逻辑代码就可以得到很好的测试。见以下代码:
1234567891011121314151617181920212223242526272829303132333435363738394041 | /************************************************************ * Project Name: lhjTest * File Name : CoolUiClassETest.java * File Desc : CoolUiClassETest.java * Author : Administrator * Create : 2007-3-24 * Modify: ***********************************************************/ package org.lhj.cool.uiunit; import javax.swing.JFrame; import org.lhj.cool.uiunit.CoolUiClass; /** * @author Administrator */ public class CoolUiClassETest extends CoolUiClass { /* (non-Javadoc) * @see org.lhj.cool.uiunit.CoolUiClass#appendText() */ @Override protected void appendText() { // call the super method twice super.appendText(); super.appendText(); } /** * test the calss in main,use your eye to test.So this method calls Eye Test. * the eyt test method's idea is extends the test calss and overrride somemethod so * that you can expect what you need. * @param args */ public static void main(String[] args) { JFrame frm = new JFrame( "CoolUiClassETest" ); frm.getContentPane().add( new CoolUiClassETest()); frm.setDefaultCloseOperation(JFrame.DISPOSE_ON_CLOSE); frm.pack(); frm.setVisible( true ); } } |
添加回答
举报