在本章中, 我们将学习如何将 JUnit 和 Mockito 集成在一起。在这里, 我们将创建一个数学应用程序, 使用 CalculatorService 执行基本的数学运算, 如加法, 减法, 乘法和除法。
我们将使用 Mockito 来模拟 CalculatorService 的虚拟实现。此外, 我们还广泛使用了注解来展示它们与 JUnit 和 Mockito 的兼容性。
下面将以循序渐进的方式讨论此过程。
步骤1−创建一个称为 CalculatorService 的接口, 以提供数学函数
文件: CalculatorService. java
/**
* 计算相关服务
*/
public interface CalculatorService {
/**
* 加法
*
* @param input1
* @param input2
* @return
*/
public double add(double input1, double input2);
/**
* 减法
*
* @param input1
* @param input2
* @return
*/
public double subtract(double input1, double input2);
/**
* 乘法
*
* @param input1
* @param input2
* @return
*/
public double multiply(double input1, double input2);
/**
* 除法
*
* @param input1
* @param input2
* @return
*/
public double divide(double input1, double input2);
}
步骤2−创建一个 JAVA 类来表示 MathApplication
文件: MathApplication. java
/**
* 数学应用
*/
public class MathApplication {
private CalculatorService calcService;
public void setCalculatorService(CalculatorService calcService) {
this.calcService = calcService;
}
public double add(double input1, double input2) {
return calcService.add(input1, input2);
}
public double subtract(double input1, double input2) {
return calcService.subtract(input1, input2);
}
public double multiply(double input1, double input2) {
return calcService.multiply(input1, input2);
}
public double divide(double input1, double input2) {
return calcService.divide(input1, input2);
}
}
步骤3−测试 MathApplication 类
让我们测试 MathApplication 类, 通过注入一个 calculatorService 的Mock。Mock将由 Mockito 创建。
文件: MathApplicationTester. java
import static org.mockito.Mockito.when;
import org.junit.Assert;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.mockito.InjectMocks;
import org.mockito.Mock;
import org.mockito.runners.MockitoJUnitRunner;
// @RunWith attaches a runner with the test class to initialize the test data
@RunWith(MockitoJUnitRunner.class)
public class MathApplicationTester {
//@InjectMocks annotation is used to create and inject the mock object
@InjectMocks
MathApplication mathApplication = new MathApplication();
//@Mock annotation is used to create the mock object to be injected
@Mock
CalculatorService calcService;
@Test
public void testAdd(){
//add the behavior of calc service to add two numbers
when(calcService.add(10.0,20.0)).thenReturn(30.00);
//test the add functionality
Assert.assertEquals(mathApplication.add(10.0, 20.0),30.0,0);
}
}
@Mock: 创建一个Mock.
@InjectMocks: 创建一个实例,其余用@Mock(或@Spy)注解创建的mock将被注入到用该实例中。
注意:必须使用@RunWith(MockitoJUnitRunner.class) 或 Mockito.initMocks(this)进行mocks的初始化和注入。
步骤4−创建要执行到测试用例的类
在C > Mockito_WORKSPACE中创建名为 TestRunner 的 java 类文件以执行测试用例。
文件: TestRunner. java
import org.junit.runner.JUnitCore;
import org.junit.runner.Result;
import org.junit.runner.notification.Failure;
public class TestRunner {
public static void main(String[] args) {
Result result = JUnitCore.runClasses(MathApplicationTester.class);
for (Failure failure : result.getFailures()) {
System.out.println(failure.toString());
}
System.out.println(result.wasSuccessful());
}
}
步骤5−验证结果
使用javac编译器编译类, 如下所示−
C:\Mockito_WORKSPACE>javac CalculatorService.java MathApplication. java MathApplicationTester.java TestRunner.java
现在运行TestRunner以查看结果−
C:\Mockito_WORKSPACE>java TestRunner
验证输出。
true
要了解有关 JUnit 的更多信息, 请参阅教程点的 junit 教程
翻译自:https://www.tutorialspoint.com/mockito/mockito_junit_integration.htm
注意:目前我采用的时mockito稳定版本2.15.0,在这个版本下@RunWith(MockitoJUnitRunner.class)这里会报错,说已过时。
我们需要修改package引用路径即可 import org.mockito.junit.MockitoJUnitRunner;
之后的博文中将不再说明。