BDD - एक BDD वे में TDD
TDD में, "स्वीकृति टेस्ट" शब्द भ्रामक है। स्वीकृति परीक्षण वास्तव में सिस्टम के अपेक्षित व्यवहार का प्रतिनिधित्व करते हैं। फुर्तीली प्रथाओं में, पूरी टीम के सहयोग और ग्राहक और अन्य हितधारकों के साथ बातचीत पर जोर दिया जाता है। इसने उन शर्तों के उपयोग की आवश्यकता को जन्म दिया है जो परियोजना में शामिल सभी लोगों द्वारा आसानी से समझे जाते हैं।
टीडीडी आपको आवश्यक के बारे में सोचने देता है Behavior और इसलिए शब्द 'व्यवहार' शब्द की तुलना में अधिक उपयोगी है ‘Test’। BDD एक शब्दावली के साथ टेस्ट ड्रिवेन डेवलपमेंट है जो व्यवहार पर केंद्रित है न कि परीक्षण।
डैन नॉर्थ के शब्दों में, "मुझे व्यवहार में परीक्षणों से सोच में बदलाव इतना गहरा मिला कि मैंने TDD को BDD, या व्यवहार प्रेरित विकास के रूप में संदर्भित करना शुरू कर दिया।" टीडीडी इस बात पर केंद्रित है कि कुछ कैसे काम करेगा, बीडीडी इस बात पर ध्यान केंद्रित करता है कि हम इसे बिल्कुल क्यों बनाते हैं।
BDD अक्सर डेवलपर्स द्वारा सामना किए जाने वाले निम्नलिखित सवालों के जवाब देता है -
सवाल | उत्तर |
---|---|
कहा से शुरुवात करे? | बाहर |
क्या परीक्षण करें? | प्रयोक्ता कहानियां |
क्या परीक्षण नहीं करना है? | और कुछ |
इन उत्तरों के परिणामस्वरूप कहानी की रूपरेखा इस प्रकार है -
Story Framework
के तौर पर [Role]
मुझे चाहिए [Feature]
ताकि [Benefit]
इसका मतलब है, 'जब ए Feature निष्पादित किया जाता है, जिसके परिणामस्वरूप Benefit खेल रहे व्यक्ति के लिए है Role.'
BDD निम्नलिखित प्रश्नों के उत्तर देता है -
सवाल | उत्तर |
---|---|
एक बार में कितना टेस्ट करना है? | बहुत कम-केंद्रित |
उनके परीक्षणों को क्या कहें? | वाक्य टेम्पलेट |
कैसे समझें कि एक परीक्षा में फेल क्यों हुआ | प्रलेखन |
ये उत्तर उदाहरण के ढांचे में इस प्रकार हैं -
Example Framework
Given कुछ प्रारंभिक संदर्भ,
When एक घटना होती है,
Then कुछ परिणाम सुनिश्चित करें।
इसका मतलब है, 'शुरुआती संदर्भ से शुरू होने पर, जब कोई विशेष घटना होती है, तो हमें पता होता है कि परिणाम क्या हैं should be। '
इस प्रकार, उदाहरण सिस्टम के अपेक्षित व्यवहार को दर्शाता है। सिस्टम के विभिन्न परिदृश्यों को दर्शाने के लिए उदाहरणों का उपयोग किया जाता है।
कहानी और परिदृश्य
एक एटीएम प्रणाली के बारे में डैन नॉर्थ द्वारा निम्नलिखित उदाहरण पर विचार करें।
कहानी
As a ग्राहक,
I want एटीएम से नकदी निकालना,
so that मुझे बैंक में लाइन में इंतजार नहीं करना पड़ेगा।
परिदृश्य
इस कहानी के लिए दो संभावित परिदृश्य हैं।
Scenario 1 - खाता क्रेडिट में है
Given खाता क्रेडिट में है
And कार्ड मान्य है
And मशीन में नकदी होती है
When ग्राहक नकदी का अनुरोध करता है
Then सुनिश्चित करें कि खाता डेबिट हो गया है
And सुनिश्चित करें कि नकदी छितरी हुई है
And सुनिश्चित करें कि कार्ड लौटा दिया गया है
Scenario 2 - खाता ओवरड्राफ्ट सीमा से अधिक है
Given खाता ओवरड्राॅन है
And कार्ड मान्य है
When ग्राहक नकदी का अनुरोध करता है
Then एक अस्वीकृति संदेश प्रदर्शित किया जाता है सुनिश्चित करें
And यह सुनिश्चित करना कि नकदी बिखरी हुई नहीं है
And सुनिश्चित करें कि कार्ड लौटा दिया गया है
घटना दोनों परिदृश्यों में समान है, लेकिन संदर्भ अलग है। इसलिए, परिणाम अलग हैं।
विकास चक्र
बीडीडी के लिए विकास चक्र एक है outside-in दृष्टिकोण।
Step 1- एक उच्च-स्तरीय (बाहर) व्यावसायिक मूल्य उदाहरण (ककड़ी या RSpec / Capybara का उपयोग करके) लिखें जो लाल हो जाता है। (RSpec रूबी भाषा में एक BDD ढांचा तैयार करता है)
Step 2 - कार्यान्वयन के पहले चरण के लिए निम्न-स्तरीय (अंदर) RSpec उदाहरण लिखें जो लाल हो जाता है।
Step 3 - उस निचले स्तर के उदाहरण को पारित करने के लिए न्यूनतम कोड को लागू करें, इसे हरे रंग में देखें।
Step 4 - अगला निचला-स्तरीय RSpec उदाहरण लिखें, जो लाल हो जाए चरण 1 को पार करने की ओर।
Step 5 - चरण 1 में चरण 3 और चरण 4 को दोहराएं जब तक कि चरण 1 में उच्च-स्तरीय उदाहरण हरा नहीं हो जाता।
Note - निम्नलिखित बातों को ध्यान में रखा जाना चाहिए -
Red/green राज्य अनुमति की स्थिति है।
जब आपके निम्न-स्तर के परीक्षण हरे होते हैं, तो आपको नए उदाहरण लिखने या मौजूदा कार्यान्वयन को प्रतिबिंबित करने की अनुमति होती है। आपको रिफैक्टिंग के संदर्भ में नई कार्यक्षमता / लचीलापन नहीं जोड़ना चाहिए।
जब आपके निम्न-स्तरीय परीक्षण लाल होते हैं, तो आपको केवल मौजूदा परीक्षणों को हरा बनाने के लिए कार्यान्वयन कोड लिखने या बदलने की अनुमति होती है। आपको अपने अगले टेस्ट को पास करने के लिए कोड लिखने के आग्रह का विरोध करना चाहिए, जो मौजूद नहीं है, या उन विशेषताओं को लागू करने के लिए जिन्हें आप सोच सकते हैं कि अच्छा है (ग्राहक ने पूछा नहीं होगा)।