व्यवहार प्रेरित विकास - घेरकिन
घेरकिन एक भाषा है, जिसका उपयोग लिखने के लिए किया जाता है Features, Scenarios, and Steps। गेरकिन का उद्देश्य हमें ठोस आवश्यकताओं को लिखने में मदद करना है।
ठोस आवश्यकताओं से हमारा क्या मतलब है, यह समझने के लिए, निम्नलिखित उदाहरण पर विचार करें -
ग्राहकों को अमान्य क्रेडिट कार्ड विवरण दर्ज करने से रोका जाना चाहिए।
यदि कोई ग्राहक क्रेडिट कार्ड नंबर दर्ज करता है जो ठीक 16 अंकों का नहीं है, जब वे फॉर्म जमा करने की कोशिश करते हैं, तो उन्हें त्रुटि संदेश के साथ फिर से परिभाषित किया जाना चाहिए, जिससे उन्हें अंकों की सही संख्या की सलाह दी जा सके।
उत्तरार्द्ध में कोई अस्पष्टता नहीं है और त्रुटियों से बचा जाता है और बहुत अधिक परीक्षण योग्य है।
गेरकिन को उन आवश्यकताओं को बनाने के लिए डिज़ाइन किया गया है जो अधिक ठोस हैं। घेरकिन में, उपरोक्त उदाहरण दिखता है -
Feature
अमान्य क्रेडिट कार्ड विवरण दर्ज करते समय प्रतिक्रिया Feature Definition
उपयोगकर्ता परीक्षण में, हमने कई लोगों को देखा है जो गलतियों का दस्तावेज़ीकरण करते हैं
Background True for all Scenarios Below
Given मैंने एक आइटम को खरीदने के लिए चुना है,
And मैं अपना क्रेडिट कार्ड नंबर दर्ज करने वाला हूं
Scenario - क्रेडिट कार्ड नंबर बहुत कमScenario Definition
When मैं एक कार्ड नंबर दर्ज करता हूं जो 16 अंकों से कम लंबा है
And अन्य सभी विवरण सही हैं
And मैं फॉर्म जमा करता हूंSteps
Then फॉर्म को फिर से जांचा जाना चाहिए
And मुझे एक संदेश देखना चाहिए जो मुझे अंकों की सही संख्या की सलाह दे रहा है
घेरकिन प्रारूप और सिंटेक्स
Gherkin फाइलें सादा पाठ फ़ाइलें हैं और एक्सटेंशन .feature हैं। प्रत्येक पंक्ति जो रिक्त नहीं है उसे एक Gherkin कीवर्ड के साथ शुरू करना होगा, इसके बाद आपको कोई भी पाठ पसंद आएगा। कीवर्ड हैं -
Feature
Scenario
दिया, जब, फिर, और, लेकिन (कदम)
Background
परिदृश्य की रूपरेखा
Examples
"" (डॉक स्ट्रिंग्स)
| (डाटा टेबल्स)
@ (टैग)
# (टिप्पणियाँ)
*
फ़ीचर
Featureकिसी सॉफ़्टवेयर सुविधा का वर्णन करने के लिए और संबंधित परिदृश्यों को समूहित करने के लिए कीवर्ड का उपयोग किया जाता है। एक फ़ीचर में तीन मूल तत्व होते हैं -
कीवर्ड - फ़ीचर।
फीचर का नाम, फीचर कीवर्ड के समान लाइन पर प्रदान किया गया है।
एक वैकल्पिक (लेकिन अत्यधिक अनुशंसित) विवरण जिसमें कई पंक्तियाँ हो सकती हैं अर्थात कीवर्ड विशेषता वाली रेखा के बीच सभी पाठ, और एक पंक्ति जो परिदृश्य, पृष्ठभूमि, या परिदृश्य रूपरेखा से शुरू होती है।
नाम और विवरण के अलावा, विशेषताओं में परिदृश्यों या परिदृश्य रूपरेखा और वैकल्पिक पृष्ठभूमि की एक सूची होती है।
यह नाम के लिए पारंपरिक है .featureफ़ाइल को फ़ीचर का नाम देकर, इसे लोअरकेस में कनवर्ट करें और स्पेस को अंडरलाइन से बदलें। उदाहरण के लिए,
feedback_when_entering_invalid_credit_card_details.feature
अपने सिस्टम में सुविधाओं की पहचान करने के लिए, आप "फीचर इंजेक्शन टेम्पलेट" के रूप में जाना जाता है का उपयोग कर सकते हैं।
विवरण
Gherkin दस्तावेजों के कुछ हिस्सों को एक कीवर्ड से शुरू नहीं करना पड़ता है।
फ़ीचर, परिदृश्य, परिदृश्य रूपरेखा या उदाहरणों का अनुसरण करते हुए, आप अपनी पसंद के अनुसार कुछ भी लिख सकते हैं, जब तक कि कोई पंक्ति किसी कीवर्ड से शुरू न हो। यह विवरण शामिल करने का तरीका है।
परिदृश्य
अपने सिस्टम के व्यवहार को व्यक्त करने के लिए, आप प्रत्येक फ़ीचर के साथ एक या अधिक परिदृश्य संलग्न करते हैं। यह फ़ीचर के आसपास के सभी व्यवहारों को पूरी तरह से निर्दिष्ट करने के लिए फ़ीचर प्रति 5 से 20 परिदृश्यों को देखना विशिष्ट है।
परिदृश्य निम्नलिखित पैटर्न का अनुसरण करते हैं -
एक प्रारंभिक संदर्भ का वर्णन करें
एक घटना का वर्णन करें
एक अपेक्षित परिणाम बताएं
हम एक संदर्भ से शुरू करते हैं, एक कार्रवाई का वर्णन करते हैं, और परिणाम की जांच करते हैं। यह चरणों के साथ किया जाता है। गेरकिन तीन संदर्भों को कदम के रूप में संदर्भों, कार्यों और परिणामों का वर्णन करने के लिए प्रदान करता है।
Given - संदर्भ स्थापित करें
When - कार्रवाई करें
Then - परिणाम की जाँच करें
ये कीवर्ड परिदृश्य की पठनीयता प्रदान करते हैं।
Example
Scenario - खाते से पैसा निकालना।
Given मेरे खाते में $ 100 हैं।
When मैं 20 डॉलर का अनुरोध करता हूं।
Then $ 20 का वितरण किया जाना चाहिए।
अगर कई हैं Given या When एक दूसरे के नीचे कदम, आप उपयोग कर सकते हैं And या But। वे आपको परिदृश्यों को विस्तार से निर्दिष्ट करने की अनुमति देते हैं।
Example
Scenario - चोरी किए गए कार्ड का उपयोग कर निकासी का प्रयास।
Given मेरे खाते में $ 100 हैं।
But मेरा कार्ड अमान्य है।
When मैं $ 50 का अनुरोध करता हूं।
Then मेरा कार्ड वापस नहीं किया जाना चाहिए।
And मुझे बैंक से संपर्क करने के लिए कहा जाना चाहिए।
परिदृश्य बनाते समय, याद रखें 'प्रत्येक परिदृश्य को समझ में आना चाहिए और किसी अन्य परिदृश्य के स्वतंत्र रूप से निष्पादित होने में सक्षम होना चाहिए'। इसका मतलब है -
आपके पास एक परिदृश्य की सफलता की स्थिति इस तथ्य पर निर्भर नहीं कर सकती है कि कुछ अन्य परिदृश्य को इससे पहले निष्पादित किया गया था।
प्रत्येक परिदृश्य अपना विशेष संदर्भ बनाता है, एक चीज को निष्पादित करता है, और परिणाम का परीक्षण करता है।
इस तरह के परिदृश्य निम्नलिखित लाभ प्रदान करते हैं -
टेस्ट सरल और समझने में आसान होंगे।
आप अपने परिदृश्यों का एक सबसेट चला सकते हैं और आपको अपने परीक्षण सेट के टूटने के बारे में चिंता करने की आवश्यकता नहीं है।
आपके सिस्टम के आधार पर, आप अपने सभी परीक्षणों को निष्पादित करने में लगने वाले समय को कम करते हुए, समानांतर में परीक्षण चलाने में सक्षम हो सकते हैं।
परिदृश्य की रूपरेखा
यदि आपको कई इनपुट या आउटपुट के साथ परिदृश्य लिखना है, तो आप कई परिदृश्य बना सकते हैं जो केवल उनके मूल्यों से भिन्न होते हैं। समाधान परिदृश्य रूपरेखा का उपयोग करना है। एक परिदृश्य रूपरेखा लिखने के लिए,
परिदृश्य रूपरेखा चरणों में चर <और> के साथ चिह्नित हैं।
चरों के लिए विभिन्न मान एक तालिका में उदाहरण के रूप में दिए गए हैं।
Example
मान लीजिए आप किसी कैलकुलेटर पर दो नंबर जोड़ने के लिए एक फीचर लिख रहे हैं।
Feature - जोड़ें।
Scenario Outline: Add two numbers.
Given the input "<input>"
When the calculator is run
Then the output should be <output>"
Examples
| input | output |
| 2+2 | 4 |
| 98+1 | 99 |
| 255+390 | 645 |
एक परिदृश्य रूपरेखा अनुभाग हमेशा उदाहरण के एक या एक से अधिक वर्गों द्वारा पीछा किया जाता है, जो एक तालिका के लिए एक कंटेनर होते हैं। तालिका में परिदृश्य रूपरेखा चरणों में चर के अनुरूप हेडर पंक्ति होनी चाहिए। नीचे दी गई प्रत्येक पंक्तियों को एक नया परिदृश्य बनाया जाएगा, जो चर मानों को भर देगा