Mockito - 验证行为

Mockito 可以确保模拟方法是否使用必需的参数进行调用。这是使用 verify() 方法完成的。请查看以下代码片段。

//测试添加功能
Assert.assertEquals(calcService.add(10.0, 20.0),30.0,0);

//verify call to calcService is made or not with same arguments.
verify(calcService).add(10.0, 20.0);

示例 - 使用相同参数的 verify()

步骤 1 − 创建一个名为 CalculatorService 的接口来提供数学函数

文件:CalculatorService.java

public interface CalculatorService {
   public double add(double input1, double input2);
   public double subtract(double input1, double input2);
   public double multiply(double input1, double input2);
   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);
      return 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 类

让我们通过在其中注入 calculatorService 的模拟来测试 MathApplication 类。模拟将由 Mockito 创建。

文件:MathApplicationTester.java

import static org.mockito.Mockito.verify;
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 将运行器附加到测试类以初始化测试数据
@RunWith(MockitoJUnitRunner.class)
public class MathApplicationTester {
	
   //@InjectMocks 注解用于创建并注入mock对象
   @InjectMocks 
   MathApplication mathApplication = new MathApplication();

   //@Mock注解用于创建需要注入的模拟对象
   @Mock
   CalculatorService calcService;

   @Test
   public void testAdd(){
      //添加计算服务的行为以将两个数字相加
      when(calcService.add(10.0,20.0)).thenReturn(30.00);
		
      //测试添加功能
      Assert.assertEquals(calcService.add(10.0, 20.0),30.0,0);
       
      //verify the behavior
      verify(calcService).add(10.0, 20.0);
   }
}

步骤 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

现在运行测试运行器来查看结果

C:\Mockito_WORKSPACE>java TestRunner

验证输出。

true

示例 - 使用不同参数的 verify()

步骤 1 − 创建接口 CalculatorService 以提供数学函数

文件:CalculatorService.java

public interface CalculatorService {
   public double add(double input1, double input2);
   public double subtract(double input1, double input2);
   public double multiply(double input1, double input2);
   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);
      return 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 类

让我们通过在其中注入 calculatorService 的模拟来测试 MathApplication 类。模拟将由 Mockito 创建。

文件:MathApplicationTester.java

import static org.mockito.Mockito.verify;
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 将运行器附加到测试类以初始化测试数据
@RunWith(MockitoJUnitRunner.class)
public class MathApplicationTester {
	
   //@InjectMocks 注解用于创建并注入mock对象
   @InjectMocks 
   MathApplication mathApplication = new MathApplication();

   //@Mock注解用于创建需要注入的模拟对象
   @Mock
   CalculatorService calcService;

   @Test
   public void testAdd(){
      //添加计算服务的行为以将两个数字相加
      when(calcService.add(10.0,20.0)).thenReturn(30.00);
		
      //测试添加功能
      Assert.assertEquals(calcService.add(10.0, 20.0),30.0,0);
       
      //verify the behavior
      verify(calcService).add(20.0, 30.0);
   }
}

步骤 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

现在运行测试运行器来查看结果 −

C:\Mockito_WORKSPACE>java TestRunner

验证输出。

testAdd(MathApplicationTester): 
Argument(s) are different! Wanted:
calcService.add(20.0, 30.0);
-> at MathApplicationTester.testAdd(MathApplicationTester.java:32)
Actual invocation has different arguments:
calcService.add(10.0, 20.0);
-> at MathApplication.add(MathApplication.java:10)

false