(译) 05-Mockito-JUnit 集成

在本章中, 我们将学习如何将 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;

之后的博文中将不再说明。

你可能感兴趣的:(Mockito,Mockito)