बीडीडी - टेस्ट ड्रिवेन डेवलपमेंट
जब आप व्यवहार प्रेरित विकास पर किसी भी संदर्भ को देखते हैं, तो आपको "BDD TDD से प्राप्त होता है", "BDD और TDD" जैसे वाक्यांशों का उपयोग मिलेगा। बीडीडी कैसे अस्तित्व में आया, यह जानने के लिए कि इसे टीडीडी से क्यों कहा गया है और बीडीडी और टीडीडी क्या है, आपको टीडीडी की समझ होनी चाहिए।
परीक्षण क्यों?
शुरू करने के लिए, हमें परीक्षण के मूल सिद्धांतों में शामिल होना चाहिए। परीक्षण का उद्देश्य यह सुनिश्चित करना है कि जो सिस्टम बनाया गया है वह अपेक्षित रूप से काम कर रहा है। निम्नलिखित उदाहरण पर विचार करें।
इसलिए, अनुभव से हमने सीखा है कि जब और जब इसे पेश किया जाता है तो एक दोष को उजागर करना और इसे तुरंत ठीक करना लागत प्रभावी होगा। इसलिए, विकास और परीक्षण के प्रत्येक चरण में परीक्षण मामलों को लिखने की आवश्यकता है। यह हमारे पारंपरिक परीक्षण प्रथाओं ने हमें सिखाया है, जिसे अक्सर टेस्ट-अर्ली कहा जाता है।
इस परीक्षण दृष्टिकोण को टेस्ट-लास्ट दृष्टिकोण के रूप में कहा जाता है क्योंकि परीक्षण एक चरण के पूरा होने के बाद किया जाता है।
परीक्षण-अंतिम दृष्टिकोण के साथ चुनौतियां
सॉफ्टवेयर-विकास परियोजनाओं में काफी समय तक टेस्ट-लास्ट दृष्टिकोण का पालन किया गया था। हालांकि, वास्तव में, इस दृष्टिकोण के साथ, चूंकि परीक्षण को विशेष चरण पूरा होने तक इंतजार करना पड़ता है, अक्सर इसकी वजह से अनदेखी की जाती है -
मंच के पूरा होने में देरी।
टाइट टाइम शेड्यूल।
समय पर डिलीवरी पर ध्यान दें, परीक्षण लंघन।
इसके अलावा, टेस्ट-लास्ट अप्रोच में, यूनिट टेस्टिंग, जिसे डेवलपर्स द्वारा किया जाना चाहिए, को अक्सर छोड़ दिया जाता है। पाए गए विभिन्न कारण डेवलपर्स के माइंड-सेट पर आधारित हैं -
वे डेवलपर हैं और परीक्षक नहीं हैं।
परीक्षण करना परीक्षकों की जिम्मेदारी है।
वे कोडिंग में कुशल हैं और उनके कोड में दोष नहीं होंगे।
यह परिणाम -
वितरित उत्पाद की गुणवत्ता पर समझौता।
केवल परीक्षकों पर गुणवत्ता के लिए जवाबदेही होना।
दोषों को ठीक करने में उच्च लागत, डिलीवरी के बाद।
ग्राहकों की संतुष्टि प्राप्त करने में असमर्थता, जिसका अर्थ बार-बार होने वाले व्यवसाय का नुकसान भी होगा, जिससे विश्वसनीयता प्रभावित होगी।
इन कारकों ने परीक्षण पर ध्यान केंद्रित करने के लिए प्रतिमान में बदलाव का आह्वान किया। परिणाम टेस्ट-प्रथम दृष्टिकोण था।
परीक्षण-प्रथम दृष्टिकोण
टेस्ट-प्रथम दृष्टिकोण विकास के अंदर-बाहर (लिखने के कोड और फिर परीक्षण) के स्थान पर विकास (लिखने और फिर कोड) के तरीके को बदल देता है।
इस दृष्टिकोण को निम्नलिखित सॉफ्टवेयर विकास विधियों में शामिल किया गया है (जो कि फुर्तीली भी हैं) -
इXtreme Pघूमना (XP)।
TEST DRiven Development (TDD)।
इन पद्धतियों में, डेवलपर कोड मॉड्यूल की एक पंक्ति लिखने से पहले एक कोड मॉड्यूल के लिए यूनिट परीक्षणों को डिजाइन और लिखता है। डेवलपर तब यूनिट टेस्ट पास करने के लक्ष्य के साथ कोड मॉड्यूल बनाता है। इस प्रकार, ये तरीके विकास को चलाने के लिए यूनिट परीक्षण का उपयोग करते हैं।
ध्यान देने योग्य बात यह है कि लक्ष्य परीक्षण के आधार पर विकास है।
रेड-ग्रीन-रिफ्लेक्टर साइकिल
टेस्ट ड्रिवेन डेवलपमेंट का उपयोग यूनिट परीक्षणों द्वारा निर्देशित कोड को विकसित करने के लिए किया जाता है।
Step 1 - एक कोड मॉड्यूल पर विचार करें जिसे लिखा जाना है।
Step 2 - एक परीक्षण लिखें
Step 3 - टेस्ट चलाएं।
परीक्षण विफल रहता है, क्योंकि कोड अभी भी नहीं लिखा गया है। इसलिए, चरण 2 को आमतौर पर असफल होने के लिए एक परीक्षा लिखने के रूप में संदर्भित किया जाता है।
Step 4 - टेस्ट पास करने के लिए न्यूनतम कोड संभव लिखें।
Step 5- यह सुनिश्चित करने के लिए सभी परीक्षण चलाएं कि वे अभी भी पास हैं। इस चरण को सुविधाजनक बनाने के लिए इकाई परीक्षण स्वचालित हैं।
Step 6 - रिफ्लेक्टर।
Step 7 - अगले कोड मॉड्यूल के लिए चरण 1 से चरण 6 तक दोहराएं।
प्रत्येक चक्र बहुत छोटा होना चाहिए, और एक सामान्य घंटे में कई चक्र होने चाहिए।
यह भी लोकप्रिय रूप में जाना जाता है Red-Green-Refactor साइकिल, जहां -
Red - एक परीक्षा लिखना जो विफल हो जाता है।
Green - टेस्ट पास करने के लिए कोड लिखना।
Refactor - दोहराव निकालें और कोड को स्वीकार्य मानकों में सुधारें।
टीडीडी प्रक्रिया चरण
टीडीडी प्रक्रिया के चरणों को नीचे चित्रित किया गया है।
TDD के लाभ
टेस्ट ड्रिवेन डेवलपमेंट के लाभ या फायदे हैं -
डेवलपर को सबसे पहले यह समझने की जरूरत है कि कोड बनाने से पहले वांछित परिणाम क्या होना चाहिए और इसका परीक्षण कैसे किया जाए।
एक घटक के लिए कोड केवल तभी समाप्त होता है जब परीक्षण पास हो जाता है और कोड फिर से सक्रिय हो जाता है। डेवलपर द्वारा अगले परीक्षण पर जाने से पहले यह परीक्षण और रीफैक्टरिंग सुनिश्चित करता है।
जैसा कि प्रत्येक परिशोधन के बाद इकाई परीक्षणों के सुइट को चलाया जाता है, प्रतिक्रिया है कि प्रत्येक घटक अभी भी काम कर रहा है स्थिर है।
यूनिट परीक्षण जीवित दस्तावेज के रूप में कार्य करता है जो हमेशा डेटा तक रहता है।
यदि कोई दोष पाया जाता है, तो डेवलपर उस दोष को प्रकट करने के लिए एक परीक्षण बनाता है और फिर कोड को संशोधित करता है ताकि परीक्षण पास हो जाए और दोष ठीक हो जाए। इससे डिबगिंग का समय कम हो जाता है। अन्य सभी परीक्षण भी चलाए जाते हैं और जब वे पास होते हैं, तो यह सुनिश्चित करता है कि मौजूदा कार्यक्षमता टूटी नहीं है
डेवलपर किसी भी समय डिजाइन निर्णय और रिफ्लेक्टर बना सकता है और परीक्षणों का चलना सुनिश्चित करता है कि सिस्टम अभी भी काम कर रहा है। यह सॉफ्टवेयर को बनाए रखने योग्य बनाता है।
डेवलपर को किसी भी परिवर्तन करने का विश्वास है क्योंकि यदि परिवर्तन किसी भी मौजूदा कार्यक्षमता को प्रभावित करता है, तो परीक्षण चलाने से इसका पता चलता है और दोष तुरंत ठीक किया जा सकता है।
प्रत्येक क्रमिक परीक्षण रन पर, पिछले सभी दोषों को भी सत्यापित किया जाता है और उसी दोष की पुनरावृत्ति को कम किया जाता है।
जैसा कि अधिकांश परीक्षण विकास के दौरान ही किया जाता है, प्रसव से पहले परीक्षण को छोटा कर दिया जाता है।
टीडीडी के नुकसान
शुरुआती बिंदु उपयोगकर्ता कहानियां है, जो सिस्टम के व्यवहार का वर्णन करता है। इसलिए, डेवलपर्स अक्सर निम्नलिखित सवालों का सामना करते हैं -
कब करें टेस्ट?
क्या परीक्षण करें?
कैसे पता करें कि क्या कोई विनिर्देशन पूरा हुआ है?
क्या कोड व्यवसाय मूल्य प्रदान करता है?
टीडीडी के बारे में गलत धारणाएं
निम्नलिखित गलतफहमी उद्योग में मौजूद हैं और स्पष्टीकरण की आवश्यकता है।
ग़लतफ़हमी | स्पष्टीकरण |
---|---|
टीडीडी परीक्षण और परीक्षण स्वचालन के बारे में है। | टीडीडी टेस्ट-प्रथम दृष्टिकोण का उपयोग करके एक विकास पद्धति है। |
टीडीडी में कोई डिज़ाइन शामिल नहीं है। | टीडीडी में आवश्यकताओं के आधार पर महत्वपूर्ण विश्लेषण और डिजाइन शामिल हैं। डिजाइन विकास के दौरान उभरता है। |
टीडीडी केवल यूनिट स्तर पर है। | टीडीडी को एकीकरण और सिस्टम स्तरों पर उपयोग किया जा सकता है। |
TDD का उपयोग पारंपरिक परीक्षण परियोजनाओं द्वारा नहीं किया जा सकता है। | टीडीडी चरम प्रोग्रामिंग के साथ लोकप्रिय हो गया और इसका उपयोग अन्य चुस्त तरीकों में किया जा रहा है। हालाँकि, इसका उपयोग पारंपरिक परीक्षण परियोजनाओं में भी किया जा सकता है। |
TDD एक टूल है। | टीडीडी एक विकास पद्धति है, और प्रत्येक नए यूनिट टेस्ट पास होने के बाद, इसे ऑटोमेशन टेस्ट सूट में जोड़ा जाता है, क्योंकि जब भी कोई नया कोड जोड़ा जाता है या मौजूदा कोड को संशोधित किया जाता है और प्रत्येक रिफैक्टरिंग के बाद भी सभी परीक्षणों को चलाने की आवश्यकता होती है। इस प्रकार, TDD का समर्थन करने वाले टेस्ट ऑटोमेशन टूल इस प्रक्रिया को सुविधाजनक बनाते हैं। |
TDD का अर्थ है डेवलपर्स को स्वीकृति परीक्षण सौंपना। | TDD का अर्थ डेवलपर्स को स्वीकृति टेस्ट देना नहीं है। |
स्वीकृति टीडीडी
स्वीकृति टेस्ट ड्रिवेन डेवलपमेंट (ATDD), विकास के आरंभ में, उपयोगकर्ता स्टोरीज़ के निर्माण के दौरान एक्सेप्टेंस मानदंड और स्वीकृति टेस्ट को परिभाषित करता है। ATDD ग्राहकों, डेवलपर्स और परीक्षकों के बीच संचार और सामान्य समझ पर केंद्रित है।
ATDD में प्रमुख अभ्यास इस प्रकार हैं -
डोमेन की साझा समझ बनाने के लिए वास्तविक दुनिया के परिदृश्यों पर चर्चा करें।
स्वीकृति मानदंडों पर पहुंचने के लिए उन परिदृश्यों का उपयोग करें।
स्वत: स्वीकृति परीक्षण।
उन परीक्षणों पर ध्यान केंद्रित करें।
परिवर्तन की सुविधा के लिए एक लाइव विनिर्देश के रूप में परीक्षणों का उपयोग करें।
ATDD का उपयोग करने के लाभ इस प्रकार हैं -
आवश्यकताएं अस्पष्ट हैं और कार्यात्मक अंतराल के बिना।
अन्य उन विशेष मामलों को समझते हैं जो डेवलपर्स को पूर्वाभास कराते हैं।
स्वीकृति परीक्षण विकास का मार्गदर्शन करता है।
टीडीडी बनाम बी.डी.डी.
डैन नॉर्थ के अनुसार, टेस्ट ड्रिवेन डेवलपमेंट करते समय प्रोग्रामर को आमतौर पर निम्नलिखित समस्याओं का सामना करना पड़ता है -
कहा से शुरुवात करे
क्या टेस्ट करना है और क्या नहीं टेस्ट करना है
एक बार में कितना टेस्ट करना है
उनके परीक्षणों को क्या कहें
कैसे समझें कि एक परीक्षा में फेल क्यों हुआ
इन सभी समस्याओं का हल है बिहेवियर ड्रिवेन डेवलपमेंट। यह स्थापित चुस्त प्रथाओं से विकसित हुआ है और उन्हें टीमों के लिए अधिक सुलभ और प्रभावी बनाने के लिए डिज़ाइन किया गया है, जो चुस्त सॉफ़्टवेयर डिलीवरी के लिए नया है। समय के साथ, बीडीडी चुस्त विश्लेषण और स्वचालित स्वीकृति परीक्षण की व्यापक तस्वीर को शामिल करने के लिए बढ़ गया है।
मुख्य difference between TDD and BDD वह है -
TDD बताता है कि सॉफ्टवेयर कैसे काम करता है।
दूसरी ओर, बीडीडी -
बताता है कि अंतिम उपयोगकर्ता सॉफ़्टवेयर का उपयोग कैसे करता है।
सहयोग और संचार को बढ़ावा देता है।
सिस्टम के व्यवहार के उदाहरणों पर जोर देता है।
उदाहरणों से प्राप्त निष्पादन योग्य विशिष्टताओं पर उद्देश्य