JUnit - त्वरित गाइड

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

यूनिट परीक्षण दो तरीकों से किया जा सकता है - मैनुअल परीक्षण और स्वचालित परीक्षण।

मैनुअल परीक्षण स्वचालित परीक्षण
किसी भी उपकरण समर्थन के बिना मैन्युअल रूप से परीक्षण मामलों को निष्पादित करना मैन्युअल परीक्षण के रूप में जाना जाता है। उपकरण समर्थन लेना और स्वचालन उपकरण का उपयोग करके परीक्षण मामलों को निष्पादित करना स्वचालन परीक्षण के रूप में जाना जाता है।
Time-consuming and tedious - चूंकि मानव संसाधन द्वारा परीक्षण मामलों को निष्पादित किया जाता है, इसलिए यह बहुत धीमा और थकाऊ है। Fast - स्वचालन मानव संसाधन की तुलना में काफी तेजी से परीक्षण मामलों को चलाता है।
Huge investment in human resources - चूंकि परीक्षण मामलों को मैन्युअल रूप से निष्पादित करने की आवश्यकता होती है, इसलिए मैन्युअल परीक्षण में अधिक परीक्षकों की आवश्यकता होती है। Less investment in human resources - स्वचालन मामलों का उपयोग करके परीक्षण मामलों को निष्पादित किया जाता है, इसलिए स्वचालन परीक्षण में कम संख्या में परीक्षकों की आवश्यकता होती है।
Less reliable - मैनुअल परीक्षण कम विश्वसनीय है, क्योंकि इसमें मानवीय त्रुटियों के लिए जिम्मेदार है। More reliable - स्वचालन परीक्षण सटीक और विश्वसनीय हैं।
Non-programmable - छिपी जानकारी लाने के लिए परिष्कृत परीक्षणों को लिखने के लिए कोई प्रोग्रामिंग नहीं की जा सकती है। Programmable - परीक्षक छिपी जानकारी को बाहर लाने के लिए परिष्कृत परीक्षण कर सकते हैं।

JUnit क्या है?

JUnit जावा प्रोग्रामिंग लैंग्वेज के लिए एक यूनिट टेस्टिंग फ्रेमवर्क है। यह एक महत्वपूर्ण भूमिका परीक्षण-संचालित विकास निभाता है, और इकाई परीक्षण ढांचे का एक परिवार है जिसे सामूहिक रूप से एक्सयूनिट के रूप में जाना जाता है।

JUnit "पहले परीक्षण फिर कोडिंग" के विचार को बढ़ावा देता है, जो कोड के एक टुकड़े के लिए परीक्षण डेटा सेट करने पर जोर देता है जिसे पहले परीक्षण किया जा सकता है और फिर कार्यान्वित किया जा सकता है। यह दृष्टिकोण "थोड़ा परीक्षण, थोड़ा कोड, थोड़ा परीक्षण, थोड़ा कोड" की तरह है। यह प्रोग्रामर की उत्पादकता और प्रोग्राम कोड की स्थिरता को बढ़ाता है, जो बदले में प्रोग्रामर पर तनाव और डिबगिंग पर खर्च किए गए समय को कम करता है।

JUnit की विशेषताएं

  • JUnit एक ओपन सोर्स फ्रेमवर्क है, जिसका उपयोग लेखन और परीक्षण चलाने के लिए किया जाता है।

  • परीक्षण विधियों की पहचान करने के लिए एनोटेशन प्रदान करता है।

  • अपेक्षित परिणामों के परीक्षण के लिए दावे प्रदान करता है।

  • परीक्षण चलाने के लिए परीक्षण धावक प्रदान करता है।

  • JUnit परीक्षण आपको तेजी से कोड लिखने की अनुमति देता है, जिससे गुणवत्ता बढ़ जाती है।

  • JUnit सुरुचिपूर्ण ढंग से सरल है। यह कम जटिल है और कम समय लेता है।

  • JUnit परीक्षण स्वचालित रूप से चलाए जा सकते हैं और वे अपने स्वयं के परिणामों की जांच करते हैं और तत्काल प्रतिक्रिया प्रदान करते हैं। परीक्षण के परिणामों की रिपोर्ट के माध्यम से मैन्युअल रूप से कंघी करने की कोई आवश्यकता नहीं है।

  • JUnit परीक्षण परीक्षण मामलों और अन्य परीक्षण सूट वाले टेस्ट सूट में आयोजित किए जा सकते हैं।

  • JUnit एक बार में परीक्षण प्रगति को दिखाता है जो हरा है यदि परीक्षण सुचारू रूप से चल रहा है, और परीक्षण विफल होने पर यह लाल हो जाता है।

यूनिट टेस्ट केस क्या है?

एक यूनिट टेस्ट केस कोड का एक हिस्सा है, जो यह सुनिश्चित करता है कि कोड का दूसरा हिस्सा (विधि) अपेक्षा के अनुरूप काम करता है। वांछित परिणामों को जल्दी से प्राप्त करने के लिए, एक परीक्षण रूपरेखा की आवश्यकता होती है। JUnit जावा प्रोग्रामिंग लैंग्वेज के लिए एक परफेक्ट यूनिट टेस्ट फ्रेमवर्क है।

एक औपचारिक लिखित इकाई परीक्षण मामला एक ज्ञात इनपुट और एक अपेक्षित आउटपुट की विशेषता है, जिसे परीक्षण निष्पादित होने से पहले काम किया जाता है। ज्ञात इनपुट को एक पूर्व शर्त का परीक्षण करना चाहिए और अपेक्षित आउटपुट को पोस्ट-कंडीशन का परीक्षण करना चाहिए।

प्रत्येक आवश्यकता के लिए कम से कम दो इकाई परीक्षण मामले होने चाहिए - एक सकारात्मक परीक्षण और एक नकारात्मक परीक्षण। यदि किसी आवश्यकता की उप-आवश्यकताएँ हैं, तो प्रत्येक उप-आवश्यकता के पास सकारात्मक और नकारात्मक के रूप में कम से कम दो परीक्षण मामले होने चाहिए।

स्थानीय पर्यावरण सेटअप

JUnit जावा के लिए एक ढांचा है, इसलिए सबसे पहली आवश्यकता आपके मशीन में JDK को स्थापित करने की है।

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

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

चरण 1: अपनी मशीन में जावा इंस्टॉलेशन को सत्यापित करें

सबसे पहले, कंसोल खोलें और आप जिस ऑपरेटिंग सिस्टम पर काम कर रहे हैं, उसके आधार पर एक जावा कमांड निष्पादित करें।

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

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

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

जावा संस्करण "1.8.0_101"

जावा (TM) एसई रनटाइम एनवायरनमेंट (बिल्ड 1.8.0_101)

लिनक्स

जावा संस्करण "1.8.0_101"

जावा (TM) एसई रनटाइम एनवायरनमेंट (बिल्ड 1.8.0_101)

मैक

जावा संस्करण "1.8.0_101"

जावा (TM) एसई रनटाइम एनवायरनमेंट (बिल्ड 1.8.0_101)

यदि आपके पास अपने सिस्टम पर जावा इंस्टॉल नहीं है, तो निम्न लिंक से जावा सॉफ्टवेयर डेवलपमेंट किट (एसडीके) डाउनलोड करें https://www.oracle.com। हम इस ट्यूटोरियल के लिए जावा 1.8.0_101 को स्थापित संस्करण मान रहे हैं।

चरण 2: जावा पर्यावरण सेट करें

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

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

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

ओएस उत्पादन
खिड़कियाँ तार लगाओ C:\Program Files\Java\jdk1.8.0_101\bin सिस्टम चर के अंत में, Path
लिनक्स निर्यात पथ = $PATH:$JAVA_HOME / bin /
मैक आवश्यक नहीं

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

चरण 3: JUnit पुरालेख डाउनलोड करें

JUnit जार फ़ाइल का नवीनतम संस्करण डाउनलोड करें http://www.junit.org। इस ट्यूटोरियल को लिखने के समय, हमने Junit-4.12.jar डाउनलोड किया है और इसे C: \> JUnit फ़ोल्डर में कॉपी किया है।

ओएस संग्रह का नाम
खिड़कियाँ junit4.12.jar
लिनक्स junit4.12.jar
मैक junit4.12.jar

चरण 4: सेट करें JUnit पर्यावरण

ठीक JUNIT_HOMEपर्यावरण चर को आधार निर्देशिका स्थान पर इंगित करने के लिए जहां JUNIT जार आपकी मशीन पर संग्रहीत है। मान लेते हैं कि हमने junit4.12.jar को JUNIT फ़ोल्डर में संग्रहीत किया है।

अनु क्रमांक ओएस और विवरण
1

Windows

पर्यावरण चर JUNIT_HOME को C: \ JUNIT पर सेट करें

2

Linux

निर्यात JUNIT_HOME = / usr / स्थानीय / JUNIT

3

Mac

निर्यात JUNIT_HOME = / लाइब्रेरी / JUNIT

चरण 5: CLASSPATH चर सेट करें

ठीक CLASSPATH पर्यावरण चर JUNIT जार स्थान को इंगित करने के लिए।

अनु क्रमांक ओएस और विवरण
1

Windows

परिवेश चर CLASSPATH को% CLASSPATH%;% JUNIT_HOME% \ junit4.12.jar; पर सेट करें।

2

Linux

निर्यात CLASSPATH = $CLASSPATH:$JUNIT_HOME / junit4.12.jar :.

3

Mac

निर्यात CLASSPATH = $CLASSPATH:$JUNIT_HOME / junit4.12.jar :.

चरण 6: टेस्ट JUnit सेटअप

में एक जावा वर्ग फ़ाइल नाम TestJunit बनाएँ C:\>JUNIT_WORKSPACE

import org.junit.Test;
import static org.junit.Assert.assertEquals;

public class TestJunit {
   @Test
	
   public void testAdd() {
      String str = "Junit is working fine";
      assertEquals("Junit is working fine",str);
   }
}

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

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(TestJunit.class);
		
      for (Failure failure : result.getFailures()) {
         System.out.println(failure.toString());
      }
		
      System.out.println(result.wasSuccessful());
   }
}

चरण 7: परिणाम सत्यापित करें

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

C:\JUNIT_WORKSPACE>javac TestJunit.java TestRunner.java

अब रिजल्ट देखने के लिए टेस्ट रनर दौड़ें -

C:\JUNIT_WORKSPACE>java TestRunner

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

true

JUnit एक है Regression Testing Frameworkजावा में इकाई परीक्षण को लागू करने के लिए डेवलपर्स द्वारा उपयोग किया जाता है, और प्रोग्रामिंग गति में तेजी लाने और कोड की गुणवत्ता में वृद्धि होती है। JUnit फ्रेमवर्क को निम्नलिखित में से किसी एक के साथ आसानी से एकीकृत किया जा सकता है -

  • Eclipse
  • Ant
  • Maven

JUnit टेस्ट फ्रेमवर्क की विशेषताएं

JUnit परीक्षण ढांचा निम्नलिखित महत्वपूर्ण विशेषताएं प्रदान करता है -

  • Fixtures
  • टेस्ट सूट
  • परीक्षण धावकों
  • JUnit कक्षाएं

फिक्स्चर

Fixturesपरीक्षण चलाने के लिए आधार रेखा के रूप में उपयोग की जाने वाली वस्तुओं के एक सेट की एक निश्चित स्थिति है। एक परीक्षण स्थिरता का उद्देश्य यह सुनिश्चित करना है कि एक प्रसिद्ध और निश्चित वातावरण है जिसमें परीक्षण चलाए जाते हैं ताकि परिणाम दोहराए जा सकें। इसमें शामिल हैं -

  • setUp () विधि, जो प्रत्येक परीक्षण आह्वान से पहले चलती है।
  • अश्रु () विधि, जो प्रत्येक परीक्षण विधि के बाद चलती है।

आइए एक उदाहरण देखें -

import junit.framework.*;

public class JavaTest extends TestCase {
   protected int value1, value2;
   
   // assigning the values
   protected void setUp(){
      value1 = 3;
      value2 = 3;
   }

   // test method to add two values
   public void testAdd(){
      double result = value1 + value2;
      assertTrue(result == 6);
   }
}

परीक्षण सूट

एक परीक्षण सूट कुछ इकाई परीक्षण मामलों को बंडल करता है और उन्हें एक साथ चलाता है। जुइनिट में, सुइट परीक्षण चलाने के लिए @RunWith और @Suite एनोटेशन दोनों का उपयोग किया जाता है। नीचे एक उदाहरण दिया गया है जो TestJunit1 और TestJunit2 परीक्षण कक्षाओं का उपयोग करता है।

import org.junit.runner.RunWith;
import org.junit.runners.Suite;

//JUnit Suite Test
@RunWith(Suite.class)

@Suite.SuiteClasses({ 
   TestJunit1.class ,TestJunit2.class
})

public class JunitTestSuite {
}
import org.junit.Test;
import org.junit.Ignore;
import static org.junit.Assert.assertEquals;

public class TestJunit1 {

   String message = "Robert";	
   MessageUtil messageUtil = new MessageUtil(message);
   
   @Test
   public void testPrintMessage() {	
      System.out.println("Inside testPrintMessage()");    
      assertEquals(message, messageUtil.printMessage());     
   }
}
import org.junit.Test;
import org.junit.Ignore;
import static org.junit.Assert.assertEquals;

public class TestJunit2 {

   String message = "Robert";	
   MessageUtil messageUtil = new MessageUtil(message);
 
   @Test
   public void testSalutationMessage() {
      System.out.println("Inside testSalutationMessage()");
      message = "Hi!" + "Robert";
      assertEquals(message,messageUtil.salutationMessage());
   }
}

परीक्षण धावकों

टेस्ट रनर का उपयोग परीक्षण मामलों को निष्पादित करने के लिए किया जाता है। यहाँ एक उदाहरण है जो परीक्षण वर्ग को मानता हैTestJunit पहले से ही मौजूद है।

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(TestJunit.class);
		
      for (Failure failure : result.getFailures()) {
         System.out.println(failure.toString());
      }
		
      System.out.println(result.wasSuccessful());
   }
}

JUnit क्लासेस

JUnit कक्षाएं महत्वपूर्ण कक्षाएं हैं, जिनका उपयोग JUnits के लेखन और परीक्षण में किया जाता है। कुछ महत्वपूर्ण वर्ग हैं -

  • Assert - मुखर विधियों का एक सेट होता है।

  • TestCase - एक परीक्षण मामला होता है जो कई परीक्षणों को चलाने के लिए स्थिरता को परिभाषित करता है।

  • TestResult - एक परीक्षण मामले को निष्पादित करने के परिणामों को इकट्ठा करने के तरीके शामिल हैं।

आइए अब हमारे पास JUnit का उपयोग करने की चरण-दर-चरण प्रक्रिया को प्रदर्शित करने के लिए एक मूल उदाहरण है।

एक क्लास बनाएँ

मैसेज यूटील.जवा में परीक्षण के लिए एक जावा क्लास बनाएं C:\>JUNIT_WORKSPACE

/*
* This class prints the given message on console.
*/

public class MessageUtil {

   private String message;

   //Constructor
   //@param message to be printed
	
   public MessageUtil(String message){
      this.message = message;
   }
      
   // prints the message
   public String printMessage(){
      System.out.println(message);
      return message;
   }   
}

टेस्ट केस क्लास बनाएं

  • एक जावा टेस्ट क्लास बनाएं, कहिए, TestJunit.java।
  • अपने परीक्षण वर्ग में एक परीक्षण विधि testPrintMessage () जोड़ें।
  • मेथड टेस्टप्रिंटमैसेज () में एनोटेशन @ टेस्ट को जोड़ें।
  • परीक्षण की स्थिति को लागू करें और JUnit के एपीआई का उपयोग करके स्थिति की जाँच करें।

एक जावा वर्ग फ़ाइल नाम TestJunit.java बनाएँ C:\>JUNIT_WORKSPACE

import org.junit.Test;
import static org.junit.Assert.assertEquals;

public class TestJunit {
	
   String message = "Hello World";	
   MessageUtil messageUtil = new MessageUtil(message);

   @Test
   public void testPrintMessage() {
      assertEquals(message,messageUtil.printMessage());
   }
}

टेस्ट रनर क्लास बनाएं

  • एक TestRunner जावा वर्ग बनाएँ।
  • उपरोक्त बनाए गए टेस्ट क्लास के टेस्ट केस को चलाने के लिए JUnit के JUnitCore क्लास के रनक्लास विधि का उपयोग करें।
  • परिणाम मामलों में चलाए जाने वाले परीक्षण मामलों का परिणाम प्राप्त करें।
  • परिणामी वस्तु के getFailures () पद्धति का उपयोग करके विफलता प्राप्त करें।
  • परिणाम ऑब्जेक्ट की wasSuccessful () पद्धति का उपयोग करके सफलता परिणाम प्राप्त करें।

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

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(TestJunit.class);
		
      for (Failure failure : result.getFailures()) {
         System.out.println(failure.toString());
      }
		
      System.out.println(result.wasSuccessful());
   }
}

मैसेज यूटिल, टेस्ट केस और टेस्ट रनर क्लासेस को javac का उपयोग करके संकलित करें।

C:\JUNIT_WORKSPACE>javac MessageUtil.java TestJunit.java TestRunner.java

अब टेस्ट रनर चलाएं, जो प्रदान किए गए टेस्ट केस क्लास में परिभाषित टेस्ट केस को चलाएगा।

C:\JUNIT_WORKSPACE>java TestRunner

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

Hello World
true

अब TestJunit को अपडेट करें C:\>JUNIT_WORKSPACEताकि परीक्षा में फेल हो जाए। संदेश स्ट्रिंग बदलें।

import org.junit.Test;
import static org.junit.Assert.assertEquals;

public class TestJunit {
	
   String message = "Hello World";	
   MessageUtil messageUtil = new MessageUtil(message);

   @Test
   public void testPrintMessage() {
      message = "New Word";
      assertEquals(message,messageUtil.printMessage());
   }
}

आइए शेष वर्गों को जैसा है वैसा ही रखें और उसी टेस्ट रनर को चलाने का प्रयास करें।

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(TestJunit.class);
		
      for (Failure failure : result.getFailures()) {
         System.out.println(failure.toString());
      }
		
      System.out.println(result.wasSuccessful());
   }
}

अब टेस्ट रनर चलाएं, जो प्रदान किए गए टेस्ट केस क्लास में परिभाषित टेस्ट केस को चलाएगा।

C:\JUNIT_WORKSPACE>java TestRunner

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

Hello World
testPrintMessage(TestJunit): expected:<[New Wor]d> but was:<[Hello Worl]d>
false

JUnit में सबसे महत्वपूर्ण पैकेज है junit.framework, जिसमें सभी मुख्य वर्ग शामिल हैं। कुछ महत्वपूर्ण वर्ग इस प्रकार हैं -

अनु क्रमांक। कक्षा का नाम कार्यक्षमता
1 ज़ोर मुखर तरीकों का एक सेट।
2 परीक्षण का मामला एक परीक्षण मामला कई परीक्षणों को चलाने के लिए स्थिरता को परिभाषित करता है।
3 परीक्षा परिणाम एक TestResult एक परीक्षण मामले को निष्पादित करने के परिणाम एकत्र करता है।
4 परीक्षण सूट एक TestSuite परीक्षणों का एक संयोजन है।

वर्ग जोर देते हैं

निम्नलिखित के लिए घोषणा है org.junit.Assert वर्ग -

public class Assert extends java.lang.Object

यह वर्ग परीक्षण लिखने के लिए उपयोगी जोर का एक सेट प्रदान करता है। केवल असफल दावे दर्ज किए जाते हैं। Assert वर्ग के कुछ महत्वपूर्ण तरीके इस प्रकार हैं -

अनु क्रमांक। तरीके और विवरण
1

void assertEquals(boolean expected, boolean actual)

जाँच करता है कि दो आदिम / वस्तुएँ समान हैं।

2

void assertFalse(boolean condition)

जाँचता है कि एक शर्त झूठी है।

3

void assertNotNull(Object object)

जाँचता है कि कोई वस्तु अशक्त नहीं है।

4

void assertNull(Object object)

जाँचता है कि कोई वस्तु अशक्त है।

5

void assertTrue(boolean condition)

जाँच करता है कि एक शर्त सही है।

6

void fail()

एक संदेश के साथ एक परीक्षण विफल रहता है।

आइए ऊपर दिए गए कुछ तरीकों का उपयोग एक उदाहरण में करें। TestJunit1.java नाम से एक जावा क्लास फ़ाइल बनाएँC:\>JUNIT_WORKSPACE

import org.junit.Test;
import static org.junit.Assert.*;

public class TestJunit1 {
   @Test
   public void testAdd() {
      //test data
      int num = 5;
      String temp = null;
      String str = "Junit is working fine";

      //check for equality
      assertEquals("Junit is working fine", str);
      
      //check for false condition
      assertFalse(num > 6);

      //check for not null value
      assertNotNull(temp);
   }
}

इसके बाद, नाम से एक java class फाइल बनाएं TestRunner1.java C: \> JUNIT_WORKSPACE परीक्षण मामले को निष्पादित करने के लिए।

import org.junit.runner.JUnitCore;
import org.junit.runner.Result;
import org.junit.runner.notification.Failure;

public class TestRunner1 {
   public static void main(String[] args) {
      Result result = JUnitCore.runClasses(TestJunit1.class);
		
      for (Failure failure : result.getFailures()) {
         System.out.println(failure.toString());
      }
		
      System.out.println(result.wasSuccessful());
   }
}

Javac का उपयोग करके टेस्ट केस और टेस्ट रनर कक्षाओं को संकलित करें।

C:\JUNIT_WORKSPACE>javac TestJunit1.java TestRunner1.java

अब टेस्ट रनर चलाएं, जो प्रदान किए गए टेस्ट केस क्लास में परिभाषित टेस्ट केस को चलाएगा।

C:\JUNIT_WORKSPACE>java TestRunner1

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

true

टेस्टकेस क्लास

निम्नलिखित के लिए घोषणा है org.junit.TestCase वर्ग -

public abstract class TestCase extends Assert implements Test

एक परीक्षण मामला कई परीक्षणों को चलाने के लिए स्थिरता को परिभाषित करता है। के कुछ महत्वपूर्ण तरीकेTestCase वर्ग इस प्रकार हैं -

अनु क्रमांक। तरीके और विवरण
1

int countTestCases()

रन (TestResult परिणाम) द्वारा निष्पादित परीक्षण मामलों की संख्या की गणना करता है।

2

TestResult createResult()

एक डिफ़ॉल्ट TestResult ऑब्जेक्ट बनाता है।

3

String getName()

एक TestCase का नाम लेता है।

4

TestResult run()

इस परीक्षण को चलाने के लिए एक सुविधा विधि, डिफ़ॉल्ट TestResult ऑब्जेक्ट के साथ परिणाम एकत्र करना।

5

void run(TestResult result)

परीक्षण मामले को चलाता है और TestResult में परिणाम एकत्र करता है।

6

void setName(String name)

एक TestCase का नाम सेट करता है।

7

void setUp()

उदाहरण के लिए, सेट अप स्थिरता, एक नेटवर्क कनेक्शन खोलें।

8

void tearDown()

उदाहरण के लिए, नीचे आँसू आंसू, एक नेटवर्क कनेक्शन बंद करें।

9

String toString()

परीक्षण के मामले का एक स्ट्रिंग प्रतिनिधित्व लौटाता है।

आइए ऊपर दिए गए कुछ तरीकों का उपयोग एक उदाहरण में करें। नाम से एक जावा वर्ग फ़ाइल बनाएँTestJunit2.java C: \> JUNIT_WORKSPACE में।

import junit.framework.TestCase;
import org.junit.Before;
import org.junit.Test;

public class TestJunit2 extends TestCase  {
   protected double fValue1;
   protected double fValue2;
   
   @Before 
   public void setUp() {
      fValue1 = 2.0;
      fValue2 = 3.0;
   }
	
   @Test
   public void testAdd() {
      //count the number of test cases
      System.out.println("No of Test Case = "+ this.countTestCases());
		
      //test getName 
      String name = this.getName();
      System.out.println("Test Case Name = "+ name);

      //test setName
      this.setName("testNewAdd");
      String newName = this.getName();
      System.out.println("Updated Test Case Name = "+ newName);
   }
	
   //tearDown used to close the connection or clean up activities
   public void tearDown(  ) {
   }
}

इसके बाद, नाम से एक java class फाइल बनाएं TestRunner2.java C: \> JUNIT_WORKSPACE परीक्षण मामले को निष्पादित करने के लिए।

import org.junit.runner.JUnitCore;
import org.junit.runner.Result;
import org.junit.runner.notification.Failure;

public class TestRunner2 {
   public static void main(String[] args) {
      Result result = JUnitCore.runClasses(TestJunit2.class);
		
      for (Failure failure : result.getFailures()) {
         System.out.println(failure.toString());
      }
		
      System.out.println(result.wasSuccessful());
   }
}

Javac का उपयोग करके टेस्ट केस और टेस्ट रनर कक्षाओं को संकलित करें।

C:\JUNIT_WORKSPACE>javac TestJunit2.java TestRunner2.java

अब टेस्ट रनर चलाएं, जो प्रदान किए गए टेस्ट केस क्लास में परिभाषित टेस्ट केस को चलाएगा।

C:\JUNIT_WORKSPACE>java TestRunner2

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

No of Test Case = 1
Test Case Name = testAdd
Updated Test Case Name = testNewAdd
true

TestResult Class

निम्नलिखित के लिए घोषणा है org.junit.TestResult वर्ग -

public class TestResult extends Object

एक TestResult एक परीक्षण मामले को निष्पादित करने के परिणाम एकत्र करता है। यह कलेक्टिंग पैरामीटर पैटर्न का एक उदाहरण है। परीक्षण की रूपरेखा विफलताओं और त्रुटियों के बीच अंतर करती है। एक असफलता की आशंका के साथ जांच की जाती है। त्रुटियां एक ArrayIndexOutOfBoundsException जैसी अप्रत्याशित समस्याएं हैं। के कुछ महत्वपूर्ण तरीकेTestResult वर्ग इस प्रकार हैं -

अनु क्रमांक। तरीके और विवरण
1

void addError(Test test, Throwable t)

त्रुटियों की सूची में त्रुटि जोड़ता है।

2

void addFailure(Test test, AssertionFailedError t)

विफलताओं की सूची में विफलता को जोड़ता है।

3

void endTest(Test test)

परिणाम की सूचना देता है कि एक परीक्षण पूरा हो गया था।

4

int errorCount()

पता चला त्रुटियों की संख्या हो जाती है।

5

Enumeration<TestFailure> errors()

त्रुटियों के लिए एक गणना लौटाता है।

6

int failureCount()

पता चला विफलताओं की संख्या हो जाती है।

7

void run(TestCase test)

एक TestCase चलाता है।

8

int runCount()

रन टेस्ट की संख्या प्राप्त करता है।

9

void startTest(Test test)

परिणाम को सूचित करता है कि एक परीक्षण शुरू किया जाएगा।

10

void stop()

निशान कि परीक्षण रन बंद हो जाना चाहिए।

नाम से एक जावा वर्ग फ़ाइल बनाएँ TestJunit3.java C: \> JUNIT_WORKSPACE में।

import org.junit.Test;
import junit.framework.AssertionFailedError;
import junit.framework.TestResult;

public class TestJunit3 extends TestResult {
   // add the error
   public synchronized void addError(Test test, Throwable t) {
      super.addError((junit.framework.Test) test, t);
   }

   // add the failure
   public synchronized void addFailure(Test test, AssertionFailedError t) {
      super.addFailure((junit.framework.Test) test, t);
   }
	
   @Test
   public void testAdd() {
      // add any test
   }
   
   // Marks that the test run should stop.
   public synchronized void stop() {
      //stop the test here
   }
}

इसके बाद, नाम से एक java class फाइल बनाएं TestRunner3.java C: \> JUNIT_WORKSPACE परीक्षण मामले को निष्पादित करने के लिए।

import org.junit.runner.JUnitCore;
import org.junit.runner.Result;
import org.junit.runner.notification.Failure;

public class TestRunner3 {
   public static void main(String[] args) {
      Result result = JUnitCore.runClasses(TestJunit3.class);

      for (Failure failure : result.getFailures()) {
         System.out.println(failure.toString());
      }
		
      System.out.println(result.wasSuccessful());
   }
}

Javac का उपयोग करके टेस्ट केस और टेस्ट रनर कक्षाओं को संकलित करें।

C:\JUNIT_WORKSPACE>javac TestJunit3.java TestRunner3.java

अब टेस्ट रनर चलाएं, जो प्रदान किए गए टेस्ट केस क्लास में परिभाषित टेस्ट केस को चलाएगा।

C:\JUNIT_WORKSPACE>java TestRunner3

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

true

टेस्टसुइट क्लास

निम्नलिखित के लिए घोषणा है org.junit.TestSuite वर्ग:

public class TestSuite extends Object implements Test

एक TestSuite परीक्षणों का एक समग्र है। यह परीक्षण मामलों का एक संग्रह चलाता है। के कुछ महत्वपूर्ण तरीकेTestSuite वर्ग इस प्रकार हैं -

अनु क्रमांक। तरीके और विवरण
1

void addTest(Test test)

सुइट में एक परीक्षण जोड़ता है।

2

void addTestSuite(Class<? extends TestCase> testClass)

दिए गए वर्ग से सुइट में परीक्षण जोड़ता है।

3

int countTestCases()

इस परीक्षण द्वारा चलाए जाने वाले परीक्षण मामलों की संख्या की गणना करता है।

4

String getName()

सुइट का नाम देता है।

5

void run(TestResult result)

परीक्षण चलाता है और एक TestResult में उनके परिणाम एकत्र करता है।

6

void setName(String name)

सुइट का नाम सेट करता है।

7

Test testAt(int index)

दिए गए सूचकांक पर परीक्षण लौटाता है।

8

int testCount()

इस सुइट में परीक्षणों की संख्या लौटाता है।

9

static Test warning(String message)

एक परीक्षण देता है जो विफल हो जाएगा और चेतावनी संदेश लॉग करेगा।

नाम से एक जावा वर्ग फ़ाइल बनाएँ JunitTestSuite.java C: \> JUNIT_WORKSPACE टेस्ट सूट बनाने के लिए।

import junit.framework.*;

public class JunitTestSuite {
   public static void main(String[] a) {
      // add the test's in the suite
      TestSuite suite = new TestSuite(TestJunit1.class, TestJunit2.class, TestJunit3.class );
      TestResult result = new TestResult();
      suite.run(result);
      System.out.println("Number of test cases = " + result.runCount());
   }
}

जावैक का उपयोग करके टेस्ट सुइट कक्षाओं को संकलित करें।

C:\JUNIT_WORKSPACE>javac JunitTestSuite.java

अब टेस्ट सूट चलाओ।

C:\JUNIT_WORKSPACE>java JunitTestSuite

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

No of Test Case = 1
Test Case Name = testAdd
Updated Test Case Name = testNewAdd
Number of test cases = 3

यहां हम POJO वर्ग, बिजनेस लॉजिक क्लास और एक टेस्ट क्लास का उपयोग करते हुए JUnit परीक्षण का एक पूरा उदाहरण देखेंगे, जो परीक्षण धावक द्वारा चलाया जाएगा।

सृजन करना EmployeeDetails.java C: \> JUNIT_WORKSPACE में, जो एक POJO वर्ग है।

public class EmployeeDetails {

   private String name;
   private double monthlySalary;
   private int age;
   
   /**
   * @return the name
   */
	
   public String getName() {
      return name;
   }
	
   /**
   * @param name the name to set
   */
	
   public void setName(String name) {
      this.name = name;
   }
	
   /**
   * @return the monthlySalary
   */
	
   public double getMonthlySalary() {
      return monthlySalary;
   }
	
   /**
   * @param monthlySalary the monthlySalary to set
   */
	
   public void setMonthlySalary(double monthlySalary) {
      this.monthlySalary = monthlySalary;
   }
	
   /**
   * @return the age
   */
   public int getAge() {
      return age;
   }
	
   /**
   * @param age the age to set
   */
   public void setAge(int age) {
      this.age = age;
   }
}

EmployeeDetails वर्ग का उपयोग किया जाता है -

  • कर्मचारी के नाम का मूल्य प्राप्त / निर्धारित करना।
  • कर्मचारी के मासिक वेतन का मूल्य निर्धारित करें।
  • कर्मचारी की आयु का मूल्य प्राप्त / निर्धारित करें।

नामक एक फ़ाइल बनाएँ EmpBusinessLogic.java C: \> JUNIT_WORKSPACE में, जिसमें व्यावसायिक तर्क हैं।

public class EmpBusinessLogic {
   // Calculate the yearly salary of employee
   public double calculateYearlySalary(EmployeeDetails employeeDetails) {
      double yearlySalary = 0;
      yearlySalary = employeeDetails.getMonthlySalary() * 12;
      return yearlySalary;
   }
	
   // Calculate the appraisal amount of employee
   public double calculateAppraisal(EmployeeDetails employeeDetails) {
      double appraisal = 0;
		
      if(employeeDetails.getMonthlySalary() < 10000){
         appraisal = 500;
      }else{
         appraisal = 1000;
      }
		
      return appraisal;
   }
}

EmpBusinessLogic वर्ग की गणना के लिए उपयोग किया जाता है -

  • किसी कर्मचारी का वार्षिक वेतन।
  • एक कर्मचारी की मूल्यांकन राशि।

नामक एक फ़ाइल बनाएँ TestEmployeeDetails.java C: \> JUNIT_WORKSPACE में, जिसमें परीक्षण किए जाने वाले परीक्षण मामले हैं।

import org.junit.Test;
import static org.junit.Assert.assertEquals;

public class TestEmployeeDetails {
   EmpBusinessLogic empBusinessLogic = new EmpBusinessLogic();
   EmployeeDetails employee = new EmployeeDetails();

   //test to check appraisal
   @Test
   public void testCalculateAppriasal() {
      employee.setName("Rajeev");
      employee.setAge(25);
      employee.setMonthlySalary(8000);
		
      double appraisal = empBusinessLogic.calculateAppraisal(employee);
      assertEquals(500, appraisal, 0.0);
   }

   // test to check yearly salary
   @Test
   public void testCalculateYearlySalary() {
      employee.setName("Rajeev");
      employee.setAge(25);
      employee.setMonthlySalary(8000);
		
      double salary = empBusinessLogic.calculateYearlySalary(employee);
      assertEquals(96000, salary, 0.0);
   }
}

TestEmployeeDetails वर्ग के तरीकों के परीक्षण के लिए प्रयोग किया जाता है EmpBusinessLogicकक्षा। यह

  • कर्मचारी के वार्षिक वेतन का परीक्षण करता है।
  • कर्मचारी की मूल्यांकन राशि का परीक्षण करता है।

इसके बाद नाम से दायर एक जावा क्लास बनाएं TestRunner.java C: \> JUNIT_WORKSPACE परीक्षण मामले को निष्पादित करने के लिए।

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(TestEmployeeDetails.class);
		
      for (Failure failure : result.getFailures()) {
         System.out.println(failure.toString());
      }
		
      System.out.println(result.wasSuccessful());
   }
}

Javac का उपयोग करके टेस्ट केस और टेस्ट रनर कक्षाओं को संकलित करें।

C:\JUNIT_WORKSPACE>javac EmployeeDetails.java 
EmpBusinessLogic.java TestEmployeeDetails.java TestRunner.java

अब टेस्ट रनर चलाएं, जो प्रदान किए गए टेस्ट केस क्लास में परिभाषित टेस्ट केस को चलाएगा।

C:\JUNIT_WORKSPACE>java TestRunner

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

true

अभिकथन

सभी दावे मुखर वर्ग में हैं।

public class Assert extends java.lang.Object

यह वर्ग परख के तरीकों का एक सेट प्रदान करता है, जो परीक्षण लिखने के लिए उपयोगी है। केवल असफल दावे दर्ज किए जाते हैं। Assert वर्ग के कुछ महत्वपूर्ण तरीके इस प्रकार हैं -

अनु क्रमांक। तरीके और विवरण
1

void assertEquals(boolean expected, boolean actual)

जाँच करता है कि दो आदिम / वस्तुएँ समान हैं।

2

void assertTrue(boolean condition)

जाँच करता है कि एक शर्त सही है।

3

void assertFalse(boolean condition)

जाँचता है कि एक शर्त झूठी है।

4

void assertNotNull(Object object)

जाँचता है कि कोई वस्तु अशक्त नहीं है।

5

void assertNull(Object object)

जाँचता है कि कोई वस्तु अशक्त है।

6

void assertSame(object1, object2)

यदि कोई वस्तु एक ही वस्तु को संदर्भित करती है, तो अभिकथन () विधि परीक्षण करती है।

7

void assertNotSame(object1, object2)

यदि कोई ऑब्जेक्ट संदर्भ एक ही ऑब्जेक्ट को इंगित नहीं करता है तो assertNotSame () विधि परीक्षण।

8

void assertArrayEquals(expectedArray, resultArray);

AssertArrayEquals () विधि परीक्षण करेगी कि क्या दो सरणियाँ एक दूसरे के बराबर हैं।

आइए ऊपर दिए गए कुछ तरीकों का उपयोग एक उदाहरण में करें। नाम से एक जावा वर्ग फ़ाइल बनाएँTestAssertions.java C: \> JUNIT_WORKSPACE में।

import org.junit.Test;
import static org.junit.Assert.*;

public class TestAssertions {

   @Test
   public void testAssertions() {
      //test data
      String str1 = new String ("abc");
      String str2 = new String ("abc");
      String str3 = null;
      String str4 = "abc";
      String str5 = "abc";
		
      int val1 = 5;
      int val2 = 6;

      String[] expectedArray = {"one", "two", "three"};
      String[] resultArray =  {"one", "two", "three"};

      //Check that two objects are equal
      assertEquals(str1, str2);

      //Check that a condition is true
      assertTrue (val1 < val2);

      //Check that a condition is false
      assertFalse(val1 > val2);

      //Check that an object isn't null
      assertNotNull(str1);

      //Check that an object is null
      assertNull(str3);

      //Check if two object references point to the same object
      assertSame(str4,str5);

      //Check if two object references not point to the same object
      assertNotSame(str1,str3);

      //Check whether two arrays are equal to each other.
      assertArrayEquals(expectedArray, resultArray);
   }
}

इसके बाद, नाम से एक java class फाइल बनाएं TestRunner.java C: \> JUNIT_WORKSPACE परीक्षण मामले को निष्पादित करने के लिए।

import org.junit.runner.JUnitCore;
import org.junit.runner.Result;
import org.junit.runner.notification.Failure;

public class TestRunner2 {
   public static void main(String[] args) {
      Result result = JUnitCore.runClasses(TestAssertions.class);
		
      for (Failure failure : result.getFailures()) {
         System.out.println(failure.toString());
      }
		
      System.out.println(result.wasSuccessful());
   }
}

Javac का उपयोग करके टेस्ट केस और टेस्ट रनर कक्षाओं को संकलित करें।

C:\JUNIT_WORKSPACE>javac TestAssertions.java TestRunner.java

अब टेस्ट रनर चलाएं, जो प्रदान किए गए टेस्ट केस क्लास में परिभाषित टेस्ट केस को चलाएगा।

C:\JUNIT_WORKSPACE>java TestRunner

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

true

टिप्पणी

एनोटेशन मेटा-टैग की तरह होते हैं जिन्हें आप अपने कोड में जोड़ सकते हैं, और उन्हें तरीकों या कक्षा में लागू कर सकते हैं। JUnit में ये टिप्पणियां परीक्षण विधियों के बारे में निम्नलिखित जानकारी प्रदान करती हैं -

  • परीक्षण विधियों से पहले और बाद में कौन से तरीके चलने वाले हैं।
  • सभी विधियों से पहले और बाद में कौन से तरीके चलते हैं, और।
  • निष्पादन के दौरान किन तरीकों या वर्गों को अनदेखा किया जाएगा।

निम्न तालिका JUnit में एनोटेशन और उनके अर्थ की एक सूची प्रदान करती है -

अनु क्रमांक। एनोटेशन और विवरण
1

@Test

टेस्ट एनोटेशन JUnit को बताता है कि सार्वजनिक शून्य विधि जिससे इसे संलग्न किया जाता है, परीक्षण केस के रूप में चलाया जा सकता है।

2

@Before

कई परीक्षणों को चलाने से पहले इसी तरह की वस्तुओं की आवश्यकता होती है। @Before के साथ सार्वजनिक शून्य विधि की व्याख्या करने से प्रत्येक टेस्ट विधि से पहले उस विधि को चलाया जाता है।

3

@After

यदि आप पहले के तरीके में बाहरी संसाधनों का आवंटन करते हैं, तो आपको परीक्षण चलाने के बाद उन्हें जारी करने की आवश्यकता होती है। @ विधि के साथ सार्वजनिक शून्य विधि की व्याख्या करने के बाद परीक्षण विधि के बाद उस विधि को चलाया जाता है।

4

@BeforeClass

@BeforeClass के साथ सार्वजनिक स्थैतिक शून्य विधि की व्याख्या करने से कक्षा में किसी भी परीक्षण विधि से पहले इसे एक बार चलाया जा सकता है।

5

@AfterClass

सभी परीक्षण समाप्त होने के बाद यह विधि का प्रदर्शन करेगा। इसका उपयोग साफ-सफाई की गतिविधियों को करने के लिए किया जा सकता है।

6

@Ignore

इग्नोर एनोटेशन का उपयोग परीक्षण को अनदेखा करने के लिए किया जाता है और उस परीक्षण को निष्पादित नहीं किया जाएगा।

नाम से एक जावा वर्ग फ़ाइल बनाएँ JunitAnnotation.java C: \> JUNIT_WORKSPACE को एनोटेशन परीक्षण करने के लिए।

import org.junit.After;
import org.junit.AfterClass;

import org.junit.Before;
import org.junit.BeforeClass;

import org.junit.Ignore;
import org.junit.Test;

public class JunitAnnotation {
	
   //execute before class
   @BeforeClass
   public static void beforeClass() {
      System.out.println("in before class");
   }

   //execute after class
   @AfterClass
   public static void  afterClass() {
      System.out.println("in after class");
   }

   //execute before test
   @Before
   public void before() {
      System.out.println("in before");
   }
	
   //execute after test
   @After
   public void after() {
      System.out.println("in after");
   }
	
   //test case
   @Test
   public void test() {
      System.out.println("in test");
   }
	
   //test case ignore and will not execute
   @Ignore
   public void ignoreTest() {
      System.out.println("in ignore test");
   }
}

इसके बाद, नाम से एक java class फाइल बनाएं TestRunner.java C: \> JUNIT_WORKSPACE एनोटेशन निष्पादित करने के लिए।

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(JunitAnnotation.class);
		
      for (Failure failure : result.getFailures()) {
         System.out.println(failure.toString());
      }
		
      System.out.println(result.wasSuccessful());
   }
}

Javac का उपयोग करके टेस्ट केस और टेस्ट रनर कक्षाओं को संकलित करें।

C:\JUNIT_WORKSPACE>javac JunitAnnotation.java TestRunner.java

अब टेस्ट रनर चलाएं, जो प्रदान किए गए टेस्ट केस क्लास में परिभाषित टेस्ट केस को चलाएगा।

C:\JUNIT_WORKSPACE>java TestRunner

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

in before class
in before
in test
in after
in after class
true

यह अध्याय JUnit में विधियों के निष्पादन की प्रक्रिया की व्याख्या करता है, जो कहे जाने वाले तरीकों के क्रम को परिभाषित करता है। नीचे चर्चा की गई उदाहरण के साथ JUnit परीक्षण एपीआई विधियों की निष्पादन प्रक्रिया है।

C: \> JUNIT_WORKSPACE को एनोटेशन परीक्षण करने के लिए ExecutionProcedureJunit.java नाम से एक जावा क्लास फ़ाइल बनाएँ।

import org.junit.After;
import org.junit.AfterClass;

import org.junit.Before;
import org.junit.BeforeClass;

import org.junit.Ignore;
import org.junit.Test;

public class ExecutionProcedureJunit {
	
   //execute only once, in the starting 
   @BeforeClass
   public static void beforeClass() {
      System.out.println("in before class");
   }

   //execute only once, in the end
   @AfterClass
   public static void  afterClass() {
      System.out.println("in after class");
   }

   //execute for each test, before executing test
   @Before
   public void before() {
      System.out.println("in before");
   }
	
   //execute for each test, after executing test
   @After
   public void after() {
      System.out.println("in after");
   }
	
   //test case 1
   @Test
   public void testCase1() {
      System.out.println("in test case 1");
   }

   //test case 2
   @Test
   public void testCase2() {
      System.out.println("in test case 2");
   }
}

इसके बाद, नाम से एक java class फाइल बनाएं TestRunner.java C: \> JUNIT_WORKSPACE एनोटेशन निष्पादित करने के लिए।

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(ExecutionProcedureJunit.class);

      for (Failure failure : result.getFailures()) {
         System.out.println(failure.toString());
      }
		
      System.out.println(result.wasSuccessful());
   }
}

Javac का उपयोग करके टेस्ट केस और टेस्ट रनर कक्षाओं को संकलित करें।

C:\JUNIT_WORKSPACE>javac ExecutionProcedureJunit.java TestRunner.java

अब टेस्ट रनर चलाएं, जो प्रदान किए गए टेस्ट केस क्लास में परिभाषित टेस्ट केस को चलाएगा।

C:\JUNIT_WORKSPACE>java TestRunner

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

in before class
in before
in test case 1
in after
in before
in test case 2
in after
in after class

उपरोक्त आउटपुट देखें। निष्पादन प्रक्रिया इस प्रकार है -

  • सबसे पहले, पहले क्लॉस () विधि केवल एक बार निष्पादित होती है।
  • AfterClass () विधि केवल एक बार निष्पादित होती है।
  • पहले () विधि प्रत्येक परीक्षण मामले के लिए निष्पादित होती है, लेकिन परीक्षण मामले को निष्पादित करने से पहले।
  • प्रत्येक परीक्षण मामले के लिए () विधि निष्पादित होती है, लेकिन परीक्षण मामले के निष्पादन के बाद।
  • पहले () और बाद में () के बीच, प्रत्येक परीक्षण केस निष्पादित होता है।

परीक्षण मामलों का उपयोग करके निष्पादित किया जाता है JUnitCoreकक्षा। JUnitCore परीक्षण चलाने का एक पहलू है। यह JUnit 4 परीक्षण, JUnit 3.8.x परीक्षण और मिश्रण चलाने का समर्थन करता है। कमांड लाइन से परीक्षण चलाने के लिए, java org.junit.runner.JUnitCore <TestClass> चलाएं। एक-शॉट टेस्ट रन के लिए, स्टैटिक विधि runClasses (क्लास []) का उपयोग करें।

निम्नलिखित के लिए घोषणा है org.junit.runner.JUnitCore वर्ग:

public class JUnitCore extends java.lang.Object

यहां हम देखेंगे कि JUnitCore की मदद से परीक्षणों को कैसे निष्पादित किया जाए।

एक क्लास बनाएँ

परीक्षण करने के लिए एक जावा वर्ग बनाएँ, कहते हैं, MessageUtil.java, C: \> JUNIT_WORKSPACE में।

/*
* This class prints the given message on console.
*/

public class MessageUtil {

   private String message;

   //Constructor
   //@param message to be printed
   public MessageUtil(String message){
      this.message = message;
   }
      
   // prints the message
   public String printMessage(){
      System.out.println(message);
      return message;
   }   
	
}

टेस्ट केस क्लास बनाएं

  • एक जावा टेस्ट क्लास बनाएं, कहिए, TestJunit.java।

  • अपने परीक्षण वर्ग में एक परीक्षण विधि testPrintMessage () जोड़ें।

  • विधि परीक्षण PintintMessage () के लिए एक एनोटेशन @ टेस्ट जोड़ें।

  • परीक्षण की स्थिति को लागू करें और JUnit के एपीआई का उपयोग करके स्थिति की जाँच करें।

नाम से एक जावा वर्ग फ़ाइल बनाएँ TestJunit.java C: \> JUNIT_WORKSPACE में।

import org.junit.Test;
import static org.junit.Assert.assertEquals;

public class TestJunit {
	
   String message = "Hello World";	
   MessageUtil messageUtil = new MessageUtil(message);

   @Test
   public void testPrintMessage() {
      assertEquals(message,messageUtil.printMessage());
   }
}

टेस्ट रनर क्लास बनाएं

अब नाम से एक java class file बनाएं TestRunner.javaC: \> JUNIT_WORKSPACE परीक्षण मामले को निष्पादित करने के लिए। यह JUnitCore क्लास को इम्पोर्ट करता है और रनक्लास () विधि का उपयोग करता है जो टेस्ट क्लास के नाम को अपने पैरामीटर के रूप में लेता है।

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(TestJunit.class);
		
      for (Failure failure : result.getFailures()) {
         System.out.println(failure.toString());
      }
		
      System.out.println(result.wasSuccessful());
   }
}

Javac का उपयोग करके टेस्ट केस और टेस्ट रनर कक्षाओं को संकलित करें।

C:\JUNIT_WORKSPACE>javac MessageUtil.java TestJunit.java TestRunner.java

अब टेस्ट रनर चलाएं, जो प्रदान किए गए टेस्ट केस क्लास में परिभाषित टेस्ट केस को चलाएगा।

C:\JUNIT_WORKSPACE>java TestRunner

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

Hello World
true

Test suiteकुछ इकाई परीक्षण मामलों को बंडल करने और उन्हें एक साथ चलाने के लिए उपयोग किया जाता है। JUnit में, दोनों@RunWith तथा @Suiteसुइट परीक्षण चलाने के लिए एनोटेशन का उपयोग किया जाता है। यह अध्याय एक उदाहरण लेता है जिसमें दो परीक्षण कक्षाएं होती हैं,TestJunit1 और TestJunit2, कि टेस्ट सूट का उपयोग करके एक साथ चलते हैं।

एक क्लास बनाएँ

परीक्षण करने के लिए एक जावा वर्ग बनाएँ, कहते हैं, MessageUtil.java C: \> JUNIT_WORKSPACE में।

/*
* This class prints the given message on console.
*/

public class MessageUtil {

   private String message;

   //Constructor
   //@param message to be printed
   public MessageUtil(String message){
      this.message = message; 
   }

   // prints the message
   public String printMessage(){
      System.out.println(message);
      return message;
   }   

   // add "Hi!" to the message
   public String salutationMessage(){
      message = "Hi!" + message;
      System.out.println(message);
      return message;
   }   
}

टेस्ट केस क्लासेस बनाएं

नाम से एक जावा वर्ग फ़ाइल बनाएँ TestJunit1.java C: \> JUNIT_WORKSPACE में।

import org.junit.Test;
import org.junit.Ignore;
import static org.junit.Assert.assertEquals;

public class TestJunit1 {

   String message = "Robert";	
   MessageUtil messageUtil = new MessageUtil(message);
   
   @Test
   public void testPrintMessage() {	
      System.out.println("Inside testPrintMessage()");    
      assertEquals(message, messageUtil.printMessage());     
   }
}

नाम से एक जावा वर्ग फ़ाइल बनाएँ TestJunit2.java C: \> JUNIT_WORKSPACE में।

import org.junit.Test;
import org.junit.Ignore;
import static org.junit.Assert.assertEquals;

public class TestJunit2 {

   String message = "Robert";	
   MessageUtil messageUtil = new MessageUtil(message);
 
   @Test
   public void testSalutationMessage() {
      System.out.println("Inside testSalutationMessage()");
      message = "Hi!" + "Robert";
      assertEquals(message,messageUtil.salutationMessage());
   }
}

टेस्ट सूट क्लास बनाएं

  • एक जावा वर्ग बनाएँ।
  • वर्ग के साथ @RunWith (Suite.class) संलग्न करें।
  • @ सूट का उपयोग करके JUnit टेस्ट कक्षाओं के संदर्भ जोड़ें। SuiteClasses एनोटेशन।

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

import org.junit.runner.RunWith;
import org.junit.runners.Suite;

@RunWith(Suite.class)

@Suite.SuiteClasses({
   TestJunit1.class,
   TestJunit2.class
})

public class JunitTestSuite {   
}

टेस्ट रनर क्लास बनाएं

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

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(JunitTestSuite.class);

      for (Failure failure : result.getFailures()) {
         System.out.println(failure.toString());
      }
		
      System.out.println(result.wasSuccessful());
   }
}

जावा का उपयोग करके सभी जावा कक्षाओं को संकलित करें।

C:\JUNIT_WORKSPACE>javac MessageUtil.java TestJunit1.java 
TestJunit2.java JunitTestSuite.java TestRunner.java

अब टेस्ट रनर चलाएं, जो प्रदान किए गए टेस्ट केस क्लास में परिभाषित टेस्ट केस को चलाएगा।

C:\JUNIT_WORKSPACE>java TestRunner

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

Inside testPrintMessage()
Robert
Inside testSalutationMessage()
Hi Robert
true

कभी-कभी ऐसा होता है कि टेस्ट केस चलाते समय हमारा कोड पूरी तरह से तैयार नहीं होता है। नतीजतन, परीक्षण का मामला विफल हो जाता है। @Ignore एनोटेशन इस परिदृश्य में मदद करता है।

  • @Ignore के साथ एनोटेट की गई परीक्षा पद्धति निष्पादित नहीं की जाएगी।

  • यदि @Ignore के साथ एक टेस्ट क्लास एनोटेट किया जाता है, तो इसके परीक्षण के तरीकों में से कोई भी निष्पादित नहीं होगा।

अब देखते हैं @Ignore एक्शन में है।

एक क्लास बनाएँ

परीक्षण करने के लिए एक जावा वर्ग बनाएँ, कहते हैं, MessageUtil.java C: \> JUNIT_WORKSPACE में।

/*
* This class prints the given message on console.
*/

public class MessageUtil {

   private String message;

   //Constructor
   //@param message to be printed
   public MessageUtil(String message){
      this.message = message; 
   }

   // prints the message
   public String printMessage(){
      System.out.println(message);
      return message;
   }   

   // add "Hi!" to the message
   public String salutationMessage(){
      message = "Hi!" + message;
      System.out.println(message);
      return message;
   }   
	
}

टेस्ट केस क्लास बनाएं

  • एक जावा टेस्ट क्लास बनाएं, कहिए, TestJunit.java।

  • एक परीक्षण विधि TestPrintMessage () या testSalutationMessage () को अपने परीक्षण वर्ग में जोड़ें।

  • मेथड टेस्टप्रिंटमैसेज () में एनोटेशन @ इग्नोर जोड़ें।

नाम से एक जावा वर्ग फ़ाइल बनाएँ TestJunit.java C: \ JUNIT_WORKSPACE में।

import org.junit.Test;
import org.junit.Ignore;
import static org.junit.Assert.assertEquals;

public class TestJunit {

   String message = "Robert";	
   MessageUtil messageUtil = new MessageUtil(message);
   
   @Ignore
   @Test
   public void testPrintMessage() {
      System.out.println("Inside testPrintMessage()");
      message = "Robert";
      assertEquals(message,messageUtil.printMessage());
   }

   @Test
   public void testSalutationMessage() {
      System.out.println("Inside testSalutationMessage()");
      message = "Hi!" + "Robert";
      assertEquals(message,messageUtil.salutationMessage());
   }
	
}

टेस्ट रनर क्लास बनाएं

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

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(TestJunit.class);

      for (Failure failure : result.getFailures()) {
         System.out.println(failure.toString());
      }
		
      System.out.println(result.wasSuccessful());
   }
}

मैसेज यूटिल, टेस्ट केस और टेस्ट रनर क्लासेस को javac का उपयोग करके संकलित करें।

C:\JUNIT_WORKSPACE>javac MessageUtil.java TestJunit.java TestRunner.java

अब टेस्ट रनर चलाएं, जो प्रदान किए गए टेस्ट केस क्लास में परिभाषित टेस्टप्रिंटरमेसेज () टेस्ट केस नहीं चलाएगा।

C:\JUNIT_WORKSPACE>java TestRunner

आउटपुट सत्यापित करें। testPrintMessage () परीक्षण मामले का परीक्षण नहीं किया गया है।

Inside testSalutationMessage()
Hi!Robert
true

अब, TestJunit को C: \> JUNIT_WORKSPACE में अपडेट करें, सभी परीक्षण मामलों की अनदेखी करें। वर्ग स्तर पर @Ignore जोड़ें।

import org.junit.Test;
import org.junit.Ignore;
import static org.junit.Assert.assertEquals;

@Ignore
public class TestJunit {

   String message = "Robert";	
   MessageUtil messageUtil = new MessageUtil(message);
     
   @Test
   public void testPrintMessage() {
      System.out.println("Inside testPrintMessage()");
      message = "Robert";
      assertEquals(message,messageUtil.printMessage());
   }

   @Test
   public void testSalutationMessage() {
      System.out.println("Inside testSalutationMessage()");
      message = "Hi!" + "Robert";
      assertEquals(message,messageUtil.salutationMessage());
   }
	
}

Javac का उपयोग करके परीक्षण केस संकलित करें।

C:\JUNIT_WORKSPACE>javac TestJunit.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(TestJunit.class);
		
      for (Failure failure : result.getFailures()) {
         System.out.println(failure.toString());
      }
		
      System.out.println(result.wasSuccessful());
   }
}

अब टेस्ट रनर चलाएं, जो प्रदान किए गए टेस्ट केस क्लास में परिभाषित किसी भी टेस्ट केस को नहीं चलाएगा।

C:\JUNIT_WORKSPACE>java TestRunner

आउटपुट सत्यापित करें। किसी भी परीक्षण मामले का परीक्षण नहीं किया जाता है।

true

JUnit टाइमआउट का एक आसान विकल्प प्रदान करता है। यदि एक परीक्षण मामले में मिलीसेकंड की निर्दिष्ट संख्या से अधिक समय लगता है, तो JUnit स्वचालित रूप से इसे विफल के रूप में चिह्नित करेगा। timeoutपैरामीटर का उपयोग @Test एनोटेशन के साथ किया जाता है। हमें कार्रवाई में @ समय (टाइमआउट) देखते हैं।

एक क्लास बनाएँ

परीक्षण करने के लिए एक जावा वर्ग बनाएँ, कहते हैं, MessageUtil.java C: \> JUNIT_WORKSPACE में।

PrintMessage () विधि के अंदर लूप करते समय एक अनंत जोड़ें।

/*
* This class prints the given message on console.
*/

public class MessageUtil {

   private String message;

   //Constructor
   //@param message to be printed
   public MessageUtil(String message){
      this.message = message; 
   }

   // prints the message
   public void printMessage(){
      System.out.println(message);
      while(true);
   }   

   // add "Hi!" to the message
   public String salutationMessage(){
      message = "Hi!" + message;
      System.out.println(message);
      return message;
   }   
}

टेस्ट केस क्लास बनाएं

एक जावा टेस्ट क्लास बनाएं, कहें, TestJunit.java। 1000 का टाइमआउट जोड़ें टेस्टप्रिंटरमेसेज () टेस्ट केस।

नाम से एक जावा वर्ग फ़ाइल बनाएँ TestJunit.java C: \> JUNIT_WORKSPACE में।

import org.junit.Test;
import org.junit.Ignore;
import static org.junit.Assert.assertEquals;

public class TestJunit {

   String message = "Robert";	
   MessageUtil messageUtil = new MessageUtil(message);
   
   @Test(timeout = 1000)
   public void testPrintMessage() {	
      System.out.println("Inside testPrintMessage()");     
      messageUtil.printMessage();     
   }

   @Test
   public void testSalutationMessage() {
      System.out.println("Inside testSalutationMessage()");
      message = "Hi!" + "Robert";
      assertEquals(message,messageUtil.salutationMessage());
   }
}

टेस्ट रनर क्लास बनाएं

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

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(TestJunit.class);
		
      for (Failure failure : result.getFailures()) {
         System.out.println(failure.toString());
      }
		
      System.out.println(result.wasSuccessful());
   }
}

मैसेज यूटिल, टेस्ट केस और टेस्ट रनर क्लासेस को javac का उपयोग करके संकलित करें।

C:\JUNIT_WORKSPACE>javac MessageUtil.java TestJunit.java TestRunner.java

अब टेस्ट रनर चलाएं, जो प्रदान किए गए टेस्ट केस क्लास में परिभाषित टेस्ट केस चलाएगा।

C:\JUNIT_WORKSPACE>java TestRunner

आउटपुट सत्यापित करें। testPrintMessage () परीक्षण मामले में इकाई परीक्षण विफल हो जाएगा।

Inside testPrintMessage()
Robert
Inside testSalutationMessage()
Hi!Robert
testPrintMessage(TestJunit): test timed out after 1000 milliseconds
false

JUnit कोड के अपवाद हैंडलिंग को ट्रेस करने का एक विकल्प प्रदान करता है। आप परीक्षण कर सकते हैं कि कोड वांछित अपवाद फेंकता है या नहीं। expectedपैरामीटर का उपयोग @Test एनोटेशन के साथ किया जाता है। हमें कार्रवाई में @Test (अपेक्षित) देखते हैं।

एक क्लास बनाएँ

परीक्षण करने के लिए एक जावा वर्ग बनाएँ, कहते हैं, MessageUtil.java C: \> JUNIT_WORKSPACE में।

PrintMessage () विधि के अंदर एक त्रुटि स्थिति जोड़ें।

/*
* This class prints the given message on console.
*/

public class MessageUtil {

   private String message;

   //Constructor
   //@param message to be printed
   public MessageUtil(String message){
      this.message = message; 
   }

   // prints the message
   public void printMessage(){
      System.out.println(message);
      int a = 0;
      int b = 1/a;
   }   

   // add "Hi!" to the message
   public String salutationMessage(){
      message = "Hi!" + message;
      System.out.println(message);
      return message;
   }   
}

टेस्ट केस क्लास बनाएं

जावा टेस्ट क्लास बनाएं TestJunit.java। TestPrintMessage () परीक्षण मामले में एक अपेक्षित अपवाद अंकगणित अपवाद जोड़ें।

नाम से एक जावा वर्ग फ़ाइल बनाएँ TestJunit.java C: \> JUNIT_WORKSPACE में।

import org.junit.Test;
import org.junit.Ignore;
import static org.junit.Assert.assertEquals;

public class TestJunit {

   String message = "Robert";	
   MessageUtil messageUtil = new MessageUtil(message);
   
   @Test(expected = ArithmeticException.class)
   public void testPrintMessage() {	
      System.out.println("Inside testPrintMessage()");     
      messageUtil.printMessage();     
   }

   @Test
   public void testSalutationMessage() {
      System.out.println("Inside testSalutationMessage()");
      message = "Hi!" + "Robert";
      assertEquals(message,messageUtil.salutationMessage());
   }
}

टेस्ट रनर क्लास बनाएं

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

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(TestJunit.class);
		
      for (Failure failure : result.getFailures()) {
         System.out.println(failure.toString());
      }
		
      System.out.println(result.wasSuccessful());
   }
}

मैसेज यूटिल, टेस्ट केस और टेस्ट रनर क्लासेस को javac का उपयोग करके संकलित करें।

C:\JUNIT_WORKSPACE>javac MessageUtil.java TestJunit.java TestRunner.java

अब टेस्ट रनर चलाएं, जो प्रदान किए गए टेस्ट केस क्लास में परिभाषित टेस्ट केस चलाएगा।

C:\JUNIT_WORKSPACE>java TestRunner

आउटपुट सत्यापित करें। testPrintMessage () परीक्षण मामला पारित किया जाएगा।

Inside testPrintMessage()
Robert
Inside testSalutationMessage()
Hi!Robert
true

JUnit 4 ने एक नया फीचर पेश किया है parameterized tests। पैरामीटर परीक्षण अलग-अलग मानों का उपयोग करके एक डेवलपर को एक ही परीक्षण को बार-बार चलाने की अनुमति देता है। पांच चरण हैं जो आपको एक मानकीकृत परीक्षण बनाने के लिए पालन करने की आवश्यकता है।

  • @RunWith (Parameterized.class) के साथ एनोटेट टेस्ट क्लास।

  • एक सार्वजनिक स्थैतिक विधि बनाएँ, जो @Parameters के साथ एनोटेट की गई हो, जो टेस्ट डेटा सेट के रूप में ऑब्जेक्ट्स का संग्रह (Array के रूप में) लौटाता है।

  • एक सार्वजनिक निर्माणकर्ता बनाएं जो परीक्षण डेटा के एक "पंक्ति" के बराबर है।

  • परीक्षण डेटा के प्रत्येक "कॉलम" के लिए एक उदाहरण चर बनाएं।

  • परीक्षण डेटा के स्रोत के रूप में उदाहरण चर का उपयोग करके अपना परीक्षण मामला बनाएं।

डेटा की प्रत्येक पंक्ति के लिए एक बार परीक्षण मामला लागू किया जाएगा। हमें कार्रवाई में पैरामीटरित परीक्षण देखें।

एक क्लास बनाएँ

परीक्षण करने के लिए एक जावा वर्ग बनाएँ, कहते हैं, PrimeNumberChecker.java C: \> JUNIT_WORKSPACE में।

public class PrimeNumberChecker {
   public Boolean validate(final Integer primeNumber) {
      for (int i = 2; i < (primeNumber / 2); i++) {
         if (primeNumber % i == 0) {
            return false;
         }
      }
      return true;
   }
}

Parameterized टेस्ट केस क्लास बनाएँ

एक जावा टेस्ट क्लास बनाएं, कहें, PrimeNumberCheckerTest.java। नाम से एक जावा वर्ग फ़ाइल बनाएँPrimeNumberCheckerTest.java C: \> JUNIT_WORKSPACE में।

import java.util.Arrays;
import java.util.Collection;
 
import org.junit.Test;
import org.junit.Before;

import org.junit.runners.Parameterized;
import org.junit.runners.Parameterized.Parameters;
import org.junit.runner.RunWith;
import static org.junit.Assert.assertEquals;

@RunWith(Parameterized.class)
public class PrimeNumberCheckerTest {
   private Integer inputNumber;
   private Boolean expectedResult;
   private PrimeNumberChecker primeNumberChecker;

   @Before
   public void initialize() {
      primeNumberChecker = new PrimeNumberChecker();
   }

   // Each parameter should be placed as an argument here
   // Every time runner triggers, it will pass the arguments
   // from parameters we defined in primeNumbers() method
	
   public PrimeNumberCheckerTest(Integer inputNumber, Boolean expectedResult) {
      this.inputNumber = inputNumber;
      this.expectedResult = expectedResult;
   }

   @Parameterized.Parameters
   public static Collection primeNumbers() {
      return Arrays.asList(new Object[][] {
         { 2, true },
         { 6, false },
         { 19, true },
         { 22, false },
         { 23, true }
      });
   }

   // This test will run 4 times since we have 5 parameters defined
   @Test
   public void testPrimeNumberChecker() {
      System.out.println("Parameterized Number is : " + inputNumber);
      assertEquals(expectedResult, 
      primeNumberChecker.validate(inputNumber));
   }
}

टेस्ट रनर क्लास बनाएं

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

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(PrimeNumberCheckerTest.class);

      for (Failure failure : result.getFailures()) {
         System.out.println(failure.toString());
      }
		
      System.out.println(result.wasSuccessful());
   }
}

जनाक का उपयोग करके PrimeNumberChecker, PrimeNumberCheckerTest और Test Runner Classes को कंपाइल करें।

C:\JUNIT_WORKSPACE>javac PrimeNumberChecker.java PrimeNumberCheckerTest.java
TestRunner.java

अब टेस्ट रनर चलाएं, जो प्रदान किए गए टेस्ट केस क्लास में परिभाषित टेस्ट केस चलाएगा।

C:\JUNIT_WORKSPACE>java TestRunner

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

Parameterized Number is : 2
Parameterized Number is : 6
Parameterized Number is : 19
Parameterized Number is : 22
Parameterized Number is : 23
true

हमारे पास ANT का उपयोग करके JUnit को चलाने के तरीके को प्रदर्शित करने के लिए एक उदाहरण होगा। नीचे दिए गए चरणों का पालन करें।

चरण 1: अपाचे चींटी डाउनलोड करें

आप जिस ऑपरेटिंग सिस्टम पर काम कर रहे हैं, उसके आधार पर Apache Ant डाउनलोड करें ।

ओएस पुरालेख का नाम
खिड़कियाँ apache-ant-1.8.4-bin.zip
लिनक्स अपाचे-चींटी-1.8.4-bin.tar.gz
मैक अपाचे-चींटी-1.8.4-bin.tar.gz

चरण 2: चींटी पर्यावरण सेट करें

ठीक ANT_HOMEपर्यावरण चर को बेस डायरेक्टरी स्थान पर इंगित करने के लिए, जहां ANT लाइब्रेरी आपकी मशीन पर संग्रहीत हैं। मान लें कि चींटी पुस्तकालयों को फ़ोल्डर अपाचे-चींटी-1.8.4 में संग्रहीत किया गया है।

अनु क्रमांक। ओएस और विवरण
1

Windows

पर्यावरण चर ANT_HOME को C: \ Program Files \ Apache Software Foundation \ Apache-ant-1.8.4 पर सेट करें

2

Linux

ANT_HOME = /usr/local/apache-ant-1.8.4 निर्यात करें

3

Mac

निर्यात ANT_HOME = /Library/apache-ant-1.8.4

सिस्टम पथ में चींटी संकलक का स्थान निम्नानुसार है -

ओएस उत्पादन
खिड़कियाँ तार लगाओ %ANT_HOME\bin सिस्टम चर के अंत में, Path
लिनक्स निर्यात पथ = $PATH:$ANT_HOME / bin /
मैक आवश्यक नहीं

चरण 3: JUnit पुरालेख डाउनलोड करें

एक JUnit पुरालेख डाउनलोड करें जो आपके ऑपरेटिंग सिस्टम के अनुकूल हो।

ओएस पुरालेख का नाम
खिड़कियाँ junit4.10.jar
लिनक्स junit4.10.jar
मैक junit4.10.jar

चरण 4: प्रोजेक्ट संरचना बनाएँ

  • एक फ़ोल्डर बनाएँ TestJunitWithAnt C: \> JUNIT_WORKSPACE में।

  • एक फ़ोल्डर बनाएँ src C: \> JUNIT_WORKSPACE> TestJunitWithAnt में।

  • एक फ़ोल्डर बनाएँ test C: \> JUNIT_WORKSPACE> TestJunitWithAnt में।

  • एक फ़ोल्डर बनाएँ lib C: \> JUNIT_WORKSPACE> TestJunitWithAnt में।

  • सृजन करना MessageUtil C: \> JUNIT_WORKSPACE> TestJunitWithAnt> srcfolder में कक्षा।

/*
* This class prints the given message on console.
*/

public class MessageUtil {

   private String message;

   //Constructor
   //@param message to be printed
   public MessageUtil(String message){
      this.message = message; 
   }

   // prints the message
   public String printMessage(){
      System.out.println(message);
      return message;
   }   

   // add "Hi!" to the message
   public String salutationMessage(){
      message = "Hi!" + message;
      System.out.println(message);
      return message;
   }   
}

सृजन करना TestMessageUtil फ़ोल्डर में वर्ग C: \> JUNIT_WORKSPACE> TestJunitWithAnt> src।

import org.junit.Test;
import org.junit.Ignore;
import static org.junit.Assert.assertEquals;

public class TestMessageUtil {

   String message = "Robert";	
   MessageUtil messageUtil = new MessageUtil(message);
   
   @Test
   public void testPrintMessage() {	
      System.out.println("Inside testPrintMessage()");     
      assertEquals(message,messageUtil.printMessage());
   }

   @Test
   public void testSalutationMessage() {
      System.out.println("Inside testSalutationMessage()");
      message = "Hi!" + "Robert";
      assertEquals(message,messageUtil.salutationMessage());
   }
}

फ़ोल्डर पर junit-4.10.jar को कॉपी करें: \> JUNIT_WORKSPACE> TestJunitWithAnt> lib।

ANT Build.xml बनाएँ

हम उपयोग करेंगे <junit> चींटी में कार्य हमारे JUnit परीक्षण मामलों को निष्पादित करने के लिए।

<project name = "JunitTest" default = "test" basedir = ".">
   <property name = "testdir" location = "test" />
   <property name = "srcdir" location = "src" />
   <property name = "full-compile" value = "true" />
	
   <path id = "classpath.base"/>
	
   <path id = "classpath.test">
      <pathelement location = "lib/junit-4.10.jar" />
      <pathelement location = "${testdir}" /> <pathelement location = "${srcdir}" />
      <path refid = "classpath.base" />
   </path>
	
   <target name = "clean" >
      <delete verbose = "${full-compile}"> <fileset dir = "${testdir}" includes = "**/*.class" />
      </delete>
   </target>
	
   <target name = "compile" depends = "clean">
      <javac srcdir = "${srcdir}" destdir = "${testdir}" 
         verbose = "${full-compile}">
         <classpath refid = "classpath.test"/>
      </javac>
   </target>
	
   <target name = "test" depends = "compile">
      <junit>
         <classpath refid = "classpath.test" />
         <formatter type = "brief" usefile = "false" />
         <test name = "TestMessageUtil" />
      </junit>
   </target>
	
</project>

निम्नलिखित चींटी कमांड चलाएं।

C:\JUNIT_WORKSPACE\TestJunitWithAnt>ant

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

Buildfile: C:\JUNIT_WORKSPACE\TestJunitWithAnt\build.xml

clean:  

compile:  
   [javac] Compiling 2 source files to C:\JUNIT_WORKSPACE\TestJunitWithAnt\test
   [javac] [parsing started C:\JUNIT_WORKSPACE\TestJunitWithAnt\src\
      MessageUtil.java]
   [javac] [parsing completed 18ms]
   [javac] [parsing started C:\JUNIT_WORKSPACE\TestJunitWithAnt\src\
      TestMessageUtil.java]
   [javac] [parsing completed 2ms]
   [javac] [search path for source files: C:\JUNIT_WORKSPACE\
      TestJunitWithAnt\src]    
   [javac] [loading java\lang\Object.class(java\lang:Object.class)]
   [javac] [loading java\lang\String.class(java\lang:String.class)]
   [javac] [loading org\junit\Test.class(org\junit:Test.class)]
   [javac] [loading org\junit\Ignore.class(org\junit:Ignore.class)]
   [javac] [loading org\junit\Assert.class(org\junit:Assert.class)]
   [javac] [loading java\lang\annotation\Retention.class
      (java\lang\annotation:Retention.class)]
   [javac] [loading java\lang\annotation\RetentionPolicy.class
      (java\lang\annotation:RetentionPolicy.class)]
   [javac] [loading java\lang\annotation\Target.class
      (java\lang\annotation:Target.class)]
   [javac] [loading java\lang\annotation\ElementType.class
      (java\lang\annotation:ElementType.class)]
   [javac] [loading java\lang\annotation\Annotation.class
      (java\lang\annotation:Annotation.class)]
   [javac] [checking MessageUtil]
   [javac] [loading java\lang\System.class(java\lang:System.class)]
   [javac] [loading java\io\PrintStream.class(java\io:PrintStream.class)]
   [javac] [loading java\io\FilterOutputStream.class
      (java\io:FilterOutputStream.class)]
   [javac] [loading java\io\OutputStream.class(java\io:OutputStream.class)]
   [javac] [loading java\lang\StringBuilder.class
      (java\lang:StringBuilder.class)]
   [javac] [loading java\lang\AbstractStringBuilder.class
      (java\lang:AbstractStringBuilder.class)]
   [javac] [loading java\lang\CharSequence.class(java\lang:CharSequence.class)]
   [javac] [loading java\io\Serializable.class(java\io:Serializable.class)]
   [javac] [loading java\lang\Comparable.class(java\lang:Comparable.class)]
   [javac] [loading java\lang\StringBuffer.class(java\lang:StringBuffer.class)]
   [javac] [wrote C:\JUNIT_WORKSPACE\TestJunitWithAnt\test\MessageUtil.class]
   [javac] [checking TestMessageUtil]
   [javac] [wrote C:\JUNIT_WORKSPACE\TestJunitWithAnt\test\TestMessageUtil.class]
   [javac] [total 281ms]

test:
    [junit] Testsuite: TestMessageUtil
    [junit] Tests run: 2, Failures: 0, Errors: 0, Time elapsed: 0.008 sec
    [junit]
    [junit] ------------- Standard Output ---------------
    [junit] Inside testPrintMessage()
    [junit] Robert
    [junit] Inside testSalutationMessage()
    [junit] Hi!Robert
    [junit] ------------- ---------------- ---------------

BUILD SUCCESSFUL
Total time: 0 seconds

ग्रहण के साथ JUnit स्थापित करने के लिए, नीचे दिए गए चरणों का पालन करें।

चरण 1: JUnit पुरालेख डाउनलोड करें

आपके सिस्टम में मौजूद ऑपरेटिंग सिस्टम के आधार पर JUnit जार डाउनलोड करें।

ओएस पुरालेख का नाम
खिड़कियाँ junit4.10.jar
लिनक्स junit4.10.jar
मैक junit4.10.jar

मान लें कि आपने JAR फ़ाइल को फ़ोल्डर C: \> JUnit पर कॉपी कर लिया है।

चरण 2: ग्रहण पर्यावरण सेट करें

खुला ग्रहण → प्रोजेक्ट पर राइट क्लिक करें और प्रॉपर्टी पर क्लिक करें> बिल्ड पाथ> बिल्ड पाथ कॉन्फ़िगर करें और पुस्तकालयों में जूनियर-4.10.jar जोड़ें बटन का उपयोग करके बाहरी जार जोड़ें।

हम मानते हैं कि आपके ग्रहण में JUnit प्लगइन इनबिल्ट है। यदि यह C: \> eclipse \ plugins निर्देशिका में उपलब्ध नहीं है, तो आप इसे से डाउनलोड कर सकते हैंJUnit Plugin। ग्रहण के प्लगइन फ़ोल्डर में डाउनलोड की गई ज़िप फ़ाइल को अनज़िप करें। अंत में ग्रहण को पुनः आरंभ करें।

अब आपका ग्रहण JUnit परीक्षण मामलों के विकास के लिए तैयार है।

चरण 3: ग्रहण में JUnit स्थापना को सत्यापित करें

एक प्रोजेक्ट बनाएं TestJunitकिसी भी स्थान पर ग्रहण में। फिर एक क्लास बनाएंMessageUtil परियोजना में परीक्षण करने के लिए।

/*
* This class prints the given message on console.
*/

public class MessageUtil {

   private String message;

   //Constructor
   //@param message to be printed
   public MessageUtil(String message){
      this.message = message;
   }
      
   // prints the message
   public String printMessage(){
      System.out.println(message);
      return message;
   }   
}

टेस्ट क्लास बनाएं TestJunit परियोजना में।

import org.junit.Test;
import static org.junit.Assert.assertEquals;

public class TestJunit {
	
   String message = "Hello World";	
   MessageUtil messageUtil = new MessageUtil(message);

   @Test
   public void testPrintMessage() {	  
      assertEquals(message,messageUtil.printMessage());
   }
}

परियोजना संरचना निम्नलिखित होनी चाहिए -

अंत में, प्रोग्राम पर राइट क्लिक करें और प्रोग्राम के आउटपुट को सत्यापित करने के लिए JUnit के रूप में चलाएं।

परिणाम सत्यापित करें।

JUnit एक्सटेंशन निम्नलिखित हैं -

  • Cactus
  • JWebUnit
  • XMLUnit
  • MockObject

कैक्टस

कैक्टस यूनिट टेस्टिंग सर्वर-साइड जावा कोड (सर्वलेट्स, ईजेबी, टैग लिब, फाइलिंग) के लिए एक सरल परीक्षण ढांचा है। कैक्टस का इरादा सर्वर-साइड कोड के लिए परीक्षण परीक्षण की लागत को कम करना है। यह JUnit का उपयोग करता है और इसका विस्तार करता है। कैक्टस इन-कंटेनर रणनीति को लागू करता है जो कंटेनर के अंदर परीक्षणों को निष्पादित करता है।

कैक्टस पारिस्थितिकी तंत्र कई घटकों से बना है -

  • Cactus Frameworkकैक्टस का दिल है। यह इंजन है जो कैक्टस परीक्षण लिखने के लिए एपीआई प्रदान करता है।

  • Cactus Integration Modules फ्रंट-एंड और फ्रेमवर्क हैं जो कैक्टस फ्रेमवर्क (चींटी स्क्रिप्ट, एक्लिप्स प्लगइन और मावरा प्लगइन) का उपयोग करने के आसान तरीके प्रदान करते हैं।

निम्नलिखित कोड दर्शाता है कि कैक्टस का उपयोग कैसे किया जा सकता है।

import org.apache.cactus.*;
import junit.framework.*;

public class TestSampleServlet extends ServletTestCase {
   @Test
   public void testServlet() {
      // Initialize class to test
      SampleServlet servlet = new SampleServlet();

      // Set a variable in session as the doSomething()
      // method that we are testing 
      session.setAttribute("name", "value");

      // Call the method to test, passing an 
      // HttpServletRequest object (for example)
      String result = servlet.doSomething(request);

      // Perform verification that test was successful
      assertEquals("something", result);
      assertEquals("otherValue", session.getAttribute("otherName"));
   }
}

JWebUnit

JWebUnit वेब अनुप्रयोगों के लिए जावा-आधारित परीक्षण ढांचा है। यह आपके वेब अनुप्रयोगों की शुद्धता का परीक्षण करने के लिए एक एकीकृत, सरल परीक्षण इंटरफ़ेस के साथ मौजूदा परीक्षण ढांचे जैसे कि HtmlUnit और सेलेनियम को लपेटता है।

JWebUnit एप्लिकेशन की शुद्धता को सत्यापित करने के लिए मुखरता के एक सेट के साथ संयुक्त एक वेब एप्लिकेशन को नेविगेट करने के लिए एक उच्च-स्तरीय जावा एपीआई प्रदान करता है। इसमें लिंक के माध्यम से नेविगेशन, फॉर्म प्रविष्टि और सबमिशन, टेबल सामग्री की मान्यता, और अन्य विशिष्ट व्यवसाय वेब एप्लिकेशन विशेषताएं शामिल हैं।

सरल नेविगेशन के तरीके और रेडी-टू-यूज़ दावे केवल JUnit या HtmlUpit का उपयोग करने की तुलना में अधिक तेजी से परीक्षण निर्माण की अनुमति देते हैं। और यदि आप HtmlUnit से अन्य प्लगइन्स जैसे सेलेनियम (जल्द ही उपलब्ध) पर स्विच करना चाहते हैं, तो अपने परीक्षणों को फिर से लिखने की कोई आवश्यकता नहीं है।

यहाँ एक नमूना कोड है।

import junit.framework.TestCase;
import net.sourceforge.jwebunit.WebTester;

public class ExampleWebTestCase extends TestCase {
   private WebTester tester;
   
   public ExampleWebTestCase(String name) {
      super(name);
      tester = new WebTester();
   }
	
   //set base url
   public void setUp() throws Exception {
      getTestContext().setBaseUrl("http://myserver:8080/myapp");
   }
	
   // test base info
   @Test
   public void testInfoPage() {
      beginAt("/info.html");
   }
}

XMLUnit

XMLUnit एक एकल JUnit एक्सटेंशन क्लास, XMLTestCase, और सहायक कक्षाओं का एक सेट प्रदान करता है जो इस बारे में दावे करने की अनुमति देता है -

  • XML के दो टुकड़ों के बीच अंतर (डिफ और डिटेंडीएफ वर्गों के माध्यम से)।

  • XML के एक टुकड़े की वैधता (सत्यापनकर्ता वर्ग के माध्यम से)।

  • XSLT (ट्रांसफ़ॉर्म क्लास के माध्यम से) का उपयोग करके XML के एक टुकड़े को बदलने का परिणाम।

  • XML के एक टुकड़े पर एक XPath अभिव्यक्ति का मूल्यांकन (XpathEngine इंटरफ़ेस को लागू करने वाली कक्षाओं के माध्यम से)।

  • XML के एक टुकड़े में व्यक्तिगत नोड्स जो DOM ट्रैवर्सल (NodeTest वर्ग के माध्यम से) द्वारा उजागर किए जाते हैं।

आइए मान लें कि हमारे पास XML के दो टुकड़े हैं जिनकी हम तुलना करना चाहते हैं और दावा करते हैं कि वे समान हैं। हम एक साधारण परीक्षा वर्ग को इस तरह लिख सकते हैं -

import org.custommonkey.xmlunit.XMLTestCase;

public class MyXMLTestCase extends XMLTestCase {

   // this test method compare two pieces of the XML
   @Test
   public void testForXMLEquality() throws Exception {
      String myControlXML = "<msg><uuid>0x00435A8C</uuid></msg>";
      String myTestXML = "<msg><localId>2376</localId></msg>";
      assertXMLEqual("Comparing test xml to control xml", myControlXML, myTestXML);
   }
}

MockObject

एक इकाई परीक्षण में, नकली वस्तुएं जटिल, वास्तविक (गैर-नकली) वस्तुओं के व्यवहार का अनुकरण कर सकती हैं और इसलिए उपयोगी होती हैं जब एक वास्तविक वस्तु अव्यवहारिक या इकाई परीक्षण में शामिल करना असंभव होता है।

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

  • नकली वस्तुओं के उदाहरण बनाएँ।
  • नकली वस्तुओं में राज्य और अपेक्षाएं निर्धारित करें।
  • पैरामीटर के रूप में नकली वस्तुओं के साथ डोमेन कोड लागू करें।
  • नकली वस्तुओं में निरंतरता सत्यापित करें।

नीचे दिए गए Jock का उपयोग करके MockObject का एक उदाहरण है।

import org.jmock.Mockery;
import org.jmock.Expectations;

class PubTest extends TestCase {
   Mockery context = new Mockery();
   public void testSubReceivesMessage() {
      // set up
      final Sub sub = context.mock(Sub.class);

      Pub pub = new Pub();
      pub.add(sub);
    
      final String message = "message";
      
      // expectations
      context.checking(new Expectations() {
         oneOf (sub).receive(message);
      });

      // execute
      pub.publish(message);
      
      // verify
      context.assertIsSatisfied();
   }
}