如何使用JUnit进行自动化测试

整理文档很辛苦,赏杯茶钱您下走!

免费阅读已结束,点击下载阅读编辑剩下 ...

阅读已结束,您可以下载文档离线阅读编辑

资源描述

如何使用JUnit进行自动化测试1如何利用JUnit在Eclipse中开发自动化脚本JUnit可以和很多开发工具进行集成来进行单元测试,我们这里选取较常用的java开发工具Eclipse来使用JUnit4进行单元测试。如何在开发工具Eclipse里进行单元测试首先新建一个项目叫JUnit_Test,我们编写一个Calculator类,这是一个能够简单实现加减乘除、平方、开方的计算器类,然后对这些功能进行单元测试。这个类并不是很完美,我们故意保留了一些Bug用于演示,这些Bug在注释中都有说明。该类代码如下:packageandycpp;publicclassCalculator{privatestaticintresult;//静态变量,用于存储运行结果publicvoidadd(intn){result=result+n;}publicvoidsubstract(intn){result=result-1;//Bug:正确的应该是result=result-n}publicvoidmultiply(intn){}//此方法尚未写好publicvoiddivide(intn){result=result/n;}publicvoidsquare(intn){result=n*n;}publicvoidsquareRoot(intn){for(;;);//Bug:死循环}publicvoidclear(){//将结果清零result=0;}publicintgetResult(){returnresult;}}第二步,将JUnit4单元测试包引入这个项目:在该项目上点右键,点“属性”,如图:在弹出的属性窗口中,首先在左边选择“JavaBuildPath”,然后到右上选择“Libraries”标签,之后在最右边点击“AddLibrary…”按钮,如下图所示:然后在新弹出的对话框中选择JUnit4并点击确定,如上图所示,JUnit4软件包就被包含进我们这个项目了。第三步,生成JUnit测试框架:在Eclipse的PackageExplorer中用右键点击该类弹出菜单,选择“NewJUnitTestCase”。如下图所示:在弹出的对话框中,进行相应的选择,如下图所示:点击“下一步”后,系统会自动列出你这个类中包含的方法,选择你要进行测试的方法。此例中,我们仅对“加、减、乘、除”四个方法进行测试。如下图所示:之后系统会自动生成一个新类CalculatorTest,里面包含一些空的测试用例。你只需要将这些测试用例稍作修改即可使用。完整的CalculatorTest代码如下:packageandycpp;importstaticorg.junit.Assert.*;importorg.junit.Before;importorg.junit.Ignore;importorg.junit.Test;publicclassCalculatorTest{privatestaticCalculatorcalculator=newCalculator();@BeforepublicvoidsetUp()throwsException{calculator.clear();}@TestpublicvoidtestAdd(){calculator.add(2);calculator.add(3);assertEquals(5,calculator.getResult());}@TestpublicvoidtestSubstract(){calculator.add(10);calculator.substract(2);assertEquals(8,calculator.getResult());}@Ignore(Multiply()Notyetimplemented)@TestpublicvoidtestMultiply(){}@TestpublicvoidtestDivide(){calculator.add(8);calculator.divide(2);assertEquals(4,calculator.getResult());}}第四步,运行测试代码:按照上述代码修改完毕后,我们在CalculatorTest类上点右键,选择“RunAsàJUnitTest”来运行我们的测试,如下图所示:运行结果如下:进度条是红颜色表示发现错误,具体的测试结果在进度条上面有表示“共进行了4个测试,其中1个测试被忽略,一个测试失败”2JUnit重要元素@TEST方法的前面使用@Test标注,以表明这是一个测试方法。对于方法的声明也有如下要求:名字可以随便取,没有任何限制,但是返回值必须为void,而且不能有任何参数。@TestpublicvoidtestAdd(){calculator.add(2);calculator.add(3);assertEquals(5,calculator.getResult());}@Before方法的前面使用@Before标注,表示该测试类中,所有的测试方法在执行前,都会运行该方法。@After方法的前面使用@After标注,表示该测试类中,所有的测试方法在执行结束,都会运行该方法。@BeforeClass方法的前面使用@BeforeClass标注,表示该测试类首先会执行该方法。@AfterClass方法的前面使用@AfterClass标注,表示该测试类所有测试方法执行结束后,执行该方法。@Ignore函数的前面加上@Ignore标注,这个标注的含义就是“某些方法尚未完成,暂不参与此次测试”。这样的话测试结果就会提示你有几个测试被忽略,而不是失败。一旦你完成了相应函数,只需要把@Ignore标注删去,就可以进行正常的测试。3如何结合EasyMock去写单元测试EasyMock主要是起到分层测试的作用,即我不关心哪一层,那一层就可以用mock的方法,把它虚拟出来一个对象,而不真的去创建这个对象。为了说明EasyMock作用和用法,我们选取自动化测试COE中提供的demo作为例子。我们选取其中的两个类CalculateService类和CalculateModel类,由于是以面向接口编程的思想开发的代码,所以这两个类之间是通过接口建立起关系的。这两个类的关系如下图3.1简单的单元测试写法CalculateService类的代码如下packageservice;importjavax.script.ScriptEngine;importjavax.script.ScriptEngineManager;importjavax.script.ScriptException;publicclassCalculateServiceimplementsICalculateService{@OverridepublicStringcalculate(Stringtext){ScriptEnginejse=newScriptEngineManager().getEngineByName(JavaScript);if(null!=text){try{Objectvalue=jse.eval(text);if(value!=null){returnString.valueOf(value);}}catch(ScriptExceptione){e.printStackTrace();}}returnfailed;}}我们先看一下CalculateService的单元测试如何写?第一步要测试这个类,那我们首先要创建一个这样的对象代码如下:@BeforepublicvoidsetUp(){CalculateServiceservice=newCalculateService();}使用Before标签还是BeforeClass的决定条件在于,你要测试的方法是不是每次都要重新创建一个service第二步明确要测试的方法,并根据要测试的方法,分析测试所需要覆盖的场景。1.我们要测的方法为calculate;2.该方法需要覆盖的场景为:1)输入参数text为null2)过程中value是null(这种情况的话,输入参数为”null”)3)运算中出现异常4)运算正常输出结果那我们针对这几个场景,写测试代码如下:@Testpublicvoidshould_return_failed_when_input_is_null(){assertEquals(failed,service.calculate(null));}@Testpublicvoidshould_return_failed_when_input_is_string_null(){assertEquals(failed,service.calculate(null));}@Testpublicvoidshould_return_failed_when_input_is_not_can_calculate(){assertEquals(failed,service.calculate(/+*1));}@Testpublicvoidshould_return_5_when_input_is_1_and_4(){assertEquals(5.0,service.calculate(1+4));}通过调用service类的calculate方法,并给予不同的输入参数以创建不同的场景,从而验证当前方法是否正确。上面就是CalculateService的单元测试,那我们下面看下CalculateModel类,并一起来写一下他的单元测试要如何去写?CalculateModel类的代码如下:packagemodel;importservice.ICalculateService;publicclassCalculateModelimplementsICalculateModel{privateICalculateServiceservice;publicCalculateModel(ICalculateServiceservice){this.service=service;}@OverridepublicStringcalculate(Stringtext){returnservice.calculate(text);}}我们可以按照上面的步骤去写测试类第一步创建要测试的对象,这里由于CalculateModel的创建依赖于CalculateService,所以我们要先创建CalculateService;代码如下:@BeforepublicvoidsetUp(){CalculateServiceservice=newCalculateService();CalculateModelmodel=newCalculateModel(service);}第二步明确要测试的方法,并根据要测试的方法,分析测试所需要覆盖的场景。1.我们要测的方法为calculate;2、根据代码我们可以看出该方法需要覆盖的场景只有一个,就是不论输入的参数如何,也不管运算的结果是什么,只要调用了CalculateService的calculate方法,并把结果返回出去即可。测试代码如下:@Testpublicvoidshould_return_2_when_input_is_1_multiply_2(){Stringtext=1*2;assertEquals(2,model.calculate(text));}粗略一看好像没什么问题,但是我们仔细想一下,如果CalculateService的calculate方法出错的话,那么这个测试用例就会报错,因为返回结果就会发生错误。也就是说我们现在在测CalculateModel,但我们同时还要保证CalculateService的正确,这样显然是有问题的,因为CalculateService不是我们这次测试的对象,它在别的测试类中已经覆盖过了。那么如何解决这个问题呢?3.2结合EasyMoc

1 / 24
下载文档,编辑使用

©2015-2020 m.777doc.com 三七文档.

备案号:鲁ICP备2024069028号-1 客服联系 QQ:2149211541

×
保存成功