व्यवहार प्रेरित विकास - घेरकिन

घेरकिन एक भाषा है, जिसका उपयोग लिखने के लिए किया जाता है 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

अपने सिस्टम में सुविधाओं की पहचान करने के लिए, आप "फीचर इंजेक्शन टेम्पलेट" के रूप में जाना जाता है का उपयोग कर सकते हैं।

<कुछ प्रकार के> <एक प्रकार के उपयोगकर्ता> के रूप में <मैं चाहता हूं कि मैं <a फीचर> चाहता हूं

विवरण

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    |

एक परिदृश्य रूपरेखा अनुभाग हमेशा उदाहरण के एक या एक से अधिक वर्गों द्वारा पीछा किया जाता है, जो एक तालिका के लिए एक कंटेनर होते हैं। तालिका में परिदृश्य रूपरेखा चरणों में चर के अनुरूप हेडर पंक्ति होनी चाहिए। नीचे दी गई प्रत्येक पंक्तियों को एक नया परिदृश्य बनाया जाएगा, जो चर मानों को भर देगा