मॉकिटो - त्वरित गाइड

मॉकिंग क्या है?

अलगाव में वर्ग की कार्यक्षमता का परीक्षण करने का एक तरीका है मॉकिंग। कार्यक्षमता का परीक्षण करने के लिए मॉकिंग के लिए डेटाबेस कनेक्शन या प्रॉपर्टी फाइल रीड या फाइल सर्वर रीड की आवश्यकता नहीं होती है। नकली वस्तुएं वास्तविक सेवा का मजाक उड़ाती हैं। एक मॉक ऑब्जेक्ट एक डमी डेटा देता है जो उसके पास दिए गए कुछ डमी इनपुट के अनुरूप होता है।

Mockito

मॉकिटो मूल रूप से नकली वस्तुओं को बनाने की सुविधा देता है। किसी दिए गए इंटरफ़ेस के लिए नकली वस्तुओं को बनाने के लिए जावा रिफ्लेक्शन का उपयोग करता है। नकली वस्तुएं वास्तविक कार्यान्वयन के लिए प्रॉक्सी के अलावा और कुछ नहीं हैं।

स्टॉक सेवा के एक मामले पर विचार करें जो किसी शेयर का मूल्य विवरण लौटाता है। विकास के दौरान, वास्तविक समय डेटा प्राप्त करने के लिए वास्तविक स्टॉक सेवा का उपयोग नहीं किया जा सकता है। इसलिए हमें स्टॉक सेवा के एक डमी कार्यान्वयन की आवश्यकता है। मॉकिटो बहुत आसानी से कर सकता है, जैसा कि इसके नाम से पता चलता है।

मॉकिटो के लाभ

  • No Handwriting - अपने आप पर नकली वस्तुओं को लिखने की आवश्यकता नहीं है।

  • Refactoring Safe - इंटरफ़ेस का नाम बदलने और पैरामीटर को पुन: व्यवस्थित करने से परीक्षण कोड नहीं टूटेगा क्योंकि Mocks रनटाइम पर बनाए जाते हैं।

  • Return value support - रिटर्न मानों का समर्थन करता है।

  • Exception support - अपवादों का समर्थन करता है।

  • Order check support - विधि कॉल के आदेश पर जाँच का समर्थन करता है।

  • Annotation support - एनोटेशन का उपयोग करके नकली बनाने का समर्थन करता है।

निम्नलिखित कोड स्निपेट पर विचार करें।

package com.tutorialspoint.mock;

import java.util.ArrayList;
import java.util.List;

import static org.mockito.Mockito.*;

public class PortfolioTester {
   public static void main(String[] args){

      //Create a portfolio object which is to be tested		
      Portfolio portfolio = new Portfolio();

      //Creates a list of stocks to be added to the portfolio
      List<Stock> stocks = new ArrayList<Stock>();
      Stock googleStock = new Stock("1","Google", 10);
      Stock microsoftStock = new Stock("2","Microsoft",100);

      stocks.add(googleStock);
      stocks.add(microsoftStock);		

      //Create the mock object of stock service
      StockService stockServiceMock = mock(StockService.class);

      // mock the behavior of stock service to return the value of various stocks
      when(stockServiceMock.getPrice(googleStock)).thenReturn(50.00);
      when(stockServiceMock.getPrice(microsoftStock)).thenReturn(1000.00);

      //add stocks to the portfolio
      portfolio.setStocks(stocks);

      //set the stockService to the portfolio
      portfolio.setStockService(stockServiceMock);

      double marketValue = portfolio.getMarketValue();

      //verify the market value to be 
      //10*50.00 + 100* 1000.00 = 500.00 + 100000.00 = 100500
      System.out.println("Market value of the portfolio: "+ marketValue);
   }
}

आइए उपरोक्त कार्यक्रम की महत्वपूर्ण अवधारणाओं को समझते हैं। पूरा कोड अध्याय में उपलब्ध हैFirst Application

  • Portfolio - स्टॉक की एक सूची ले जाने और शेयर की कीमतों और स्टॉक की मात्रा का उपयोग करके बाजार मूल्य प्राप्त करने के लिए एक वस्तु।

  • Stock - किसी शेयर के विवरण जैसे उसकी आईडी, नाम, मात्रा आदि को ले जाने वाली वस्तु।

  • StockService - एक स्टॉक सेवा किसी शेयर की वर्तमान कीमत लौटाती है।

  • mock(...) - मॉकिटो ने स्टॉक सर्विस का मजाक बनाया।

  • when(...).thenReturn(...)- स्टॉक सर्विस इंटरफेस की getPrice विधि का नकली कार्यान्वयन। GoogleStock के लिए, मूल्य के रूप में 50.00 लौटाएं।

  • portfolio.setStocks(...) - पोर्टफोलियो में अब दो शेयरों की सूची है।

  • portfolio.setStockService(...) - पोर्टफोलियो को स्टॉकसेक मॉक ऑब्जेक्ट असाइन करता है।

  • portfolio.getMarketValue() - पोर्टफोलियो मॉक स्टॉक सेवा का उपयोग करके अपने शेयरों के आधार पर बाजार मूल्य लौटाता है।

मॉकिटो जावा के लिए एक रूपरेखा है, इसलिए आपकी मशीन में जेडडीके स्थापित होने की पहली आवश्यकता है।

व्यवस्था की आवश्यकता

JDK 1.5 या ऊपर।
याद कोई न्यूनतम आवश्यकता नहीं।
डिस्क में जगह कोई न्यूनतम आवश्यकता नहीं।
ऑपरेटिंग सिस्टम कोई न्यूनतम आवश्यकता नहीं।

Step 1 − Verify Java Installation on Your Machine

कंसोल खोलें और निम्न निष्पादित करें java आदेश।

ओएस टास्क आदेश
खिड़कियाँ ओपन कमांड कंसोल c: \> java -version
लिनक्स कमांड टर्मिनल खोलें $ जावा-विचलन
मैक टर्मिनल खोलें मशीन:> joseph $ java -version

आइए सभी ऑपरेटिंग सिस्टम के लिए आउटपुट को सत्यापित करें -

ओएस उत्पादन
खिड़कियाँ

जावा संस्करण "1.6.0_21"

जावा (TM) एसई रनटाइम एनवायरनमेंट (बिल्ड 1.6.0_21-b07)

जावा हॉटस्पॉट (टीएम) क्लाइंट वीएम (बिल्ड 17.0-b17, मिश्रित मोड, साझाकरण)

लिनक्स

जावा संस्करण "1.6.0_21"

जावा (TM) एसई रनटाइम एनवायरनमेंट (बिल्ड 1.6.0_21-b07)

जावा हॉटस्पॉट (टीएम) क्लाइंट वीएम (बिल्ड 17.0-b17, मिश्रित मोड, साझाकरण)

मैक

जावा संस्करण "1.6.0_21"

जावा (TM) एसई रनटाइम एनवायरनमेंट (बिल्ड 1.6.0_21-b07)

जावा हॉटस्पॉट (TM) 64-बिट सर्वर VM (बिल्ड 17.0-b17, मिश्रित मोड, साझाकरण)

यदि आपके पास जावा स्थापित नहीं है, तो जावा सॉफ्टवेयर डेवलपमेंट किट (एसडीके) स्थापित करने के लिए यहां क्लिक करें।

हम मानते हैं कि आपके पास इस ट्यूटोरियल के लिए आपके सिस्टम पर जावा 1.6.0_21 स्थापित है।

Step 2 − Set JAVA Environment

ठीक JAVA_HOMEवातावरण चर आधार निर्देशिका स्थान पर इंगित करने के लिए जहां जावा आपकी मशीन पर स्थापित है। उदाहरण के लिए,

ओएस उत्पादन
खिड़कियाँ पर्यावरण चर JAVA_HOME को C: \ Program Files \ Java \ jdk1.6.0_21 पर सेट करें
लिनक्स निर्यात JAVA_HOME = / usr / स्थानीय / जावा-वर्तमान
मैक निर्यात JAVA_HOME = / लाइब्रेरी / जावा / होम

जावा कंपाइलर के स्थान को अपने सिस्टम पथ में जोड़ें।

ओएस उत्पादन
खिड़कियाँ स्ट्रिंग को संलग्न करें; C: \ Program Files \ Java \ jdk1.6.0_21 \ bin सिस्टम चर के अंत में, पथ।
लिनक्स निर्यात पथ = $ पथ: $ जाव_होम / बिन /
मैक आवश्यक नहीं

कमांड का उपयोग करके जावा इंस्टॉलेशन को सत्यापित करें java -version जैसा कि ऊपर बताया गया है।

Step 3 − Download Mockito-All Archive

मावेन रिपोजिटरी से मॉकिटो का नवीनतम संस्करण डाउनलोड करने के लिए यहां क्लिक करें।

अपने C ड्राइव पर जार फ़ाइल सहेजें, मान लें कि C: \> Mockito।

ओएस संग्रह का नाम
खिड़कियाँ mockito सभी-2.0.2-beta.jar
लिनक्स mockito सभी-2.0.2-beta.jar
मैक mockito सभी-2.0.2-beta.jar

Step 4 − Set Mockito Environment

ठीक Mockito_HOMEपर्यावरण चर को आधार निर्देशिका स्थान पर इंगित करने के लिए जहां मॉकिटो और निर्भरता जार आपकी मशीन पर संग्रहीत हैं। निम्न तालिका से पता चलता है कि विभिन्न ऑपरेटिंग सिस्टम पर पर्यावरण चर को कैसे सेट किया जाए, यह मानते हुए कि हमने मॉकिटो-ऑल-2.0.2-beta.jar को C: \> मॉकिटो फ़ोल्डर में निकाला है।

ओएस उत्पादन
खिड़कियाँ पर्यावरण चर Mockito_HOME को C: \ Mockito पर सेट करें
लिनक्स निर्यात Mockito_HOME = / usr / स्थानीय / Mockito
मैक Mockito_HOME = / Library / Mockito निर्यात करें

Step 5 − Set CLASSPATH Variable

ठीक CLASSPATHपर्यावरण चर उस स्थान को इंगित करने के लिए जहां मॉकिटो जार संग्रहीत है। निम्न तालिका से पता चलता है कि विभिन्न ऑपरेटिंग सिस्टम पर CLASSPATH चर कैसे सेट करें।

ओएस उत्पादन
खिड़कियाँ वातावरण चर वर्ग% CLASSPATH% पर सेट करें;% Mockito_HOME% \ mockito-all-2.0.2-beta.jar ;;
लिनक्स निर्यात CLASSPATH = $ CLASSPATH: $ Mockito_HOME / mockito-all-2.0.2-beta.jar :।
मैक निर्यात CLASSPATH = $ CLASSPATH: $ Mockito_HOME / mockito-all-2.0.2-beta.jar :।

Step 6 − Download JUnit Archive

Github से JUnit jar फ़ाइल का नवीनतम संस्करण डाउनलोड करें । स्थान C: \> जूनिट पर फ़ोल्डर सहेजें।

ओएस संग्रह का नाम
खिड़कियाँ junit4.11.jar, हैमरेस्ट-कोर-1.2.1.jar
लिनक्स junit4.11.jar, हैमरेस्ट-कोर-1.2.1.jar
मैक junit4.11.jar, हैमरेस्ट-कोर-1.2.1.jar

Step 7 − Set JUnit Environment

ठीक JUNIT_HOMEआधार चर स्थान पर इंगित करने के लिए वातावरण चर जहाँ JUnit जार आपकी मशीन पर संग्रहीत हैं। निम्न तालिका दिखाती है कि विभिन्न ऑपरेटिंग सिस्टम पर इस पर्यावरण चर को कैसे सेट किया जाए, यह मानते हुए कि हमने junit4.11.jar और Hamcrest-core-1.2.1.jar को C: \> Junit पर संग्रहीत किया है।

ओएस उत्पादन
खिड़कियाँ पर्यावरण चर JUNIT_HOME को C: \ JUNIT पर सेट करें
लिनक्स निर्यात JUNIT_HOME = / usr / स्थानीय / JUNIT
मैक निर्यात JUNIT_HOME = / लाइब्रेरी / JUNIT

Step 8 − Set CLASSPATH Variable

JUNIT जार स्थान को इंगित करने के लिए CLASSPATH वातावरण चर सेट करें। निम्न तालिका से पता चलता है कि यह विभिन्न ऑपरेटिंग सिस्टम पर कैसे किया जाता है।

ओएस उत्पादन
खिड़कियाँ पर्यावरण चर कक्षा को% CLASSPATH%;% JUNIT_HOME% \ junit4.11.jar;% JUNIT_HOME% \ hamcrest-core-1.2.1.jar;
लिनक्स निर्यात CLASSPATH = $ CLASSPATH: $ JUNIT_HOME / junit4.11.jar: $ JUNIT_HOME / hamcrest-core-1.2.1.jar:।
मैक निर्यात CLASSPATH = $ CLASSPATH: $ JUNIT_HOME / junit4.11.jar: $ JUNIT_HOME / hamcrest-core-1.2.1.jar:।

मॉकिटो फ्रेमवर्क के विवरण में जाने से पहले, आइए एक एप्लिकेशन देखें। इस उदाहरण में, हमने कुछ स्टॉक और यूनिट की एक डमी कीमत का परीक्षण करने के लिए स्टॉक सर्विस का एक मॉक बनाया है, जो पोर्टफोलियो नाम के जावा वर्ग का परीक्षण करता है।

प्रक्रिया को चरण-दर-चरण तरीके से नीचे चर्चा की गई है।

Step 1 − Create a JAVA class to represent the Stock

File: Stock.java

public class Stock {
   private String stockId;
   private String name;	
   private int quantity;

   public Stock(String stockId, String name, int quantity){
      this.stockId = stockId;
      this.name = name;		
      this.quantity = quantity;		
   }

   public String getStockId() {
      return stockId;
   }

   public void setStockId(String stockId) {
      this.stockId = stockId;
   }

   public int getQuantity() {
      return quantity;
   }

   public String getTicker() {
      return name;
   }
}

Step 2 − Create an interface StockService to get the price of a stock

File: StockService.java

public interface StockService {
   public double getPrice(Stock stock);
}

Step 3 − Create a class Portfolio to represent the portfolio of any client

File: Portfolio.java

import java.util.List;

public class Portfolio {
   private StockService stockService;
   private List<Stock> stocks;

   public StockService getStockService() {
      return stockService;
   }
   
   public void setStockService(StockService stockService) {
      this.stockService = stockService;
   }

   public List<Stock> getStocks() {
      return stocks;
   }

   public void setStocks(List<Stock> stocks) {
      this.stocks = stocks;
   }

   public double getMarketValue(){
      double marketValue = 0.0;
      
      for(Stock stock:stocks){
         marketValue += stockService.getPrice(stock) * stock.getQuantity();
      }
      return marketValue;
   }
}

Step 4 − Test the Portfolio class

पोर्टफोलियो वर्ग का परीक्षण करते हैं, इसमें स्टॉकवर्क का मजाक उड़ाते हैं। मॉक मॉकिटो द्वारा बनाया जाएगा।

File: PortfolioTester.java

package com.tutorialspoint.mock;

import java.util.ArrayList;
import java.util.List;

import static org.mockito.Mockito.*;

public class PortfolioTester {
	
   Portfolio portfolio;	
   StockService stockService;
	   
   
   public static void main(String[] args){
      PortfolioTester tester = new PortfolioTester();
      tester.setUp();
      System.out.println(tester.testMarketValue()?"pass":"fail");
   }
   
   public void setUp(){
      //Create a portfolio object which is to be tested		
      portfolio = new Portfolio();		
  
      //Create the mock object of stock service
      stockService = mock(StockService.class);		

      //set the stockService to the portfolio
      portfolio.setStockService(stockService);
   }
   
   public boolean testMarketValue(){
    	   
      //Creates a list of stocks to be added to the portfolio
      List<Stock> stocks = new ArrayList<Stock>();
      Stock googleStock = new Stock("1","Google", 10);
      Stock microsoftStock = new Stock("2","Microsoft",100);	
 
      stocks.add(googleStock);
      stocks.add(microsoftStock);

      //add stocks to the portfolio
      portfolio.setStocks(stocks);

      //mock the behavior of stock service to return the value of various stocks
      when(stockService.getPrice(googleStock)).thenReturn(50.00);
      when(stockService.getPrice(microsoftStock)).thenReturn(1000.00);		

      double marketValue = portfolio.getMarketValue();		
      return marketValue == 100500.0;
   }
}

Step 5 − Verify the result

उपयोग करने वाली कक्षाओं को संकलित करें javac संकलक निम्नानुसार है -

C:\Mockito_WORKSPACE>javac Stock.java StockService.java Portfolio.java PortfolioTester.java

अब परिणाम देखने के लिए PortTertester चलाएं -

C:\Mockito_WORKSPACE>java PortfolioTester

आउटपुट सत्यापित करें

pass

इस अध्याय में, हम सीखेंगे कि जुनाइट और मॉकिटो को एक साथ कैसे जोड़ा जाए। यहां हम एक गणित एप्लिकेशन बनाएंगे जो कि कैलकुलेटर गणितीय सेवा का उपयोग करता है, जैसे कि इसके अलावा, घटाव, गुणा और भाग जैसे बुनियादी गणितीय कार्य करता है।

हम कैलक्यूलेटर सेवा की डमी कार्यान्वयन का मजाक उड़ाने के लिए मॉकिटो का उपयोग करेंगे। इसके अलावा, हमने JUnit और Mockito दोनों के साथ अपनी अनुकूलता दिखाने के लिए एनोटेशन का व्यापक उपयोग किया है।

प्रक्रिया को चरण-दर-चरण तरीके से नीचे चर्चा की गई है।

Step 1 − Create an interface called CalculatorService to provide mathematical functions

File: 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);
}

Step 2 − Create a JAVA class to represent MathApplication

File: 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);
   }
}

Step 3 − Test the MathApplication class

चलो MathApplication वर्ग का परीक्षण करते हैं, इसमें एक कैलकुलेटर कैलकुलेटर का मजाक उड़ाते हुए। मॉक मॉकिटो द्वारा बनाया जाएगा।

File: 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);
   }
}

Step 4 − Create a class to execute to test cases

TestRunner नामक एक जावा क्लास फ़ाइल बनाएँ C> Mockito_WORKSPACE परीक्षण मामले को निष्पादित करने के लिए।

File: 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());
   }
}

Step 5 − Verify the Result

उपयोग करने वाली कक्षाओं को संकलित करें javac संकलक निम्नानुसार है -

C:\Mockito_WORKSPACE>javac CalculatorService.java MathApplication.
   java MathApplicationTester.java TestRunner.java

अब परिणाम देखने के लिए टेस्ट रनर दौड़ें -

C:\Mockito_WORKSPACE>java TestRunner

आउटपुट सत्यापित करें।

true

JUnit के बारे में अधिक जानने के लिए, कृपया ट्यूटोरियल बिंदु पर JUnit ट्यूटोरियल देखें।

मॉकिटो विधियों का उपयोग करके एक मॉक ऑब्जेक्ट के लिए एक कार्यक्षमता जोड़ता है when()। निम्नलिखित कोड स्निपेट पर एक नज़र डालें।

//add the behavior of calc service to add two numbers
when(calcService.add(10.0,20.0)).thenReturn(30.00);

यहां हमने मॉकिटो को 10 और 20 को जोड़ने का व्यवहार देने का निर्देश दिया है add उसकि विधि calcService और परिणामस्वरूप, 30.00 का मान लौटाने के लिए।

इस समय, मॉक ने व्यवहार को दर्ज किया और एक काम करने वाली नकली वस्तु है।

//add the behavior of calc service to add two numbers
when(calcService.add(10.0,20.0)).thenReturn(30.00);

उदाहरण

Step 1 − Create an interface called CalculatorService to provide mathematical functions

File: 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);
}

Step 2 − Create a JAVA class to represent MathApplication

File: 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);
   }
}

Step 3 − Test the MathApplication class

चलो MathApplication वर्ग का परीक्षण करते हैं, इसमें एक कैलकुलेटर कैलकुलेटर का मजाक उड़ाते हुए। मॉक मॉकिटो द्वारा बनाया जाएगा।

File: 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);
   }
}

Step 4 − Execute test cases

TestRunner नामक एक जावा क्लास फ़ाइल बनाएँ C:\>Mockito_WORKSPACE परीक्षण मामले को निष्पादित करने के लिए।

File: 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());
   }
}

Step 5 − Verify the Result

उपयोग करने वाली कक्षाओं को संकलित करें javac संकलक निम्नानुसार है -

C:\Mockito_WORKSPACE>javac CalculatorService.java MathApplication.
   java MathApplicationTester.java TestRunner.java

अब परिणाम देखने के लिए टेस्ट रनर दौड़ें -

C:\Mockito_WORKSPACE>java TestRunner

आउटपुट सत्यापित करें।

true

मॉकिटो यह सुनिश्चित कर सकता है कि एक मॉक विधि को पुष्ट तर्क के साथ बुलाया जा रहा है या नहीं। यह का उपयोग करके किया जाता हैverify()तरीका। निम्नलिखित कोड स्निपेट पर एक नज़र डालें।

//test the add functionality
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);

उदाहरण - सत्यापित () एक ही तर्क के साथ

Step 1 − Create an interface called CalculatorService to provide mathematical functions

File: 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);
}

Step 2 − Create a JAVA class to represent MathApplication

File: 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);
   }
}

Step 3 − Test the MathApplication class

चलो MathApplication वर्ग का परीक्षण करते हैं, इसमें एक कैलकुलेटर कैलकुलेटर का मजाक उड़ाते हुए। मॉक मॉकिटो द्वारा बनाया जाएगा।

File: 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 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(calcService.add(10.0, 20.0),30.0,0);

       
      //verify the behavior
      verify(calcService).add(10.0, 20.0);
   }
}

Step 4 − Execute test cases

TestRunner नामक एक जावा क्लास फ़ाइल बनाएँ C:\> Mockito_WORKSPACE परीक्षण मामले को निष्पादित करने के लिए।

File: 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());
   }
}

Step 5 − Verify the Result

उपयोग करने वाली कक्षाओं को संकलित करें javac संकलक निम्नानुसार है -

C:\Mockito_WORKSPACE>javac CalculatorService.java MathApplication.
   java MathApplicationTester.java TestRunner.java

अब परिणाम देखने के लिए टेस्ट रनर चलाएं

C:\Mockito_WORKSPACE>java TestRunner

आउटपुट सत्यापित करें।

true

उदाहरण - सत्यापित () विभिन्न तर्कों के साथ

Step 1 − Create an interface CalculatorService to provide mathematical functions

File: 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);
}

Step 2 − Create a JAVA class to represent MathApplication

File: 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);
   }
}

Step 3 − Test the MathApplication class

चलो MathApplication वर्ग का परीक्षण करते हैं, इसमें एक कैलकुलेटर कैलकुलेटर का मजाक उड़ाते हुए। मॉक मॉकिटो द्वारा बनाया जाएगा।

File: 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 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(calcService.add(10.0, 20.0),30.0,0);

       
      //verify the behavior
      verify(calcService).add(20.0, 30.0);
   }
}

Step 4 − Execute test cases

TestRunner नामक एक जावा क्लास फ़ाइल बनाएँ C:\> Mockito_WORKSPACE परीक्षण मामले को निष्पादित करने के लिए।

File: 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());
   }
}

Step 5 − Verify the Result

उपयोग करने वाली कक्षाओं को संकलित करें 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

मॉकिटो एक विशेष पद्धति पर किए जाने वाले कॉल की संख्या पर एक विशेष जांच प्रदान करता है। मान लीजिए कि MathApplication को केवल एक बार कैलक्यूलेटरService.serviceUsed () विधि को कॉल करना चाहिए, फिर उसे एक से अधिक बार कैलक्यूलेटरService.serviceUsed () कॉल करने में सक्षम नहीं होना चाहिए।

//add the behavior of calc service to add two numbers
when(calcService.add(10.0,20.0)).thenReturn(30.00);

//limit the method call to 1, no less and no more calls are allowed
verify(calcService, times(1)).add(10.0, 20.0);

निम्नानुसार कैलक्यूलेटर सेवा इंटरफ़ेस बनाएँ।

File: 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);
}

उदाहरण

Step 1 − Create an interface called CalculatorService to provide mathematical functions

File: 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);
}

Step 2 − Create a JAVA class to represent MathApplication

File: 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);
   }
}

Step 3 − Test the MathApplication class

चलो MathApplication वर्ग का परीक्षण करते हैं, इसमें एक कैलकुलेटर कैलकुलेटर का मजाक उड़ाते हुए। मॉक मॉकिटो द्वारा बनाया जाएगा।

File: MathApplicationTester.java

import static org.mockito.Mockito.verify;
import static org.mockito.Mockito.when;
import static org.mockito.Mockito.times;
import static org.mockito.Mockito.never;

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);
		
      //add the behavior of calc service to subtract two numbers
      when(calcService.subtract(20.0,10.0)).thenReturn(10.00);
      
      //test the add functionality
      Assert.assertEquals(mathApplication.add(10.0, 20.0),30.0,0);
      Assert.assertEquals(mathApplication.add(10.0, 20.0),30.0,0);
      Assert.assertEquals(mathApplication.add(10.0, 20.0),30.0,0);
      
      //test the subtract functionality
      Assert.assertEquals(mathApplication.subtract(20.0, 10.0),10.0,0.0);
      
      //default call count is 1 
      verify(calcService).subtract(20.0, 10.0);
      
      //check if add function is called three times
      verify(calcService, times(3)).add(10.0, 20.0);
      
      //verify that method was never called on a mock
      verify(calcService, never()).multiply(10.0,20.0);
   }
}

Step 4 − Execute test cases

TestRunner नामक एक जावा क्लास फ़ाइल बनाएँ C:\> Mockito_WORKSPACE परीक्षण मामले को निष्पादित करने के लिए।

File: 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());
   }
}

Step 5 − Verify the Result

उपयोग करने वाली कक्षाओं को संकलित करें javac संकलक निम्नानुसार है -

C:\Mockito_WORKSPACE>javac CalculatorService.java MathApplication.
   java MathApplicationTester.java TestRunner.java

अब परिणाम देखने के लिए टेस्ट रनर दौड़ें -

C:\Mockito_WORKSPACE>java TestRunner

आउटपुट सत्यापित करें।

true

Mockito अपेक्षित कॉल काउंट को अलग करने के लिए निम्नलिखित अतिरिक्त तरीके प्रदान करता है।

  • atLeast (int min) - न्यूनतम कॉल की उम्मीद है।

  • atLeastOnce () - कम से कम एक कॉल की उम्मीद है।

  • atMost (int max) - अधिकतम कॉल की अपेक्षा करता है।

उदाहरण

Step 1 − Create an interface CalculatorService to provide mathematical functions

File: 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);
}

Step 2 − Create a JAVA class to represent MathApplication

File: 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);
   }
}

Step 3 − Test the MathApplication class

चलो MathApplication वर्ग का परीक्षण करते हैं, इसमें एक कैलकुलेटर कैलकुलेटर का मजाक उड़ाते हुए। मॉक मॉकिटो द्वारा बनाया जाएगा।

File: MathApplicationTester.java

import static org.mockito.Mockito.verify;
import static org.mockito.Mockito.when;
import static org.mockito.Mockito.atLeastOnce;
import static org.mockito.Mockito.atLeast;
import static org.mockito.Mockito.atMost;

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);
		
      //add the behavior of calc service to subtract two numbers
      when(calcService.subtract(20.0,10.0)).thenReturn(10.00);
      
      //test the add functionality
      Assert.assertEquals(mathApplication.add(10.0, 20.0),30.0,0);
      Assert.assertEquals(mathApplication.add(10.0, 20.0),30.0,0);
      Assert.assertEquals(mathApplication.add(10.0, 20.0),30.0,0);
      
      //test the subtract functionality
      Assert.assertEquals(mathApplication.subtract(20.0, 10.0),10.0,0.0);
      
      //check a minimum 1 call count
      verify(calcService, atLeastOnce()).subtract(20.0, 10.0);
      
      //check if add function is called minimum 2 times
      verify(calcService, atLeast(2)).add(10.0, 20.0);
      
      //check if add function is called maximum 3 times
      verify(calcService, atMost(3)).add(10.0,20.0);     
   }
}

Step 4 − Execute test cases

TestRunner नामक एक जावा क्लास फ़ाइल बनाएँ C:\> Mockito_WORKSPACE परीक्षण मामले को निष्पादित करने के लिए

File: 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());
   }
}

Step 5 − Verify the Result

उपयोग करने वाली कक्षाओं को संकलित करें javac संकलक निम्नानुसार है -

C:\Mockito_WORKSPACE>javac CalculatorService.java MathApplication.
   java MathApplicationTester.java TestRunner.java

अब परिणाम देखने के लिए टेस्ट रनर दौड़ें -

C:\Mockito_WORKSPACE>java TestRunner

आउटपुट सत्यापित करें।

true

मॉकिटो अपवादों को फेंकने के लिए एक नकली की क्षमता प्रदान करता है, इसलिए अपवाद हैंडलिंग का परीक्षण किया जा सकता है। निम्नलिखित कोड स्निपेट पर एक नज़र डालें।

//add the behavior to throw exception
doThrow(new Runtime Exception("divide operation not implemented"))
   .when(calcService).add(10.0,20.0);

यहां हमने मॉक ऑब्जेक्ट में एक अपवाद खंड जोड़ा है। MathApplication अपनी ऐड मेथड का उपयोग करके कैल्सेव्स का उपयोग करता है और जब भी कैल्सेवस.एड () विधि को मॉक किया जाता है तो मॉक एक रनटाइम एक्सेप्शन फेंकता है।

उदाहरण

Step 1 − Create an interface called CalculatorService to provide mathematical functions

File: 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);
}

Step 2 − Create a JAVA class to represent MathApplication

File: 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);
   }
}

Step 3 − Test the MathApplication class

चलो MathApplication वर्ग का परीक्षण करते हैं, इसमें एक कैलकुलेटर कैलकुलेटर का मजाक उड़ाते हुए। मॉक मॉकिटो द्वारा बनाया जाएगा।

File: MathApplicationTester.java

import static org.mockito.Mockito.doThrow;

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(MockitoRunner.class)
public class MathApplicationTester {
	
   // @TestSubject annotation is used to identify class 
      which is going to use the mock object
   @TestSubject
   MathApplication mathApplication = new MathApplication();

   //@Mock annotation is used to create the mock object to be injected
   @Mock
   CalculatorService calcService;

   @Test(expected = RuntimeException.class)
   public void testAdd(){
      //add the behavior to throw exception
      doThrow(new RuntimeException("Add operation not implemented"))
         .when(calcService).add(10.0,20.0);

      //test the add functionality
      Assert.assertEquals(mathApplication.add(10.0, 20.0),30.0,0); 
   }
}

Step 4 − Execute test cases

TestRunner नामक एक जावा क्लास फ़ाइल बनाएँ C:\> Mockito_WORKSPACE परीक्षण मामले को निष्पादित करने के लिए।

File: 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());
   }
}

Step 5 − Verify the Result

उपयोग करने वाली कक्षाओं को संकलित करें javac संकलक निम्नानुसार है -

C:\Mockito_WORKSPACE>javac CalculatorService.java MathApplication.
   java MathApplicationTester.java TestRunner.java

अब परिणाम देखने के लिए टेस्ट रनर दौड़ें -

C:\Mockito_WORKSPACE>java TestRunner

आउटपुट सत्यापित करें।

testAdd(MathApplicationTester): Add operation not implemented
false

अब तक, हमने मॉक बनाने के लिए एनोटेशन का उपयोग किया है। नकली वस्तुओं को बनाने के लिए मॉकिटो विभिन्न तरीके प्रदान करता है। मॉक () विधि कॉल के आदेश के बारे में परेशान किए बिना मॉक बनाता है जो मॉक अपनी कार्रवाई के नियत समय में बनाने जा रहा है।

वाक्य - विन्यास

calcService = mock(CalculatorService.class);

उदाहरण

Step 1 − Create an interface called CalculatorService to provide mathematical functions

File: 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);
}

Step 2 − Create a JAVA class to represent MathApplication

File: 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);
   }
}

Step 3 − Test the MathApplication class

चलो MathApplication वर्ग का परीक्षण करते हैं, इसमें एक कैलकुलेटर कैलकुलेटर का मजाक उड़ाते हुए। मॉक मॉकिटो द्वारा बनाया जाएगा।

यहाँ हमने दो मॉक मेथड कॉल्स जोड़े हैं, ऐड () और सबट्रेक्ट (), मॉक ऑब्जेक्ट जब (तब) के माध्यम से। हालाँकि, परीक्षण के दौरान, हमने कॉल जोड़ने () से पहले घटाना () कहा है। जब हम create () का उपयोग करके एक नकली वस्तु बनाते हैं, तो विधि के निष्पादन का क्रम मायने नहीं रखता है।

File: MathApplicationTester.java

package com.tutorialspoint.mock;

import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.verify;
import static org.mockito.Mockito.when;

import org.junit.Assert;
import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.mockito.runners.MockitoJUnitRunner;

// @RunWith attaches a runner with the test class to initialize the test data
@RunWith(MockitoJUnitRunner.class)
public class MathApplicationTester {
	
   private MathApplication mathApplication;
   private CalculatorService calcService;

   @Before
   public void setUp(){
      mathApplication = new MathApplication();
      calcService = mock(CalculatorService.class);
      mathApplication.setCalculatorService(calcService);
   }

   @Test
   public void testAddAndSubtract(){

      //add the behavior to add numbers
      when(calcService.add(20.0,10.0)).thenReturn(30.0);

      //subtract the behavior to subtract numbers
      when(calcService.subtract(20.0,10.0)).thenReturn(10.0);

      //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
      verify(calcService).add(20.0,10.0);
      verify(calcService).subtract(20.0,10.0);
   }
}

Step 4 − Execute test cases

TestRunner नामक एक जावा क्लास फ़ाइल बनाएँ C:\> Mockito_WORKSPACE परीक्षण मामले को निष्पादित करने के लिए।

File: 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());
   }
}

Step 5 − Verify the Result

उपयोग करने वाली कक्षाओं को संकलित करें javac संकलक निम्नानुसार है -

C:\Mockito_WORKSPACE>javac CalculatorService.java MathApplication.
   java MathApplicationTester.java TestRunner.java

अब परिणाम देखने के लिए टेस्ट रनर दौड़ें -

C:\Mockito_WORKSPACE>java TestRunner

आउटपुट सत्यापित करें।

true

मॉकिटो इनवर्टर वर्ग प्रदान करता है जो विधि कॉल के क्रम का ध्यान रखता है जो मॉक अपनी कार्रवाई के नियत समय में बनाने जा रहा है।

वाक्य - विन्यास

//create an inOrder verifier for a single mock
InOrder inOrder = inOrder(calcService);

//following will make sure that add is first called then subtract is called.
inOrder.verify(calcService).add(20.0,10.0);
inOrder.verify(calcService).subtract(20.0,10.0);

उदाहरण

Step 1 − Create an interface called CalculatorService to provide mathematical functions

File: 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);
}

Step 2 − Create a JAVA class to represent MathApplication

File: 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);
   }
}

Step 3 − Test the MathApplication class

चलो MathApplication वर्ग का परीक्षण करते हैं, इसमें एक कैलकुलेटर कैलकुलेटर का मजाक उड़ाते हुए। मॉक मॉकिटो द्वारा बनाया जाएगा।

यहाँ हमने दो मॉक मेथड कॉल्स जोड़े हैं, () और घटाना (), जब मॉक ऑब्जेक्ट को जब () के माध्यम से जोड़ा गया है। हालाँकि, परीक्षण के दौरान, हमने कॉल जोड़ने () से पहले घटाना () कहा है। जब हम मॉकिटो का उपयोग करके एक नकली वस्तु बनाते हैं, तो विधि के निष्पादन का क्रम मायने नहीं रखता है। InOrder वर्ग का उपयोग करके, हम कॉल ऑर्डर सुनिश्चित कर सकते हैं।

File: MathApplicationTester.java

import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.verify;
import static org.mockito.Mockito.when;
import static org.mockito.Mockito.inOrder;

import org.junit.Assert;
import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.mockito.InOrder;
import org.mockito.runners.MockitoJUnitRunner;

// @RunWith attaches a runner with the test class to initialize the test data
@RunWith(MockitoJUnitRunner.class)
public class MathApplicationTester {
	
   private MathApplication mathApplication;
   private CalculatorService calcService;

   @Before
   public void setUp(){
      mathApplication = new MathApplication();
      calcService = mock(CalculatorService.class);
      mathApplication.setCalculatorService(calcService);
   }

   @Test
   public void testAddAndSubtract(){

      //add the behavior to add numbers
      when(calcService.add(20.0,10.0)).thenReturn(30.0);

      //subtract the behavior to subtract numbers
      when(calcService.subtract(20.0,10.0)).thenReturn(10.0);

      //test the add functionality
      Assert.assertEquals(mathApplication.add(20.0, 10.0),30.0,0);

      //test the subtract functionality
      Assert.assertEquals(mathApplication.subtract(20.0, 10.0),10.0,0);

      //create an inOrder verifier for a single mock
      InOrder inOrder = inOrder(calcService);

      //following will make sure that add is first called then subtract is called.
      inOrder.verify(calcService).subtract(20.0,10.0);
      inOrder.verify(calcService).add(20.0,10.0);
   }
}

Step 4 − Execute test cases

TestRunner नामक एक जावा क्लास फ़ाइल बनाएँ C:\> Mockito_WORKSPACE परीक्षण मामले को निष्पादित करने के लिए।

File: 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());
   }
}

Step 5 − Verify the Result

उपयोग करने वाली कक्षाओं को संकलित करें javac संकलक निम्नानुसार है -

C:\Mockito_WORKSPACE>javac CalculatorService.java MathApplication.
   java MathApplicationTester.java TestRunner.java

अब परिणाम देखने के लिए टेस्ट रनर दौड़ें -

C:\Mockito_WORKSPACE>java TestRunner

आउटपुट सत्यापित करें।

testAddAndSubtract(MathApplicationTester): 
Verification in order failure
Wanted but not invoked:
calculatorService.add(20.0, 10.0);
-> at MathApplicationTester.testAddAndSubtract(MathApplicationTester.java:48)
Wanted anywhere AFTER following interaction:
calculatorService.subtract(20.0, 10.0);
-> at MathApplication.subtract(MathApplication.java:13)
false

मॉकिटो एक उत्तर इंटरफ़ेस प्रदान करता है जो सामान्य इंटरफ़ेस के साथ स्टबिंग की अनुमति देता है।

वाक्य - विन्यास

//add the behavior to add numbers
when(calcService.add(20.0,10.0)).thenAnswer(new Answer<Double>() {
   @Override
   public Double answer(InvocationOnMock invocation) throws Throwable {
      //get the arguments passed to mock
      Object[] args = invocation.getArguments();
      //get the mock 
      Object mock = invocation.getMock();	
      //return the result
      return 30.0;
   }
});

उदाहरण

Step 1 − Create an interface called CalculatorService to provide mathematical functions

File: 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);
}

Step 2 − Create a JAVA class to represent MathApplication

File: 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);
   }
}

Step 3 − Test the MathApplication class

चलो MathApplication वर्ग का परीक्षण करते हैं, इसमें एक कैलकुलेटर कैलकुलेटर का मजाक उड़ाते हुए। मॉक मॉकिटो द्वारा बनाया जाएगा।

यहां हमने मॉक ऑब्जेक्ट (जब) ​​के माध्यम से एक मॉक विधि कॉल, ऐड () जोड़ा है। हालाँकि, परीक्षण के दौरान, हमने कॉल जोड़ने () से पहले घटाना () कहा है। जब हम Mockito.createStrictMock () का उपयोग करके एक नकली वस्तु बनाते हैं, तो विधि के निष्पादन का क्रम मायने रखता है।

File: MathApplicationTester.java

import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.verify;
import static org.mockito.Mockito.when;
import static org.mockito.Mockito.inOrder;

import org.junit.Assert;
import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.mockito.InOrder;
import org.mockito.runners.MockitoJUnitRunner;

// @RunWith attaches a runner with the test class to initialize the test data
@RunWith(MockitoJUnitRunner.class)
public class MathApplicationTester {
	
   private MathApplication mathApplication;
   private CalculatorService calcService;

   @Before
   public void setUp(){
      mathApplication = new MathApplication();
      calcService = mock(CalculatorService.class);
      mathApplication.setCalculatorService(calcService);
   }

   @Test
   public void testAdd(){

      //add the behavior to add numbers
      when(calcService.add(20.0,10.0)).thenAnswer(new Answer<Double>() {

         @Override
         public Double answer(InvocationOnMock invocation) throws Throwable {
            //get the arguments passed to mock
            Object[] args = invocation.getArguments();
				
            //get the mock 
            Object mock = invocation.getMock();	
				
            //return the result
            return 30.0;
         }
      });

      //test the add functionality
      Assert.assertEquals(mathApplication.add(20.0, 10.0),30.0,0);
   }
}

Step 4 − Execute test cases

TestRunner नामक एक जावा क्लास फ़ाइल बनाएँ C:\> Mockito_WORKSPACE परीक्षण मामले को निष्पादित करने के लिए।

File: 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());
   }
}

Step 5 − Verify the Result

उपयोग करने वाली कक्षाओं को संकलित करें javac संकलक निम्नानुसार है -

C:\Mockito_WORKSPACE>javac CalculatorService.java MathApplication.
   java MathApplicationTester.java TestRunner.java

अब परिणाम देखने के लिए टेस्ट रनर दौड़ें -

C:\Mockito_WORKSPACE>java TestRunner

आउटपुट सत्यापित करें।

true

मॉकिटो वास्तविक वस्तुओं पर जासूसी करने का विकल्प प्रदान करता है। जब जासूसी कहलाती है, तब वास्तविक वस्तु की वास्तविक विधि कहलाती है।

वाक्य - विन्यास

//create a spy on actual object
calcService = spy(calculator);

//perform operation on real object
//test the add functionality
Assert.assertEquals(mathApplication.add(20.0, 10.0),30.0,0);

उदाहरण

Step 1 − Create an interface called CalculatorService to provide mathematical functions

File: 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);
}

Step 2 − Create a JAVA class to represent MathApplication

File: 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);
   }
}

Step 3 − Test the MathApplication class

चलो MathApplication वर्ग का परीक्षण करते हैं, इसमें एक कैलकुलेटर कैलकुलेटर का मजाक उड़ाते हुए। मॉक मॉकिटो द्वारा बनाया जाएगा।

यहां हमने मॉक ऑब्जेक्ट (जब) ​​के माध्यम से एक मॉक विधि कॉल, ऐड () जोड़ा है। हालाँकि, परीक्षण के दौरान, हमने कॉल जोड़ने () से पहले घटाना () कहा है। जब हम Mockito.createStrictMock () का उपयोग करके एक नकली वस्तु बनाते हैं, तो विधि के निष्पादन का क्रम मायने रखता है।

File: MathApplicationTester.java

import static org.mockito.Mockito.spy;

import org.junit.Assert;
import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.mockito.runners.MockitoJUnitRunner;

// @RunWith attaches a runner with the test class to initialize the test data
@RunWith(MockitoJUnitRunner.class)
public class MathApplicationTester {
	
   private MathApplication mathApplication;
   private CalculatorService calcService;

   @Before
   public void setUp(){
      mathApplication = new MathApplication();
      Calculator calculator = new Calculator();
      calcService = spy(calculator);
      mathApplication.setCalculatorService(calcService);	     
   }

   @Test
   public void testAdd(){

      //perform operation on real object
      //test the add functionality
      Assert.assertEquals(mathApplication.add(20.0, 10.0),30.0,0);
   }

   class Calculator implements CalculatorService {
      @Override
      public double add(double input1, double input2) {
         return input1 + input2;
      }

      @Override
      public double subtract(double input1, double input2) {
         throw new UnsupportedOperationException("Method not implemented yet!");
      }

      @Override
      public double multiply(double input1, double input2) {
         throw new UnsupportedOperationException("Method not implemented yet!");
      }

      @Override
      public double divide(double input1, double input2) {
         throw new UnsupportedOperationException("Method not implemented yet!");
      }
   }
}

Step 4 − Execute test cases

TestRunner नामक एक जावा क्लास फ़ाइल बनाएँ C:\> Mockito_WORKSPACE परीक्षण मामले को निष्पादित करने के लिए।

File: 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());
   }
}

Step 5 − Verify the Result

उपयोग करने वाली कक्षाओं को संकलित करें javac संकलक निम्नानुसार है -

C:\Mockito_WORKSPACE>javac CalculatorService.java MathApplication.
   java MathApplicationTester.java TestRunner.java

अब परिणाम देखने के लिए टेस्ट रनर दौड़ें -

C:\Mockito_WORKSPACE>java TestRunner

आउटपुट सत्यापित करें।

true

मॉकिटो एक नकली को रीसेट करने की क्षमता प्रदान करता है ताकि बाद में इसका पुन: उपयोग किया जा सके। निम्नलिखित कोड स्निपेट पर एक नज़र डालें।

//reset mock
reset(calcService);

यहां हमने मॉक ऑब्जेक्ट को रीसेट कर दिया है। MathApplication कैल्क सर्विस का उपयोग करता है और नकली को रीसेट करने के बाद, नकली विधि का उपयोग करने से परीक्षण विफल हो जाएगा।

उदाहरण

Step 1 − Create an interface called CalculatorService to provide mathematical functions

File: 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);
}

Step 2 − Create a JAVA class to represent MathApplication

File: 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);
   }
}

Step 3 − Test the MathApplication class

चलो MathApplication वर्ग का परीक्षण करते हैं, इसमें एक कैलकुलेटर कैलकुलेटर का मजाक उड़ाते हुए। मॉक मॉकिटो द्वारा बनाया जाएगा।

File: MathApplicationTester.java

package com.tutorialspoint.mock;

import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.when;
import static org.mockito.Mockito.reset;

import org.junit.Assert;
import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.mockito.runners.MockitoJUnitRunner;

// @RunWith attaches a runner with the test class to initialize the test data
@RunWith(MockitoJUnitRunner.class)
public class MathApplicationTester {
	
   private MathApplication mathApplication;
   private CalculatorService calcService;

   @Before
   public void setUp(){
      mathApplication = new MathApplication();
      calcService = mock(CalculatorService.class);
      mathApplication.setCalculatorService(calcService);
   }

   @Test
   public void testAddAndSubtract(){

      //add the behavior to add numbers
      when(calcService.add(20.0,10.0)).thenReturn(30.0);
  
      //test the add functionality
      Assert.assertEquals(mathApplication.add(20.0, 10.0),30.0,0);

      //reset the mock	  
      reset(calcService);

      //test the add functionality after resetting the mock
      Assert.assertEquals(mathApplication.add(20.0, 10.0),30.0,0);   
   }
}

Step 4 − Execute test cases

TestRunner नामक एक जावा क्लास फ़ाइल बनाएँ C:\> Mockito_WORKSPACE परीक्षण मामले को निष्पादित करने के लिए।

File: 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());
   }
}

Step 5 − Verify the Result

उपयोग करने वाली कक्षाओं को संकलित करें javac संकलक निम्नानुसार है -

C:\Mockito_WORKSPACE>javac CalculatorService.java MathApplication.
   java MathApplicationTester.java TestRunner.java

अब परिणाम देखने के लिए टेस्ट रनर दौड़ें -

C:\Mockito_WORKSPACE>java TestRunner

आउटपुट सत्यापित करें।

testAddAndSubtract(MathApplicationTester): expected:<0.0> but was:<30.0>
false

व्यवहार प्रेरित विकास लेखन परीक्षणों का उपयोग करने की एक शैली है given, when तथा thenपरीक्षण विधियों के रूप में प्रारूपित करें। मॉकिटो ऐसा करने के लिए विशेष तरीके प्रदान करता है। निम्नलिखित कोड स्निपेट पर एक नज़र डालें।

//Given
given(calcService.add(20.0,10.0)).willReturn(30.0);

//when
double result = calcService.add(20.0,10.0);

//then
Assert.assertEquals(result,30.0,0);

यहां हम उपयोग कर रहे हैं given इसके बजाय BDDMockito वर्ग की विधि when उसकि विधि ।

उदाहरण

Step 1 − Create an interface called CalculatorService to provide mathematical functions

File: 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);
}

Step 2 − Create a JAVA class to represent MathApplication

File: 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);
   }
}

Step 3 − Test the MathApplication class

चलो MathApplication वर्ग का परीक्षण करते हैं, इसमें एक कैलकुलेटर कैलकुलेटर का मजाक उड़ाते हुए। मॉक मॉकिटो द्वारा बनाया जाएगा।

File: MathApplicationTester.java

package com.tutorialspoint.mock;

import static org.mockito.BDDMockito.*;

import org.junit.Assert;
import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.mockito.runners.MockitoJUnitRunner;

// @RunWith attaches a runner with the test class to initialize the test data
@RunWith(MockitoJUnitRunner.class)
public class MathApplicationTester {
	
   private MathApplication mathApplication;
   private CalculatorService calcService;

   @Before
   public void setUp(){
      mathApplication = new MathApplication();
      calcService = mock(CalculatorService.class);
      mathApplication.setCalculatorService(calcService);
   }

   @Test
   public void testAdd(){

      //Given
      given(calcService.add(20.0,10.0)).willReturn(30.0);

      //when
      double result = calcService.add(20.0,10.0);

      //then
      Assert.assertEquals(result,30.0,0);   
   }
}

Step 4 − Execute test cases

TestRunner नामक एक जावा क्लास फ़ाइल बनाएँ C:\> Mockito_WORKSPACE परीक्षण मामले को निष्पादित करने के लिए।

File: 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());
   }
}

Step 5 − Verify the Result

उपयोग करने वाली कक्षाओं को संकलित करें javac संकलक निम्नानुसार है -

C:\Mockito_WORKSPACE>javac CalculatorService.java MathApplication.
   java MathApplicationTester.java TestRunner.java

अब परिणाम देखने के लिए टेस्ट रनर दौड़ें -

C:\Mockito_WORKSPACE>java TestRunner

आउटपुट सत्यापित करें।

true

Mockito परीक्षण करने के लिए एक विशेष टाइमआउट विकल्प प्रदान करता है यदि एक विधि को निर्धारित समय सीमा के भीतर कहा जाता है।

वाक्य - विन्यास

//passes when add() is called within 100 ms.
verify(calcService,timeout(100)).add(20.0,10.0);

उदाहरण

Step 1 − Create an interface called CalculatorService to provide mathematical functions

File: 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);
}

Step 2 − Create a JAVA class to represent MathApplication

File: 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);
   }
}

Step 3 − Test the MathApplication class

चलो MathApplication वर्ग का परीक्षण करते हैं, इसमें एक कैलकुलेटर कैलकुलेटर का मजाक उड़ाते हुए। मॉक मॉकिटो द्वारा बनाया जाएगा।

File: MathApplicationTester.java

package com.tutorialspoint.mock;

import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.verify;
import static org.mockito.Mockito.when;

import org.junit.Assert;
import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.mockito.runners.MockitoJUnitRunner;

// @RunWith attaches a runner with the test class to initialize the test data
@RunWith(MockitoJUnitRunner.class)
public class MathApplicationTester {
	
   private MathApplication mathApplication;
   private CalculatorService calcService;

   @Before
   public void setUp(){
      mathApplication = new MathApplication();
      calcService = mock(CalculatorService.class);
      mathApplication.setCalculatorService(calcService);
   }

   @Test
   public void testAddAndSubtract(){

      //add the behavior to add numbers
      when(calcService.add(20.0,10.0)).thenReturn(30.0);

      //subtract the behavior to subtract numbers
      when(calcService.subtract(20.0,10.0)).thenReturn(10.0);

      //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 add method to be completed within 100 ms
      verify(calcService, timeout(100)).add(20.0,10.0);
	  
      //invocation count can be added to ensure multiplication invocations
      //can be checked within given timeframe
      verify(calcService, timeout(100).times(1)).subtract(20.0,10.0);
   }
}

Step 4 − Execute test cases

TestRunner नामक एक जावा क्लास फ़ाइल बनाएँ C:\> Mockito_WORKSPACE परीक्षण मामले को निष्पादित करने के लिए।

File: 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());
   }
}

Step 5 − Verify the Result

उपयोग करने वाली कक्षाओं को संकलित करें javac संकलक निम्नानुसार है -

C:\Mockito_WORKSPACE>javac CalculatorService.java MathApplication.
   java MathApplicationTester.java TestRunner.java

अब परिणाम देखने के लिए टेस्ट रनर दौड़ें -

C:\Mockito_WORKSPACE>java TestRunner

आउटपुट सत्यापित करें।

true