- EasyMock 教程
- EasyMock – 主頁
- EasyMock – 概覽
- EasyMock – 環境設定
- EasyMock – 首個應用程式
- EasyMock – JUnit 整合
- EasyMock – 新增行為
- EasyMock – 驗證行為
- EasyMock – 預期呼叫
- EasyMock – 可變呼叫
- EasyMock – 異常處理
- EasyMock – createMock
- EasyMock – createStrictMock
- EasyMock – createNiceMock
- EasyMock 有用資源
- EasyMock – 快速指南
- EasyMock – 有用資源
- EasyMock – 討論
EasyMock – createMock
到目前為止,我們已使用註釋來建立模擬。EasyMock 提供多種方法來建立模擬物件。EasyMock.createMock() 建立模擬,而無需擔心模擬在執行期間將進行的方法呼叫的順序。
語法
calcService = EasyMock.createMock(CalculatorService.class);
示例
步驟 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);
}
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 類。模擬將由 EasyMock 建立。
在這裡,我們透過 expect() 向模擬物件添加了兩個模擬方法呼叫,add() 和 subtract()。但在測試期間,我們已在呼叫 add() 前呼叫了 subtract()。當我們使用 EasyMock.createMock() 建立模擬物件時,方法執行的順序無關緊要。
檔案:MathApplicationTester.java
import org.easymock.EasyMock;
import org.easymock.EasyMockRunner;
import org.junit.Assert;
import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
@RunWith(EasyMockRunner.class)
public class MathApplicationTester {
private MathApplication mathApplication;
private CalculatorService calcService;
@Before
public void setUp(){
mathApplication = new MathApplication();
calcService = EasyMock.createMock(CalculatorService.class);
mathApplication.setCalculatorService(calcService);
}
@Test
public void testAddAndSubtract(){
//add the behavior to add numbers
EasyMock.expect(calcService.add(20.0,10.0)).andReturn(30.0);
//subtract the behavior to subtract numbers
EasyMock.expect(calcService.subtract(20.0,10.0)).andReturn(10.0);
//activate the mock
EasyMock.replay(calcService);
//test the subtract functionality
Assert.assertEquals(mathApplication.subtract(20.0, 10.0),10.0,0);
//test the add functionality
Assert.assertEquals(mathApplication.add(20.0, 10.0),30.0,0);
//verify call to calcService is made or not
EasyMock.verify(calcService);
}
}
步驟 4:執行測試用例
在 C:\> EasyMock_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:\EasyMock_WORKSPACE>javac MathApplicationTester.java
現在執行測試執行器以檢視結果 −
C:\EasyMock_WORKSPACE>java TestRunner
輸出
驗證輸出。
true
廣告