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