如何使用 JUnit进行自动化测试
合集下载
相关主题
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
之后系统会自动生成一个新类CalculatorTest,里面包含一些空的测试用例。你只需要将这些测试用例稍作修改即可使用。完整的CalculatorTest代码如下:
package andycpp;
import static org.junit.Assert.*;
import org.junit.Before;
package service;
import javax.script.ScriptEngine;
import javax.script.ScriptEngineManager;
import javax.script.ScriptException;
public class CalculateService implements ICalculateService
{
CalculateService service= new CalculateService ();
CalculateModelmodel = new CalculateModel(service );
}
第二步明确要测试的方法,并根据要测试的方法,分析测试所需要覆盖的场景。
1.我们要测的方法为calculate;
@Test
public void should_return_failed_when_input_is_null()
{
assertEquals( "failed", service.calculate( null ) );
}
@TБайду номын сангаасst
public void should_return_failed_when_input_is_string_null()
{
assertEquals( "failed", service.calculate( "null" ) );
}
@Test
public void should_return_failed_when_input_is_not_can_calculate()
{
assertEquals( "failed", service.calculate( "/+*1" ) );
}
@Test
public void should_return_5_when_input_is_1_and_4()
{
assertEquals( "5.0", service.calculate( "1+4" ) );
}
通过调用service类的 calculate方法,并给予不同的输入参数以创建不同的场景,从而验证当前方法是否正确。
{
private ICalculateService service;
public CalculateModel( ICalculateService service )
{
this.service = service;
}
@Override
public String calculate( String text )
运行结果如下:
进度条是红颜色表示发现错误,具体的测试结果在进度条上面有表示“共进行了4个测试,其中1个测试被忽略,一个测试失败”
2
@TEST
方法的前面使用@Test标注,以表明这是一个测试方法。对于方法的声明也有如下要求:名字可以随便取,没有任何限制,但是返回值必须为void,而且不能有任何参数。
@Test
Object value = jse.eval( text );
if ( value != null )
{
return String.valueOf( value );
}
} catch ( ScriptException e )
{
e.printStackTrace();
}
}
return "failed";
@After
方法的前面使用@After标注,表示该测试类中,所有的测试方法在执行结束,都会运行该方法。
@BeforeClass
方法的前面使用@BeforeClass标注,表示该测试类首先会执行该方法。
@AfterClass
方法的前面使用@AfterClass标注,表示该测试类所有测试方法执行结束后,执行该方法。
@Ignore
函数的前面加上@Ignore标注,这个标注的含义就是“某些方法尚未完成,暂不参与此次测试”。这样的话测试结果就会提示你有几个测试被忽略,而不是失败。一旦你完成了相应函数,只需要把@Ignore标注删去,就可以进行正常的测试。
3
EasyMock主要是起到分层测试的作用,即我不关心哪一层,那一层就可以用mock的方法,把它虚拟出来一个对象,而不真的去创建这个对象。
package andycpp;
public class Calculator
{
private static int result; // 静态变量,用于存储运行结果
public void add(int n)
{
result = result + n;
}
public void substract(int n)
}
}
第二步,将JUnit4单元测试包引入这个项目:在该项目上点右键,点“属性”,如图:
在弹出的属性窗口中,首先在左边选择“Java Build Path”,然后到右上选择“Libraries”标签,之后在最右边点击“Add Library…”按钮,如下图所示:
然后在新弹出的对话框中选择JUnit4并点击确定,如上图所示,JUnit4软件包就被包含进我们这个项目了。
第三步,生成JUnit测试框架:在Eclipse的Package Explorer中用右键点击该类弹出菜单,选择“New JUnit Test Case”。如下图所示:
在弹出的对话框中,进行相应的选择,如下图所示:
点击“下一步”后,系统会自动列出你这个类中包含的方法,选择你要进行测试的方法。此例中,我们仅对“加、减、乘、除”四个方法进行测试。如下图所示:
}
}
我们先看一下CalculateService的单元测试如何写?
第一步要测试这个类,那我们首先要创建一个这样的对象
代码如下:
@Before
public void setUp()
{
CalculateService service= new CalculateService();
}
使用Before标签还是BeforeClass的决定条件在于,你要测试的方法是不是每次都要重新创建一个service
import org.junit.Ignore;
import org.junit.Test;
public class CalculatorTest
{
private static Calculator calculator = new Calculator();
@Before
public void setUp() throws Exception
{
result = result - 1; //Bug: 正确的应该是 result =result-n
}
public void multiply(int n)
{
} // 此方法尚未写好
public void divide(int n)
{
result = result / n;
}
public void square(int n)
{
@Override
public String calculate( String text )
{
ScriptEngine jse = new ScriptEngineManager().getEngineByName( "JavaScript" );
if ( null != text )
{
try
{
{
return service.calculate( text );
}
}
我们可以按照上面的步骤去写测试类
第一步创建要测试的对象,这里由于CalculateModel的创建依赖于CalculateService,所以我们要先创建CalculateService;
代码如下:
@Before
public void setUp()
第二步明确要测试的方法,并根据要测试的方法,分析测试所需要覆盖的场景。
1.我们要测的方法为calculate;
2.该方法需要覆盖的场景为:
1)输入参数text为null
2)过程中value是null(这种情况的话,输入参数为”null”)
3)运算中出现异常
4)运算正常输出结果
那我们针对这几个场景,写测试代码如下:
{
result = n * n;
}
public void squareRoot(int n)
{
for (; ; ) ; //Bug : 死循环
}
public void clear()
{ // 将结果清零
result = 0;
}
public int getResult()
{
return result;
上面就是CalculateService的单元测试,那我们下面看下CalculateModel类,并一起来写一下他的单元测试要如何去写?
CalculateModel类的代码如下:
package model;
import service.ICalculateService;
public class CalculateModel implements ICalculateModel
2、根据代码我们可以看出该方法需要覆盖的场景只有一个,就是不论输入的参数如何,也不管运算的结果是什么,只要调用了CalculateService的calculate方法,并把结果返回出去即可。
测试代码如下:
@Test
public voidshould_return_2_when_input_is_1_multiply_2()
{
String text = "1*2";
assertEquals( "2", model.calculate( text ) );
}
粗略一看好像没什么问题,但是我们仔细想一下,如果CalculateService的calculate方法出错的话,那么这个测试用例就会报错,因为返回结果就会发生错误。也就是说我们现在在测CalculateModel,但我们同时还要保证CalculateService的正确,这样显然是有问题的,因为CalculateService不是我们这次测试的对象,它在别的测试类中已经覆盖过了。那么如何解决这个问题呢?
public void testAdd()
{
calculator.add(2);
calculator.add(3);
assertEquals(5, calculator.getResult());
}
@Before
方法的前面使用@Before标注,表示该测试类中,所有的测试方法在执行前,都会运行该方法。
{
calculator.add(10);
calculator.substract(2);
assertEquals(8, calculator.getResult());
}
@Ignore("Multiply() Not yet implemented")
@Test
public void testMultiply()
{
calculator.clear();
}
@Test
public void testAdd()
{
calculator.add(2);
calculator.add(3);
assertEquals(5, calculator.getResult());
}
@Test
public void testSubstract()
{
}
@Test
public void testDivide()
{
calculator.add(8);
calculator.divide(2);
assertEquals(4, calculator.getResult());
}
}
第四步,运行测试代码:按照上述代码修改完毕后,我们在CalculatorTest类上点右键,选择“Run As à JUnit Test”来运行我们的测试,如下图所示:
如何使用JUnit进行自动化测试
1
JUnit可以和很多开发工具进行集成来进行单元测试,我们这里选取较常用的java开发工具Eclipse来使用JUnit4进行单元测试。如何在开发工具Eclipse里进行单元测试
首先新建一个项目叫JUnit_Test,我们编写一个Calculator类,这是一个能够简单实现加减乘除、平方、开方的计算器类,然后对这些功能进行单元测试。这个类并不是很完美,我们故意保留了一些Bug用于演示,这些Bug在注释中都有说明。该类代码如下:
为了说明EasyMock作用和用法,我们选取自动化测试COE中提供的demo作为例子。
我们选取其中的两个类CalculateService类和CalculateModel类,由于是以面向接口编程的思想开发的代码,所以这两个类之间是通过接口建立起关系的。
这两个类的关系如下图
3.1
CalculateService类的代码如下
package andycpp;
import static org.junit.Assert.*;
import org.junit.Before;
package service;
import javax.script.ScriptEngine;
import javax.script.ScriptEngineManager;
import javax.script.ScriptException;
public class CalculateService implements ICalculateService
{
CalculateService service= new CalculateService ();
CalculateModelmodel = new CalculateModel(service );
}
第二步明确要测试的方法,并根据要测试的方法,分析测试所需要覆盖的场景。
1.我们要测的方法为calculate;
@Test
public void should_return_failed_when_input_is_null()
{
assertEquals( "failed", service.calculate( null ) );
}
@TБайду номын сангаасst
public void should_return_failed_when_input_is_string_null()
{
assertEquals( "failed", service.calculate( "null" ) );
}
@Test
public void should_return_failed_when_input_is_not_can_calculate()
{
assertEquals( "failed", service.calculate( "/+*1" ) );
}
@Test
public void should_return_5_when_input_is_1_and_4()
{
assertEquals( "5.0", service.calculate( "1+4" ) );
}
通过调用service类的 calculate方法,并给予不同的输入参数以创建不同的场景,从而验证当前方法是否正确。
{
private ICalculateService service;
public CalculateModel( ICalculateService service )
{
this.service = service;
}
@Override
public String calculate( String text )
运行结果如下:
进度条是红颜色表示发现错误,具体的测试结果在进度条上面有表示“共进行了4个测试,其中1个测试被忽略,一个测试失败”
2
@TEST
方法的前面使用@Test标注,以表明这是一个测试方法。对于方法的声明也有如下要求:名字可以随便取,没有任何限制,但是返回值必须为void,而且不能有任何参数。
@Test
Object value = jse.eval( text );
if ( value != null )
{
return String.valueOf( value );
}
} catch ( ScriptException e )
{
e.printStackTrace();
}
}
return "failed";
@After
方法的前面使用@After标注,表示该测试类中,所有的测试方法在执行结束,都会运行该方法。
@BeforeClass
方法的前面使用@BeforeClass标注,表示该测试类首先会执行该方法。
@AfterClass
方法的前面使用@AfterClass标注,表示该测试类所有测试方法执行结束后,执行该方法。
@Ignore
函数的前面加上@Ignore标注,这个标注的含义就是“某些方法尚未完成,暂不参与此次测试”。这样的话测试结果就会提示你有几个测试被忽略,而不是失败。一旦你完成了相应函数,只需要把@Ignore标注删去,就可以进行正常的测试。
3
EasyMock主要是起到分层测试的作用,即我不关心哪一层,那一层就可以用mock的方法,把它虚拟出来一个对象,而不真的去创建这个对象。
package andycpp;
public class Calculator
{
private static int result; // 静态变量,用于存储运行结果
public void add(int n)
{
result = result + n;
}
public void substract(int n)
}
}
第二步,将JUnit4单元测试包引入这个项目:在该项目上点右键,点“属性”,如图:
在弹出的属性窗口中,首先在左边选择“Java Build Path”,然后到右上选择“Libraries”标签,之后在最右边点击“Add Library…”按钮,如下图所示:
然后在新弹出的对话框中选择JUnit4并点击确定,如上图所示,JUnit4软件包就被包含进我们这个项目了。
第三步,生成JUnit测试框架:在Eclipse的Package Explorer中用右键点击该类弹出菜单,选择“New JUnit Test Case”。如下图所示:
在弹出的对话框中,进行相应的选择,如下图所示:
点击“下一步”后,系统会自动列出你这个类中包含的方法,选择你要进行测试的方法。此例中,我们仅对“加、减、乘、除”四个方法进行测试。如下图所示:
}
}
我们先看一下CalculateService的单元测试如何写?
第一步要测试这个类,那我们首先要创建一个这样的对象
代码如下:
@Before
public void setUp()
{
CalculateService service= new CalculateService();
}
使用Before标签还是BeforeClass的决定条件在于,你要测试的方法是不是每次都要重新创建一个service
import org.junit.Ignore;
import org.junit.Test;
public class CalculatorTest
{
private static Calculator calculator = new Calculator();
@Before
public void setUp() throws Exception
{
result = result - 1; //Bug: 正确的应该是 result =result-n
}
public void multiply(int n)
{
} // 此方法尚未写好
public void divide(int n)
{
result = result / n;
}
public void square(int n)
{
@Override
public String calculate( String text )
{
ScriptEngine jse = new ScriptEngineManager().getEngineByName( "JavaScript" );
if ( null != text )
{
try
{
{
return service.calculate( text );
}
}
我们可以按照上面的步骤去写测试类
第一步创建要测试的对象,这里由于CalculateModel的创建依赖于CalculateService,所以我们要先创建CalculateService;
代码如下:
@Before
public void setUp()
第二步明确要测试的方法,并根据要测试的方法,分析测试所需要覆盖的场景。
1.我们要测的方法为calculate;
2.该方法需要覆盖的场景为:
1)输入参数text为null
2)过程中value是null(这种情况的话,输入参数为”null”)
3)运算中出现异常
4)运算正常输出结果
那我们针对这几个场景,写测试代码如下:
{
result = n * n;
}
public void squareRoot(int n)
{
for (; ; ) ; //Bug : 死循环
}
public void clear()
{ // 将结果清零
result = 0;
}
public int getResult()
{
return result;
上面就是CalculateService的单元测试,那我们下面看下CalculateModel类,并一起来写一下他的单元测试要如何去写?
CalculateModel类的代码如下:
package model;
import service.ICalculateService;
public class CalculateModel implements ICalculateModel
2、根据代码我们可以看出该方法需要覆盖的场景只有一个,就是不论输入的参数如何,也不管运算的结果是什么,只要调用了CalculateService的calculate方法,并把结果返回出去即可。
测试代码如下:
@Test
public voidshould_return_2_when_input_is_1_multiply_2()
{
String text = "1*2";
assertEquals( "2", model.calculate( text ) );
}
粗略一看好像没什么问题,但是我们仔细想一下,如果CalculateService的calculate方法出错的话,那么这个测试用例就会报错,因为返回结果就会发生错误。也就是说我们现在在测CalculateModel,但我们同时还要保证CalculateService的正确,这样显然是有问题的,因为CalculateService不是我们这次测试的对象,它在别的测试类中已经覆盖过了。那么如何解决这个问题呢?
public void testAdd()
{
calculator.add(2);
calculator.add(3);
assertEquals(5, calculator.getResult());
}
@Before
方法的前面使用@Before标注,表示该测试类中,所有的测试方法在执行前,都会运行该方法。
{
calculator.add(10);
calculator.substract(2);
assertEquals(8, calculator.getResult());
}
@Ignore("Multiply() Not yet implemented")
@Test
public void testMultiply()
{
calculator.clear();
}
@Test
public void testAdd()
{
calculator.add(2);
calculator.add(3);
assertEquals(5, calculator.getResult());
}
@Test
public void testSubstract()
{
}
@Test
public void testDivide()
{
calculator.add(8);
calculator.divide(2);
assertEquals(4, calculator.getResult());
}
}
第四步,运行测试代码:按照上述代码修改完毕后,我们在CalculatorTest类上点右键,选择“Run As à JUnit Test”来运行我们的测试,如下图所示:
如何使用JUnit进行自动化测试
1
JUnit可以和很多开发工具进行集成来进行单元测试,我们这里选取较常用的java开发工具Eclipse来使用JUnit4进行单元测试。如何在开发工具Eclipse里进行单元测试
首先新建一个项目叫JUnit_Test,我们编写一个Calculator类,这是一个能够简单实现加减乘除、平方、开方的计算器类,然后对这些功能进行单元测试。这个类并不是很完美,我们故意保留了一些Bug用于演示,这些Bug在注释中都有说明。该类代码如下:
为了说明EasyMock作用和用法,我们选取自动化测试COE中提供的demo作为例子。
我们选取其中的两个类CalculateService类和CalculateModel类,由于是以面向接口编程的思想开发的代码,所以这两个类之间是通过接口建立起关系的。
这两个类的关系如下图
3.1
CalculateService类的代码如下