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

SpecFlow एक ओपन-सोर्स प्रोजेक्ट है। स्रोत कोड GitHub पर होस्ट किया गया है। आपके एप्लिकेशन में सुविधाओं (उपयोग मामलों, उपयोगकर्ता कहानियों) के लिए स्वीकृति मानदंड को संग्रहीत करने के लिए SpecFlow द्वारा उपयोग की जाने वाली फ़ीचर फ़ाइलों को गेरकिन सिंटैक्स का उपयोग करके परिभाषित किया गया है।

गेरकिन प्रारूप को ककड़ी द्वारा पेश किया गया था और इसका उपयोग अन्य उपकरणों द्वारा भी किया जाता है। Gherkin पर Gherkin भाषा को एक परियोजना के रूप में बनाए रखा गया है -https://github.com/cucumber/gherkin

फ़ीचर एलिमेंट्स एंड स्पेसफ्लो

फ़ीचर तत्वों की प्रमुख विशेषताएं हैं -

  • फ़ीचर तत्व फ़ीचर फ़ाइल के लिए एक हेडर प्रदान करता है। फ़ीचर एलिमेंट में आपके एप्लिकेशन में नाम और संबंधित फ़ीचर का उच्च-स्तरीय वर्णन शामिल है।

    • SpecFlow सुविधा के नाम से व्युत्पन्न वर्ग नाम के साथ, फीचर तत्व के लिए एक इकाई परीक्षण वर्ग उत्पन्न करता है।

    • SpecFlow परिदृश्यों से निष्पादन योग्य यूनिट परीक्षण उत्पन्न करता है जो स्वीकृति मानदंडों का प्रतिनिधित्व करते हैं।

  • फीचर की स्वीकृति परीक्षणों का वर्णन करने के लिए उपयोग की जाने वाली एक विशेषता फ़ाइल में कई परिदृश्य हो सकते हैं।

    • परिदृश्य का एक नाम है और इसमें कई परिदृश्य चरण शामिल हो सकते हैं।

    • SpecFlow परिदृश्य के नाम से प्राप्त विधि नाम के साथ, प्रत्येक परिदृश्य के लिए एक इकाई परीक्षण विधि उत्पन्न करता है।

एकाधिक परिदृश्य कदम

परिदृश्य में कई परिदृश्य चरण हो सकते हैं। तीन प्रकार के चरण हैं जो पूर्व शर्त, क्रिया या सत्यापन चरणों को परिभाषित करते हैं, जो स्वीकृति परीक्षण को बनाते हैं।

  • विभिन्न प्रकार के कदम या तो इसके साथ शुरू होते हैं Given, When या Then उसी प्रकार के क्रमशः और बाद के चरणों को उपयोग करके लिंक किया जा सकता है And तथा But कीवर्ड।

  • गेरकिन सिंटैक्स इन तीन प्रकार के चरणों के किसी भी संयोजन की अनुमति देता है, लेकिन एक परिदृश्य में आमतौर पर अलग-अलग ब्लॉक होते हैं Given, When तथा Then बयान।

  • परिदृश्य चरणों को पाठ का उपयोग करके परिभाषित किया जाता है और इसमें डेटाटेबल या मल्टी-लाइन पाठ नामक अतिरिक्त तालिका हो सकती है जिसे डॉकस्ट्रिंग तर्क कहा जाता है।

  • परिदृश्य चरण अनुप्रयोग को स्वचालित करने के लिए किसी भी कस्टम कोड को निष्पादित करने का एक प्राथमिक तरीका है।

  • SpecFlow प्रत्येक परिदृश्य चरण के लिए इकाई परीक्षण विधि के अंदर एक कॉल उत्पन्न करता है। कॉल SpecFlow रनटाइम द्वारा किया जाता है जो परिदृश्य चरण से मेल खाता चरण परिभाषा निष्पादित करेगा।

  • मिलान रनटाइम पर किया जाता है, इसलिए उत्पन्न परीक्षणों को संकलित किया जा सकता है और निष्पादित किया जा सकता है, भले ही बाध्यकारी अभी तक लागू नहीं हुआ हो।

  • आप परिदृश्य चरणों में तालिका और बहु-पंक्ति तर्क शामिल कर सकते हैं। ये कदम परिभाषाओं द्वारा उपयोग किए जाते हैं और या तो अतिरिक्त तालिका या स्ट्रिंग तर्क के रूप में पारित किए जाते हैं।

टैग

टैग मार्कर हैं जिन्हें सुविधाओं और परिदृश्यों को सौंपा जा सकता है। एक फीचर को टैग असाइन करना फीचर फाइल में सभी परिदृश्यों के लिए टैग असाइन करने के बराबर है। एक प्रमुख @ @ टैग के साथ एक टैग नाम।

  • यदि यूनिट टेस्ट फ्रेमवर्क द्वारा समर्थित है, तो SpecFlow टैग से श्रेणियां बनाता है।

  • उत्पन्न श्रेणी का नाम टैग के नाम के समान है, लेकिन प्रमुख @ के बिना।

  • आप इन इकाई परीक्षण श्रेणियों का उपयोग करके निष्पादित किए जाने वाले परीक्षणों को फ़िल्टर और समूह कर सकते हैं। उदाहरण के लिए, आप @important के साथ महत्वपूर्ण परीक्षणों को टैग कर सकते हैं, और फिर इन परीक्षणों को अधिक बार निष्पादित कर सकते हैं।

पृष्ठभूमि के तत्व

पृष्ठभूमि भाषा तत्व एक सुविधा फ़ाइल में सभी परिदृश्यों के लिए एक सामान्य पूर्व शर्त निर्दिष्ट करने की अनुमति देता है

  • फ़ाइल के पृष्ठभूमि भाग में एक या एक से अधिक परिदृश्य चरण हो सकते हैं जो कि परिदृश्यों के किसी अन्य चरण से पहले निष्पादित किए जाते हैं।

  • SpecFlow पृष्ठभूमि तत्वों से एक विधि उत्पन्न करता है जो परिदृश्यों के लिए उत्पन्न सभी इकाई परीक्षणों से प्राप्त होता है।

परिदृश्य की रूपरेखा

डेटा-संचालित स्वीकृति परीक्षणों को परिभाषित करने के लिए परिदृश्य रूपरेखा का उपयोग किया जा सकता है। परिदृश्य की रूपरेखा में हमेशा एक परिदृश्य टेम्पलेट विनिर्देशन होता है (डेटा प्लेसहोल्डर्स के साथ एक परिदृश्य <प्लेसहोल्डर> सिंटैक्स का उपयोग करके) और उदाहरणों का एक सेट जो प्लेसहोल्डर्स के लिए मान प्रदान करता है

  • यदि यूनिट टेस्ट फ्रेमवर्क इसका समर्थन करता है, तो SpecFlow परिदृश्य रूपरेखा से पंक्ति-आधारित परीक्षण बनाता है।

  • अन्यथा, यह परिदृश्य परिव्यय के लिए एक मानकीकृत इकाई-परीक्षण तर्क पद्धति और प्रत्येक उदाहरण सेट के लिए एक अलग इकाई परीक्षण विधि उत्पन्न करता है।

  • बेहतर ट्रैसेबिलिटी के लिए, जेनरेट की गई यूनिट-टेस्ट विधि नाम परिदृश्य रूपरेखा शीर्षक और उदाहरणों के पहले मूल्य (उदाहरण तालिका का पहला कॉलम) से लिया गया है।

  • इसलिए उदाहरण सेट में पहले कॉलम के रूप में एक अद्वितीय और वर्णनात्मक पैरामीटर का चयन करना अच्छा अभ्यास है।

  • जैसा कि गेरकिन सिंटैक्स को परिदृश्य रूपरेखा में मिलान प्लेसहोल्डर्स रखने के लिए सभी उदाहरण कॉलम की आवश्यकता होती है, आप अधिक पठनीयता के साथ परीक्षणों को नाम देने के लिए उपयोग किए जाने वाले उदाहरण सेट में एक मनमाना कॉलम भी पेश कर सकते हैं।

  • SpecFlow चरण बाइंडिंग के मिलान से पहले प्लेसहोल्डर प्रतिस्थापन को एक अलग चरण के रूप में करता है।

  • कदम बाइंडिंग में कार्यान्वयन और पैरामीटर इस प्रकार स्वतंत्र हैं कि क्या वे एक प्रत्यक्ष परिदृश्य या एक परिदृश्य रूपरेखा के माध्यम से निष्पादित किए जाते हैं।

  • यह आपको बाद में स्टेप बाइंडिंग को बदलने के बिना स्वीकृति परीक्षणों में आगे के उदाहरणों को निर्दिष्ट करने की अनुमति देता है।

टिप्पणियाँ

आप # के साथ लाइन शुरू करके किसी भी स्थान पर फीचर फाइलों में टिप्पणी लाइनें जोड़ सकते हैं। हालांकि सावधान रहें, क्योंकि आपके विनिर्देश में टिप्पणियां एक संकेत हो सकती हैं कि स्वीकृति मानदंड गलत तरीके से निर्दिष्ट किया गया है। SpecFlow टिप्पणी लाइनों की अनदेखी करता है।