RSpec - त्वरित गाइड

RSpec रूबी प्रोग्रामिंग भाषा के लिए एक इकाई परीक्षण ढांचा है। RSpec, JUnit जैसे पारंपरिक xUnit चौखटे से अलग है क्योंकि RSpec एक व्यवहार चालित विकास उपकरण है। इसका मतलब यह है कि, RSpec में लिखे गए परीक्षण परीक्षण किए जा रहे एप्लिकेशन के "व्यवहार" पर ध्यान केंद्रित करते हैं। RSpec इस बात पर जोर नहीं देता है कि आवेदन कैसे काम करता है, लेकिन इसके बजाय यह कैसे व्यवहार करता है, दूसरे शब्दों में, आवेदन वास्तव में क्या करता है।

RSpec पर्यावरण

सबसे पहले, आपको अपने कंप्यूटर पर रूबी को स्थापित करना होगा। हालांकि, यदि आपने पहले से नहीं किया है, तो आप रूबी को मुख्य रूबी वेबसाइट - रूबी से डाउनलोड और इंस्टॉल कर सकते हैं ।

यदि आप विंडोज पर रूबी स्थापित कर रहे हैं, तो आपको यहां विंडोज के लिए रूबी इंस्टॉलर होना चाहिए - http://www.rubyinstaller.org

इस ट्यूटोरियल के लिए, आपको केवल टेक्स्ट एडिटर की आवश्यकता होगी, जैसे कि नोटपैड और कमांड लाइन कंसोल। यहां उदाहरण विंडोज पर cmd.exe का उपयोग करेंगे।

Cmd.exe को चलाने के लिए, बस स्टार्ट मेनू पर क्लिक करें और "cmd.exe" टाइप करें, फिर रिटर्न कुंजी दबाएं।

अपने cmd.exe विंडो में कमांड प्रॉम्प्ट पर, निम्न आदेश टाइप करें कि रूबी आप किस संस्करण का उपयोग कर रहे हैं -

ruby -v

आपको नीचे दिए गए आउटपुट को देखना चाहिए जो इस तरह दिखता है -

ruby 2.2.3p173 (2015-08-18 revision 51636) [x64-mingw32]

इस ट्यूटोरियल के उदाहरण रूबी 2.2.3 का उपयोग करेंगे लेकिन 2.0.0 से अधिक रूबी का कोई भी संस्करण पर्याप्त होगा। अगला, हमें आपकी रूबी स्थापना के लिए RSpec रत्न स्थापित करना होगा। एक रत्न एक रूबी पुस्तकालय है जिसे आप अपने कोड में उपयोग कर सकते हैं। मणि स्थापित करने के लिए, आपको मणि का उपयोग करने की आवश्यकता हैgem आदेश।

अब Rspec रत्न स्थापित करें। अपने cmd.exe विंडो पर वापस जाएं और निम्न टाइप करें -

gem install rspec

आपके पास आश्रित रत्नों की एक सूची होनी चाहिए जो कि स्थापित किए गए थे, ये ऐसे रत्न हैं जिन्हें आरएसईपी रत्न को सही ढंग से कार्य करने की आवश्यकता है आउटपुट के अंत में, आपको कुछ ऐसा दिखना चाहिए जो ऐसा दिखता है -

Done installing documentation for diff-lcs, rspec-support, rspec-mocks,
   rspec-expectations, rspec-core, rspec after 22 seconds 
6 gems installed

चिंता मत करो, अगर आपका आउटपुट बिल्कुल एक जैसा नहीं दिखता है। इसके अलावा, यदि आप मैक या लिनक्स कंप्यूटर का उपयोग कर रहे हैं, तो आपको चलाने की आवश्यकता हो सकती हैgem install rspec कमांड का उपयोग करना sudo या rspec रत्न को स्थापित करने के लिए HomeBrew या RVM जैसे टूल का उपयोग करें।

Hello World

आरंभ करने के लिए, आइए अपनी RSpec फ़ाइलों को संग्रहीत करने के लिए एक निर्देशिका (फ़ोल्डर) बनाएं। अपनी cmd.exe विंडो में, निम्न टाइप करें -

cd \

फिर टाइप करें -

mkdir rspec_tutorial

और अंत में, टाइप करें -

cd rspec_tutorial

यहां से, हम एक अन्य निर्देशिका बनाने जा रहे हैं जिसका नाम कल्पना है, इसे टाइप करके करें -

mkdir spec

हम इस फ़ोल्डर में अपनी RSpec फ़ाइलों को संग्रहीत करने जा रहे हैं। RSpec फ़ाइलों को "चश्मा" के रूप में जाना जाता है। यदि यह आपको भ्रमित करने वाला लगता है, तो आप कल्पना फ़ाइल को परीक्षण फ़ाइल के रूप में सोच सकते हैं। RSpec "युक्ति" शब्द का उपयोग करता है जो "विनिर्देश" के लिए संक्षिप्त रूप है।

चूंकि, RSpec एक BDD परीक्षण उपकरण है, इसलिए लक्ष्य इस पर ध्यान केंद्रित करता है कि आवेदन क्या करता है और क्या यह विनिर्देश का पालन करता है या नहीं। व्यवहार चालित विकास में, विनिर्देश को अक्सर "उपयोगकर्ता कहानी" के रूप में वर्णित किया जाता है। RSpec को स्पष्ट करने के लिए डिज़ाइन किया गया है कि क्या विनिर्देशन के बाद दूसरे शब्दों में लक्ष्य कोड सही व्यवहार कर रहा है।

आइए अपने हैलो वर्ल्ड कोड पर लौटते हैं। एक पाठ संपादक खोलें और निम्नलिखित कोड जोड़ें -

class HelloWorld

   def say_hello 
      "Hello World!"
   end
   
end

describe HelloWorld do 
   context “When testing the HelloWorld class” do 
      
      it "should say 'Hello World' when we call the say_hello method" do 
         hw = HelloWorld.new 
         message = hw.say_hello 
         expect(message).to eq "Hello World!"
      end
      
   end
end

इसके बाद, अपने द्वारा बनाए गए विशेष फ़ोल्डर में hello_world_spec.rb नामक फ़ाइल में इसे सहेजें। अब अपनी cmd.exe विंडो में वापस, इस कमांड को चलाएँ -

rspec spec spec\hello_world_spec.rb

जब कमांड पूरी हो जाती है, तो आपको आउटपुट देखना चाहिए जो इस तरह दिखता है -

Finished in 0.002 seconds (files took 0.11101 seconds to load) 
1 example, 0 failures

बधाई हो, आपने अभी अपना पहला RSpec यूनिट टेस्ट बनाया और चलाया!

अगले भाग में, हम RSpec फ़ाइलों के सिंटैक्स पर चर्चा करना जारी रखेंगे।

आइए हमारे कोड पर एक करीब से नज़र डालें HelloWorldउदाहरण। सबसे पहले, यदि यह स्पष्ट नहीं है, तो हम इसकी कार्यक्षमता का परीक्षण कर रहे हैंHelloWorldकक्षा। यह निश्चित रूप से, एक बहुत ही सरल वर्ग है जिसमें केवल एक विधि होती हैsay_hello()

यहाँ RSpec कोड फिर से है -

describe HelloWorld do 
   context “When testing the HelloWorld class” do 
      
      it "The say_hello method should return 'Hello World'" do 
         hw = HelloWorld.new 
         message = hw.say_hello 
         expect(message).to eq "Hello World!" 
      end
      
   end 
end

कीवर्ड का वर्णन करें

शब्द describeएक RSpec कीवर्ड है। इसका उपयोग "उदाहरण समूह" को परिभाषित करने के लिए किया जाता है। आप परीक्षणों के संग्रह के रूप में "उदाहरण समूह" के बारे में सोच सकते हैं। describeकीवर्ड क्लास का नाम और / या स्ट्रिंग तर्क ले सकता है। आपको ब्लॉक तर्क पास करने की भी आवश्यकता हैdescribe, इसमें व्यक्तिगत परीक्षण शामिल होंगे, या जैसा कि वे RSpec, "उदाहरण" में जाने जाते हैं। ब्लॉक केवल रूबी द्वारा नामित एक रूबी ब्लॉक हैdo/end कीवर्ड।

संदर्भ कीवर्ड

context कीवर्ड के समान है describe। यह भी एक वर्ग नाम और / या स्ट्रिंग तर्क को स्वीकार कर सकता है। आपको एक ब्लॉक का उपयोग करना चाहिएcontextभी। संदर्भ का विचार यह है कि यह एक निश्चित प्रकार के परीक्षणों को संलग्न करता है।

उदाहरण के लिए, आप विभिन्न संदर्भों वाले उदाहरणों के समूहों को इस तरह निर्दिष्ट कर सकते हैं -

context “When passing bad parameters to the foobar() method” 
context “When passing valid parameters to the foobar() method” 
context “When testing corner cases with the foobar() method”

context कीवर्ड अनिवार्य नहीं है, लेकिन यह उन उदाहरणों के बारे में अधिक विवरण जोड़ने में मदद करता है जो इसमें शामिल हैं।

यह खोजशब्द

शब्द itएक और RSpec कीवर्ड है जिसका उपयोग "उदाहरण" को परिभाषित करने के लिए किया जाता है। एक उदाहरण मूल रूप से एक परीक्षण या एक परीक्षण का मामला है। फिर से, जैसेdescribe तथा context, it वर्ग नाम और स्ट्रिंग तर्क दोनों को स्वीकार करता है और इसे ब्लॉक तर्क के साथ उपयोग किया जाना चाहिए, जिसके साथ निर्दिष्ट किया गया है do/end। के मामले मेंit, यह केवल एक स्ट्रिंग और ब्लॉक तर्क पारित करने के लिए प्रथागत है। स्ट्रिंग तर्क अक्सर "चाहिए" शब्द का उपयोग करता है और यह वर्णन करने के लिए होता है कि अंदर क्या विशिष्ट व्यवहार होना चाहिएit block। दूसरे शब्दों में, यह वर्णन करता है कि अपेक्षित परिणाम उदाहरण के लिए है।

ध्यान दें it block हमारे HelloWorld उदाहरण से -

it "The say_hello method should return 'Hello World'" do

यह स्ट्रिंग स्पष्ट करती है कि हैलोवर्ल्ड क्लास के उदाहरण पर जब हम हैलो कहते हैं तो क्या होना चाहिए। RSpec दर्शन का यह हिस्सा, एक उदाहरण सिर्फ एक परीक्षा नहीं है, यह एक विनिर्देश (एक युक्ति) भी है। दूसरे शब्दों में, एक उदाहरण दोनों दस्तावेज़ और आपके रूबी कोड के अपेक्षित व्यवहार का परीक्षण करता है।

उम्मीद की खोजशब्द

expectRSpec में "उम्मीद" को परिभाषित करने के लिए कीवर्ड का उपयोग किया जाता है। यह एक सत्यापन चरण है जहां हम जांच करते हैं, कि एक विशिष्ट अपेक्षित स्थिति पूरी हो गई है।

हमारे HelloWorld उदाहरण से, हमारे पास है -

expect(message).to eql "Hello World!"

के साथ विचार expectकथन यह है कि वे सामान्य अंग्रेजी की तरह पढ़ते हैं। आप इस जोर से कह सकते हैं "स्ट्रिंग संदेश को समान करने की अपेक्षा करें 'हैलो वर्ल्ड'। विचार यह है कि इसका वर्णनात्मक और पढ़ने में आसान है, यहां तक ​​कि परियोजना प्रबंधकों जैसे गैर-तकनीकी हितधारकों के लिए भी।

The to keyword

to कीवर्ड का उपयोग भाग के रूप में किया जाता है expectबयान। ध्यान दें कि आप भी उपयोग कर सकते हैंnot_toविपरीत व्यक्त करने के लिए कीवर्ड, जब आप चाहते हैं कि उम्मीद झूठी है। आप देख सकते हैं कि इसका उपयोग डॉट के साथ किया जाता है,expect(message).to,क्योंकि यह वास्तव में सिर्फ एक नियमित रूबी विधि है। वास्तव में, सभी RSpec कीवर्ड वास्तव में सिर्फ रूबी तरीके हैं।

The eql keyword

eqlकीवर्ड एक विशेष RSpec कीवर्ड है जिसे एक मिलानकर्ता कहा जाता है। आप मैचर्स का उपयोग यह निर्दिष्ट करने के लिए करते हैं कि आप किस प्रकार की स्थिति को सही (या गलत) मान रहे हैं।

हमारे HelloWorld में expect बयान, यह स्पष्ट है कि eqlस्ट्रिंग समानता का मतलब है। ध्यान दें, रूबी में विभिन्न प्रकार के समानता ऑपरेटर हैं और परिणामस्वरूप RSpec में अलग-अलग मिलानकर्ता हैं। हम बाद के अनुभाग में कई अलग-अलग प्रकार के मिलानकर्ताओं का पता लगाएंगे।

इस अध्याय में, हम एक नई रूबी क्लास बनाएंगे, इसे अपनी फाइल में सेव करेंगे और इस क्लास को टेस्ट करने के लिए एक अलग स्पेक फाइल बनाएंगे।

सबसे पहले, हमारी नई कक्षा में, इसे कहा जाता है StringAnalyzer। यह एक साधारण वर्ग है, जो आपने अनुमान लगाया है, तार का विश्लेषण करता है। हमारी कक्षा में केवल एक विधि हैhas_vowels?जैसा कि इसके नाम से पता चलता है, यदि स्ट्रिंग में स्वर और असत्य हैं तो यह सही है। यहाँ के लिए कार्यान्वयन हैStringAnalyzer -

class StringAnalyzer 
   def has_vowels?(str) 
      !!(str =~ /[aeio]+/i) 
   end 
end

यदि आपने HelloWorld अनुभाग का पालन किया है, तो आपने C: \ rspec_tutorial \ कल्पना नामक एक फ़ोल्डर बनाया है।

यदि आपके पास है तो hello_world.rb फ़ाइल को हटा दें और StringAnalyzer कोड को ऊपर एक फ़ाइल में string_analyzer.rb के नाम से C: \ rspec_tutorial \ कल्पना फ़ोल्डर में सहेजें।

StringAnalyzer का परीक्षण करने के लिए हमारी विशेष फ़ाइल का स्रोत यहां दिया गया है -

require 'string_analyzer' 

describe StringAnalyzer do 
   context "With valid input" do 
      
      it "should detect when a string contains vowels" do 
         sa = StringAnalyzer.new 
         test_string = 'uuu' 
         expect(sa.has_vowels? test_string).to be true 
      end 
		
      it "should detect when a string doesn't contain vowels" do 
         sa = StringAnalyzer.new 
         test_string = 'bcdfg' 
         expect(sa.has_vowels? test_string).to be false
      end 
      
   end 
end

इसे उसी स्पेसी डायरेक्टरी में सेव करें, इसे string_analyzer_test.rb नाम दिया गया है।

अपनी cmd.exe विंडो में, सीडी से C: \ rspec_tutorial फ़ोल्डर और इस कमांड को चलाएं: dir Spec

आपको निम्नलिखित देखना चाहिए -

C: \ rspec_tutorial \ कल्पना की निर्देशिका

09/13/2015 08:22 AM  <DIR>    .
09/13/2015 08:22 AM  <DIR>    ..
09/12/2015 11:44 PM                 81 string_analyzer.rb
09/12/2015 11:46 PM              451 string_analyzer_test.rb

अब हम अपने परीक्षण चलाने जा रहे हैं, इस कमांड को चलाएं: rspec कल्पना

जब आप किसी फ़ोल्डर का नाम पास करते हैं rspec, यह फ़ोल्डर के अंदर सभी विशेष फाइलों को चलाता है। आपको यह परिणाम देखना चाहिए -

No examples found.

Finished in 0 seconds (files took 0.068 seconds to load)
0 examples, 0 failures

ऐसा होने का कारण यह है कि, डिफ़ॉल्ट रूप से, rspecकेवल उन फ़ाइलों को चलाता है जिनके नाम "_spec.rb" में समाप्त होते हैं। String_analyzer_test.rb को string_analyzer_spec.rb नाम दें। आप इस कमांड को चलाकर आसानी से कर सकते हैं -

ren spec\string_analyzer_test.rb string_analyzer_spec.rb

अब, भागो rspec कल्पना फिर से, आपको इस तरह दिखने वाले आउटपुट को देखना चाहिए -

F.
Failures:

   1) StringAnalyzer With valid input should detect when a string contains vowels
      Failure/Error: expect(sa.has_vowels? test_string).to be true 
         expected true
            got false
      # ./spec/string_analyzer_spec.rb:9:in `block (3 levels) in <top (required)>'

Finished in 0.015 seconds (files took 0.12201 seconds to load)
2 examples, 1 failure

Failed examples:
rspec ./spec/string_analyzer_spec.rb:6 # StringAnalyzer With valid 
   input should detect when a string contains vowels
Do you see what just happened? Our spec failed because we have a bug in 
   StringAnalyzer. The bug is simple to fix, open up string_analyzer.rb
   in a text editor and change this line:
!!(str =~ /[aeio]+/i)
to this:
!!(str =~ /[aeiou]+/i)

अब, आप केवल string_analyizer.rb में किए गए परिवर्तनों को सहेजें और rspec स्पेक कमांड को फिर से चलाएं, अब आपको आउटपुट दिखना चाहिए जो दिखता है -

..
Finished in 0.002 seconds (files took 0.11401 seconds to load)
2 examples, 0 failures

बधाई, आपकी कल्पना फ़ाइल में उदाहरण (परीक्षण) अब गुजर रहे हैं। हमने नियमित अभिव्यक्ति में एक बग तय किया है जिसमें स्वर विधि है लेकिन हमारे परीक्षण पूर्ण नहीं हैं।

यह अधिक उदाहरणों को जोड़ने के लिए समझ में आता है जो विभिन्न प्रकार के इनपुट तार का परीक्षण करता है जिसमें स्वर विधि होती है।

निम्न तालिका उन कुछ क्रमों को दिखाती है जिन्हें नए उदाहरणों में जोड़ा जा सकता है (यह ब्लॉक)

इनपुट स्ट्रिंग विवरण Has_vowels के साथ अपेक्षित परिणाम?
'आ', 'ई', 'iii', 'ओ' केवल एक स्वर और कोई अन्य अक्षर नहीं। सच
'Abcefg' 'कम से कम एक स्वर और कुछ व्यंजन' सच
'Mnklp' केवल व्यंजन। असत्य
'' खाली स्ट्रिंग (कोई पत्र नहीं) असत्य
'Abcde55345 और ??' स्वर, व्यंजन, संख्या और विराम चिह्न वर्ण। सच
'423,432 %%% ^ &' संख्या और विराम चिह्न वर्ण। असत्य
'AEIOU' ऊपरी मामला केवल स्वर। सच
'AeiOuuuA' ऊपरी मामला और केवल कम स्वर। सच
'AbCdEfghI' ऊपरी और निचले मामले स्वर और व्यंजन। सच
'BCDFG' ऊपरी मामला केवल व्यंजन। असत्य
'' व्हॉट्सएप के पात्र ही। असत्य

यह आपको तय करना है कि आपकी कल्पना फ़ाइल में कौन से उदाहरण हैं। परीक्षण करने के लिए कई शर्तें हैं, आपको यह निर्धारित करने की आवश्यकता है कि शर्तों का सबसेट सबसे महत्वपूर्ण है और आपके कोड का सबसे अच्छा परीक्षण करता है।

rspec कमांड उन सभी को देखने के लिए कई अलग-अलग विकल्प प्रदान करता है, टाइप करें rspec-मदद। निम्न तालिका सबसे लोकप्रिय विकल्पों को सूचीबद्ध करती है और बताती है कि वे क्या करते हैं।

अनु क्रमांक। विकल्प / ध्वज और विवरण
1

-I PATH

पथ को लोड (आवश्यकता) पथ में जोड़ता है rspec रूबी स्रोत फ़ाइलों की तलाश में उपयोग करता है।

2

-r, --require PATH

आपके विनिर्देश में आवश्यक स्रोत फ़ाइल जोड़ता है। फ़ाइल (फ़ाइलें)।

3

--fail-fast

इस विकल्प के साथ, rspec पहले उदाहरण के विफल होने के बाद चश्मा चलाना बंद कर देगा। डिफ़ॉल्ट रूप से, rspec सभी निर्दिष्ट युक्ति फ़ाइलों को चलाता है, चाहे कितनी भी असफलता हो।

4

-f, --format FORMATTER

यह विकल्प आपको विभिन्न आउटपुट प्रारूपों को निर्दिष्ट करने की अनुमति देता है। आउटपुट स्वरूप के बारे में अधिक जानकारी के लिए फ़ॉर्मेटर्स पर अनुभाग देखें।

5

-o, --out FILE

यह विकल्प मानक फ़ाइल के बजाय आउटपुट फ़ाइल FILE के लिए परीक्षण के परिणाम लिखने के लिए rspec को निर्देशित करता है।

6

-c, --color

Rspec के आउटपुट में रंग सक्षम करता है। सफल उदाहरण के परिणाम हरे रंग के पाठ में दिखाई देंगे, असफलताएँ लाल पाठ में मुद्रित होंगी।

7

-b, --backtrace

Rspec के आउटपुट में पूर्ण त्रुटि backtraces प्रदर्शित करता है।

8

-w, --warnings

रूबी के आउटपुट में रूबी चेतावनी प्रदर्शित करता है।

9

-P, --pattern PATTERN

PATTERN पैटर्न से मेल खाने वाली विशेष फ़ाइलों को लोड और चलाएं। उदाहरण के लिए, यदि आप -p "* .rb" पास करते हैं, तो rspec सभी रूबी फ़ाइलों को चलाएगा, न कि केवल "_spec.rb" में समाप्त होने वाले।

10

-e, --example STRING

यह विकल्प उन सभी उदाहरणों को चलाने के लिए rspec को निर्देशित करता है, जिनके विवरण में पाठ STRING होता है।

1 1

-t, --tag TAG

इस विकल्प के साथ, rspec केवल उदाहरणों को चलाएगा जिसमें टैग टैग शामिल हैं। ध्यान दें कि TAG एक रूबी प्रतीक के रूप में निर्दिष्ट है। अधिक विवरण के लिए RSpec टैग पर अनुभाग देखें।

यदि आप हमारे मूल हैलो वर्ल्ड उदाहरण को याद करते हैं, तो इसमें एक पंक्ति शामिल थी जो इस तरह दिखती थी -

expect(message).to eq "Hello World!"

कीवर्ड eql एक है RSpec"मिलान"। यहां, हम RSpec में अन्य प्रकार के मिलानकर्ताओं का परिचय देंगे।

समानता / पहचान मिलानकर्ता

वस्तु या मूल्य समानता के लिए परीक्षण करने के लिए मिलान।

मिलान विवरण उदाहरण
eq के जब वास्तविक == अपेक्षित होता है उम्मीद (वास्तविक)। तक eq की उम्मीद है
eql जब वास्तविक हो जाता है। उम्मीद (वास्तविक) .to eql उम्मीद
होना जब वास्तविक हो। उम्मीद (वास्तविक)
बराबरी का जब वास्तविक हो। उम्मीद (वास्तविक)। समान रूप से अपेक्षित

उदाहरण

describe "An example of the equality Matchers" do 

   it "should show how the equality Matchers work" do 
      a = "test string" 
      b = a 
      
      # The following Expectations will all pass 
      expect(a).to eq "test string" 
      expect(a).to eql "test string" 
      expect(a).to be b 
      expect(a).to equal b 
   end
   
end

जब उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित आउटपुट का उत्पादन करेगा। आपके कंप्यूटर पर सेकंड की संख्या थोड़ी भिन्न हो सकती है -

.
Finished in 0.036 seconds (files took 0.11901 seconds to load)
1 example, 0 failures

तुलना करने वाले माचिस

मूल्यों की तुलना के लिए मिलान।

मिलान विवरण उदाहरण
> वास्तविक> अपेक्षित होने पर पास करता है उम्मीद (वास्तविक)
> = जब वास्तविक> = अपेक्षित होता है उम्मीद (वास्तविक)
< वास्तविक <अपेक्षित होने पर गुजरता है उम्मीद (वास्तविक)
<= गुजरता है जब वास्तविक <= उम्मीद की जाती है उम्मीद (वास्तविक)
be_between समावेशी पास होने पर वास्तविक <= मिनट और> = अधिकतम होता है उम्मीद (वास्तविक) .to be_between (न्यूनतम, अधिकतम) .inclusive
be_between अनन्य पास होता है जब वास्तविक <min> और max होता है उम्मीद (वास्तविक) .to be_between (न्यूनतम, अधिकतम) .exclusive
मेल खाते हैं गुजरता है जब वास्तविक एक नियमित अभिव्यक्ति से मेल खाता है उम्मीद (वास्तविक) .to मैच (/ रेगेक्स /)

उदाहरण

describe "An example of the comparison Matchers" do

   it "should show how the comparison Matchers work" do
      a = 1
      b = 2
      c = 3		
      d = 'test string'
      
      # The following Expectations will all pass
      expect(b).to be > a
      expect(a).to be >= a 
      expect(a).to be < b 
      expect(b).to be <= b 
      expect(c).to be_between(1,3).inclusive 
      expect(b).to be_between(1,3).exclusive 
      expect(d).to match /TEST/i 
   end
   
end

जब उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित आउटपुट का उत्पादन करेगा। आपके कंप्यूटर पर सेकंड की संख्या थोड़ी भिन्न हो सकती है -

. 
Finished in 0.013 seconds (files took 0.11801 seconds to load) 
1 example, 0 failures

क्लास / टाइप मैचर्स

वस्तुओं के प्रकार या वर्ग के परीक्षण के लिए मिलान।

मिलान विवरण उदाहरण
be_instance_of पास होता है जब वास्तविक अपेक्षित वर्ग का एक उदाहरण है। उम्मीद (वास्तविक)। तक be_instance_of (अपेक्षित)
be_kind_of पास तब होता है जब वास्तविक अपेक्षित वर्ग या उसके किसी मूल वर्ग का उदाहरण होता है। उम्मीद (वास्तविक)। तक be_kind_of (अपेक्षित)
का जवाब जब निर्दिष्ट विधि के लिए वास्तविक प्रतिसाद देता है। उम्मीद (वास्तविक) .to response_to (अपेक्षित)

उदाहरण

describe "An example of the type/class Matchers" do
 
   it "should show how the type/class Matchers work" do
      x = 1 
      y = 3.14 
      z = 'test string' 
      
      # The following Expectations will all pass
      expect(x).to be_instance_of Fixnum 
      expect(y).to be_kind_of Numeric 
      expect(z).to respond_to(:length) 
   end
   
end

जब उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित आउटपुट का उत्पादन करेगा। आपके कंप्यूटर पर सेकंड की संख्या थोड़ी भिन्न हो सकती है -

. 
Finished in 0.002 seconds (files took 0.12201 seconds to load) 
1 example, 0 failures

सच / गलत / शून्य मिलान

परीक्षण के लिए मिलानकर्ता कि क्या मूल्य सही है, गलत है या शून्य है।

मिलान विवरण उदाहरण
सच हो पास होने पर वास्तविक == सत्य उम्मीद (वास्तविक)। सच हो
झूठा होना पास होने पर वास्तविक == असत्य उम्मीद (वास्तविक)। गलत हो सकता है
be_truthy तब गुजरता है जब वास्तविक झूठा या शून्य नहीं होता है उम्मीद (वास्तविक)। तक be_truthy
be_falsey वास्तविक या गलत होने पर पास हो जाता है उम्मीद (वास्तविक)। तक be_falsey
be_nil पास होता है जब वास्तविक शून्य होता है उम्मीद (वास्तविक)। तक be_nil

उदाहरण

describe "An example of the true/false/nil Matchers" do
   it "should show how the true/false/nil Matchers work" do
      x = true 
      y = false 
      z = nil 
      a = "test string" 
      
      # The following Expectations will all pass
      expect(x).to be true 
      expect(y).to be false 
      expect(a).to be_truthy 
      expect(z).to be_falsey 
      expect(z).to be_nil 
   end 
end

जब उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित आउटपुट का उत्पादन करेगा। आपके कंप्यूटर पर सेकंड की संख्या थोड़ी भिन्न हो सकती है -

. 
Finished in 0.003 seconds (files took 0.12301 seconds to load) 
1 example, 0 failures

त्रुटि मिलानकर्ता

परीक्षण के लिए मिलानकर्ता, जब कोड का एक ब्लॉक एक त्रुटि उठाता है।

मिलान विवरण उदाहरण
raise_error (ErrorClass) जब ब्लॉक प्रकार ErrorClass की एक त्रुटि उठाता है। उम्मीद है कि {block} .to raise_error (ErrorClass)
raise_error ("त्रुटि संदेश") पास होता है जब ब्लॉक "त्रुटि संदेश" संदेश के साथ एक त्रुटि उठाता है। उम्मीद है कि {block} .to raise_error ("त्रुटि संदेश")
raise_error (ErrorClass, "त्रुटि संदेश") पास होता है जब ब्लॉक "त्रुटि संदेश" संदेश के साथ ErrorClass प्रकार की त्रुटि उठाता है उम्मीद है कि {block} .to raise_error (ErrorClass, "त्रुटि संदेश")

उदाहरण

नाम के साथ फ़ाइल में निम्न कोड सहेजें error_matcher_spec.rb और इसे इस कमांड से चलाएं - rspec error_matcher_spec.rb

describe "An example of the error Matchers" do 
   it "should show how the error Matchers work" do 
      
      # The following Expectations will all pass 
      expect { 1/0 }.to raise_error(ZeroDivisionError)
      expect { 1/0 }.to raise_error("divided by 0") 
      expect { 1/0 }.to raise_error("divided by 0", ZeroDivisionError) 
   end 
end

जब उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित आउटपुट का उत्पादन करेगा। आपके कंप्यूटर पर सेकंड की संख्या थोड़ी भिन्न हो सकती है -

. 
Finished in 0.002 seconds (files took 0.12101 seconds to load) 
1 example, 0 failures

इस अध्याय में, हम RSpec डबल्स पर चर्चा करेंगे, जिसे RSpec मोक्स के रूप में भी जाना जाता है। एक डबल एक ऑब्जेक्ट है जो किसी अन्य ऑब्जेक्ट के लिए "स्टैंड इन" कर सकता है। आप शायद सोच रहे हैं कि इसका क्या मतलब है और आपको इसकी आवश्यकता क्यों है।

मान लीजिए कि आप एक स्कूल के लिए एक आवेदन का निर्माण कर रहे हैं और आपके पास छात्रों की कक्षा का प्रतिनिधित्व करने वाला एक वर्ग है और छात्रों के लिए एक और कक्षा है, तो आपके पास एक क्लासरूम क्लास और एक स्टूडेंट क्लास है। आपको पहले किसी एक वर्ग के लिए कोड लिखना होगा, तो चलिए हम बताते हैं कि, कक्षा कक्षा से शुरू करें -

class ClassRoom 
   def initialize(students) 
      @students = students 
   end 
   
   def list_student_names 
      @students.map(&:name).join(',') 
   end 
end

यह एक साधारण वर्ग है, इसमें एक विधि list_student_names है, जो छात्र के नामों का अल्पविराम सीमांकित स्ट्रिंग लौटाता है। अब, हम इस वर्ग के लिए परीक्षाएँ बनाना चाहते हैं, लेकिन यदि हम अभी तक विद्यार्थी वर्ग नहीं बना पाए हैं तो हम कैसे करेंगे? हमें टेस्ट डबल चाहिए।

इसके अलावा, अगर हमारे पास एक "डमी" क्लास है, जो एक स्टूडेंट ऑब्जेक्ट की तरह व्यवहार करता है, तो हमारा क्लासरूम टेस्ट स्टूडेंट क्लास पर निर्भर नहीं करेगा। हम इस परीक्षण को अलगाव कहते हैं।

यदि हमारे ClassRoom परीक्षण किसी अन्य कक्षाओं पर निर्भर नहीं करते हैं, तो जब एक परीक्षा विफल हो जाती है, तो हम तुरंत जान सकते हैं कि हमारे ClassRoom वर्ग में बग है और कुछ अन्य वर्ग नहीं है। ध्यान रखें कि, वास्तविक दुनिया में, आप एक ऐसे वर्ग का निर्माण कर सकते हैं, जिसे किसी अन्य व्यक्ति द्वारा लिखित अन्य वर्ग के साथ बातचीत करने की आवश्यकता हो।

यह वह जगह है जहाँ RSpec डबल्स (नकली) उपयोगी हो जाते हैं। हमारी सूची_स्टुडेंट_नाम विधि प्रत्येक छात्र ऑब्जेक्ट पर उसके @ सदस्य सदस्य चर में नाम विधि कहती है। इसलिए, हमें एक डबल की आवश्यकता है जो एक नाम विधि को लागू करता है।

यहाँ RSRec उदाहरण (परीक्षण) के साथ ClassRoom के लिए कोड है, फिर भी ध्यान दें कि कोई छात्र वर्ग परिभाषित नहीं है -

class ClassRoom 
   def initialize(students) 
      @students = students 
   end
   
   def list_student_names 
      @students.map(&:name).join(',') 
   end 
end

describe ClassRoom do 
   it 'the list_student_names method should work correctly' do 
      student1 = double('student') 
      student2 = double('student') 
      
      allow(student1).to receive(:name) { 'John Smith'} 
      allow(student2).to receive(:name) { 'Jill Smith'} 
      
      cr = ClassRoom.new [student1,student2]
      expect(cr.list_student_names).to eq('John Smith,Jill Smith') 
   end 
end

जब उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित आउटपुट का उत्पादन करेगा। बीता हुआ समय आपके कंप्यूटर पर थोड़ा अलग हो सकता है -

. 
Finished in 0.01 seconds (files took 0.11201 seconds to load) 
1 example, 0 failures

जैसा कि आप देख सकते हैं, एक का उपयोग कर test doubleआपको अपने कोड का परीक्षण करने की अनुमति देता है, भले ही वह उस वर्ग पर निर्भर हो जो अपरिभाषित या अनुपलब्ध हो। इसके अलावा, इसका मतलब यह है कि जब कोई परीक्षा में असफलता होती है, तो आप तुरंत बता सकते हैं कि यह आपकी कक्षा में किसी मुद्दे के कारण है, न कि किसी अन्य द्वारा लिखित वर्ग के कारण।

यदि आप पहले से ही RSpec डबल्स (उर्फ मोक्स) पर अनुभाग पढ़ चुके हैं, तो आप पहले ही RSpec स्टब्स देख चुके हैं। RSpec में, एक स्टब को अक्सर एक विधि स्टब कहा जाता है, यह एक विशेष प्रकार की विधि है जो "मौजूदा विधि के लिए" या ऐसी विधि के लिए है जो अभी तक मौजूद नहीं है।

यहाँ RSpec डबल्स पर अनुभाग से कोड है -

class ClassRoom 
   def initialize(students) 
      @students = students 
   End
   
   def list_student_names 
      @students.map(&:name).join(',') 
   end 
end 

describe ClassRoom do 
   it 'the list_student_names method should work correctly' do 
      student1 = double('student') 
      student2 = double('student') 
      
      allow(student1).to receive(:name) { 'John Smith'}
      allow(student2).to receive(:name) { 'Jill Smith'} 
      
      cr = ClassRoom.new [student1,student2]
      expect(cr.list_student_names).to eq('John Smith,Jill Smith') 
   end 
end

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

एक बात का ध्यान रखें कि, RSpec का सिंटैक्स पिछले कुछ वर्षों में थोड़ा बदल गया है। RSpec के पुराने संस्करणों में, उपरोक्त विधि स्टब्स को इस तरह परिभाषित किया जाएगा -

student1.stub(:name).and_return('John Smith') 
student2.stub(:name).and_return('Jill Smith')

चलो उपरोक्त कोड लेते हैं और दोनों को प्रतिस्थापित करते हैं allow() पुराने RSpec सिंटैक्स के साथ लाइनें -

class ClassRoom 
   def initialize(students) 
      @students = students 
   end 
   
   def list_student_names 
      @students.map(&:name).join(',') 
   end 
	
end 

describe ClassRoom do 
   it 'the list_student_names method should work correctly' do 
      student1 = double('student') 
      student2 = double('student')
      
      student1.stub(:name).and_return('John Smith')
      student2.stub(:name).and_return('Jill Smith') 
      
      cr = ClassRoom.new [student1,student2] 
      expect(cr.list_student_names).to eq('John Smith,Jill Smith') 
   end 
end

उपरोक्त कोड निष्पादित करने पर आपको यह आउटपुट दिखाई देगा -

.
Deprecation Warnings:

Using `stub` from rspec-mocks' old `:should` syntax without explicitly 
   enabling the syntax is deprec 

ated. Use the new `:expect` syntax or explicitly enable `:should` instead. 
   Called from C:/rspec_tuto 

rial/spec/double_spec.rb:15:in `block (2 levels) in <top (required)>'.
If you need more of the backtrace for any of these deprecations 
   to identify where to make the necessary changes, you can configure 

`config.raise_errors_for_deprecations!`, and it will turn the 
   deprecation warnings into errors, giving you the full backtrace.

1 deprecation warning total

Finished in 0.002 seconds (files took 0.11401 seconds to load)
1 example, 0 failures

यह अनुशंसा की जाती है कि जब आप अपने RSpec उदाहरणों में विधि स्टब्स बनाने की आवश्यकता हो, तो आप नए अनुमति () सिंटैक्स का उपयोग करें, लेकिन हमने यहां पुरानी शैली प्रदान की है ताकि आप इसे देखने पर पहचान सकें।

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

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

RSpec में उपयोग किए जाने वाले सबसे आम हुक हुक से पहले और बाद में हैं। वे सेटअप और अशांति कोड को चलाने और परिभाषित करने का एक तरीका प्रदान करते हैं, जिसकी हमने ऊपर चर्चा की थी। आइए इस उदाहरण कोड पर विचार करें -

class SimpleClass 
   attr_accessor :message 
   
   def initialize() 
      puts "\nCreating a new instance of the SimpleClass class" 
      @message = 'howdy' 
   end 
   
   def update_message(new_message) 
      @message = new_message 
   end 
end 

describe SimpleClass do 
   before(:each) do 
      @simple_class = SimpleClass.new 
   end 
   
   it 'should have an initial message' do 
      expect(@simple_class).to_not be_nil
      @simple_class.message = 'Something else. . .' 
   end 
   
   it 'should be able to change its message' do
      @simple_class.update_message('a new message')
      expect(@simple_class.message).to_not be 'howdy' 
   end
end

जब आप यह कोड चलाते हैं, तो आपको निम्न आउटपुट प्राप्त होंगे -

Creating a new instance of the SimpleClass class 
. 
Creating a new instance of the SimpleClass class 
. 
Finished in 0.003 seconds (files took 0.11401 seconds to load) 
2 examples, 0 failures

आइए देखें कि क्या हो रहा है। पहले (: प्रत्येक) विधि वह जगह है जहां हम सेटअप कोड को परिभाषित करते हैं। जब आप पास होते हैं: प्रत्येक तर्क, आप अपने उदाहरण समूह में प्रत्येक उदाहरण से पहले चलाने के लिए विधि का निर्देश दे रहे हैं अर्थात दो इसे ऊपर दिए गए कोड में वर्णन ब्लॉक के अंदर ब्लॉक करते हैं।

पंक्ति में: @simple_class = SimpleClass.new, हम SimpleClass वर्ग का एक नया उदाहरण बना रहे हैं और इसे किसी ऑब्जेक्ट के उदाहरण चर में निर्दिष्ट कर रहे हैं। क्या वस्तु आप सोच रहे होंगे? RSpec वर्णन ब्लॉक के दायरे में पर्दे के पीछे एक विशेष वर्ग बनाता है। यह आपको इस वर्ग के चर का उदाहरण देने के लिए मान असाइन करने की अनुमति देता है, जिसे आप अपने उदाहरणों में इसे ब्लॉक कर सकते हैं। इससे हमारे परीक्षणों में क्लीनर कोड लिखना भी आसान हो जाता है। यदि प्रत्येक परीक्षण (उदाहरण) को SimpleClass का उदाहरण चाहिए, तो हम उस कोड को पहले के हुक में रख सकते हैं और उसे प्रत्येक उदाहरण में नहीं जोड़ सकते।

ध्यान दें कि, लाइन "SimpleClass क्लास का एक नया उदाहरण बनाना" कंसोल को दो बार लिखा गया है, यह दिखाता है कि, हुक से पहले प्रत्येक में कॉल किया गया था। it blocks

जैसा कि हमने उल्लेख किया है, RSpec में एक आफ्टर हुक और पहले और आफ्टर दोनों हुक हो सकते हैं: सभी एक तर्क के रूप में। निर्दिष्ट लक्ष्य के बाद हुक चलेगा। : सभी लक्ष्य का अर्थ है कि हुक सभी उदाहरणों से पहले / बाद में चलेगा। यहाँ एक सरल उदाहरण है जो दिखाता है जब प्रत्येक हुक कहा जाता है।

describe "Before and after hooks" do 
   before(:each) do 
      puts "Runs before each Example" 
   end 
   
   after(:each) do 
      puts "Runs after each Example" 
   end 
   
   before(:all) do 
      puts "Runs before all Examples" 
   end 
   
   after(:all) do 
      puts "Runs after all Examples"
   end 
   
   it 'is the first Example in this spec file' do 
      puts 'Running the first Example' 
   end 
   
   it 'is the second Example in this spec file' do 
      puts 'Running the second Example' 
   end 
end

जब आप उपरोक्त कोड चलाते हैं, तो आपको यह आउटपुट दिखाई देगा -

Runs before all Examples 
Runs before each Example 
Running the first Example 
Runs after each Example 
.Runs before each Example 
Running the second Example 
Runs after each Example 
.Runs after all Examples

RSpec टैग आपकी कल्पना फाइलों में विशिष्ट परीक्षण चलाने का एक आसान तरीका प्रदान करता है। डिफ़ॉल्ट रूप से, RSpec उन सभी फाइलों में सभी परीक्षण चलाएगा जो इसे चलाता है, लेकिन आपको केवल उनमें से एक सबसेट चलाने की आवश्यकता हो सकती है। मान लीजिए कि आपके पास कुछ परीक्षण हैं जो बहुत तेज़ी से चलते हैं और आपने अभी-अभी अपने एप्लिकेशन कोड में बदलाव किया है और आप बस त्वरित परीक्षण चलाना चाहते हैं, यह कोड प्रदर्शित करेगा कि RSpec टैग के साथ कैसे करें।

describe "How to run specific Examples with Tags" do 
   it 'is a slow test', :slow = > true do 
      sleep 10 
      puts 'This test is slow!' 
   end 
   
   it 'is a fast test', :fast = > true do 
      puts 'This test is fast!' 
   end 
end

अब, उपरोक्त कोड को एक नई फ़ाइल में सहेजें, जिसे tag_spec.rb कहा जाता है। कमांड लाइन से, इस कमांड को रन करें: rspec --tag slow tag_spec.rb

आप इस आउटपुट को देखेंगे -

रन के विकल्प: {: धीमा => सत्य} शामिल हैं

This test is slow! 
. 
Finished in 10 seconds (files took 0.11601 seconds to load) 
1 example, 0 failures

फिर, यह कमांड चलाएँ: rspec --tag fast tag_spec.rb

आप इस आउटपुट को देखेंगे -

Run options: include {:fast = >true} 
This test is fast! 
. 
Finished in 0.001 seconds (files took 0.11201 seconds to load) 
1 example, 0 failures

जैसा कि आप देख सकते हैं, RSpec टैग परीक्षण के एक सबसेट के लिए बहुत आसान बनाता है!

RSpec की एक ताकत यह है कि यह परीक्षण, स्वच्छ परीक्षण लिखने के कई तरीके प्रदान करता है। जब आपके परीक्षण कम और अप्रयुक्त होते हैं, तो यह अपेक्षित व्यवहार पर ध्यान केंद्रित करना आसान हो जाता है न कि इस बात पर कि कैसे परीक्षण लिखे जाते हैं। RSpec विषय अभी तक एक और शॉर्टकट है जो आपको सीधे सरल परीक्षण लिखने की अनुमति देता है।

इस कोड पर विचार करें -

class Person 
   attr_reader :first_name, :last_name 
   
   def initialize(first_name, last_name) 
      @first_name = first_name 
      @last_name = last_name 
   end 
end 

describe Person do 
   it 'create a new person with a first and last name' do
      person = Person.new 'John', 'Smith'
      
      expect(person).to have_attributes(first_name: 'John') 
      expect(person).to have_attributes(last_name: 'Smith') 
   end 
end

यह वास्तव में बहुत स्पष्ट है, लेकिन हम उदाहरण में कोड की मात्रा को कम करने के लिए RSpec की विषय सुविधा का उपयोग कर सकते हैं। हम ऐसा करते हैं कि व्यक्ति वस्तु को तात्कालिकता से वर्णन रेखा में ले जाता है।

class Person 
   attr_reader :first_name, :last_name 
   
   def initialize(first_name, last_name) 
      @first_name = first_name 
      @last_name = last_name 
   end 
	
end 

describe Person.new 'John', 'Smith' do 
   it { is_expected.to have_attributes(first_name: 'John') } 
   it { is_expected.to have_attributes(last_name: 'Smith') }
end

जब आप इस कोड को चलाते हैं, तो आपको यह आउटपुट दिखाई देगा -

.. 
Finished in 0.003 seconds (files took 0.11201 seconds to load) 
2 examples, 0 failures

ध्यान दें, दूसरा कोड नमूना कितना सरल है। हमने एक लियाit block पहले उदाहरण में और इसे दो के साथ प्रतिस्थापित किया it blocks अंत में कम कोड की आवश्यकता होती है और यह बिल्कुल स्पष्ट है।

कभी-कभी आपके RSpec उदाहरणों को पुन: प्रयोज्य कोड साझा करने के लिए एक आसान तरीका की आवश्यकता होती है। इसे पूरा करने का सबसे अच्छा तरीका है हेल्पर्स। सहायक मूल रूप से रूबी विधियां हैं जो आप उदाहरणों में साझा करते हैं। सहायकों के उपयोग के लाभ को समझने के लिए, आइए इस कोड पर विचार करें -

class Dog 
   attr_reader :good_dog, :has_been_walked 
   
   def initialize(good_or_not) 
      @good_dog = good_or_not 
      @has_been_walked = false 
   end 
   
   def walk_dog 
      @has_been_walked = true 
   end 
end 

describe Dog do 
   it 'should be able to create and walk a good dog' do 
      dog = Dog.new(true) 
      dog.walk_dog 
      
      expect(dog.good_dog).to be true
      expect(dog.has_been_walked).to be true 
   end 
   
   it 'should be able to create and walk a bad dog' do 
      dog = Dog.new(false) 
      dog.walk_dog 

      expect(dog.good_dog).to be false
      expect(dog.has_been_walked).to be true 
 
   end 
end

यह कोड स्पष्ट है, लेकिन जब भी संभव हो दोहराया कोड को कम करना हमेशा एक अच्छा विचार है। हम उपरोक्त कोड ले सकते हैं और इस पुनरावृत्ति को कुछ सहायक विधि से कम कर सकते हैं जिसे create_and_walk_dog () कहा जाता है।

class Dog
   attr_reader :good_dog, :has_been_walked 
   
   def initialize(good_or_not)
      @good_dog = good_or_not 
      @has_been_walked = false 
   end 
   
   def walk_dog 
      @has_been_walked = true 
   end 
end 

describe Dog do 
   def create_and_walk_dog(good_or_bad)
      dog = Dog.new(good_or_bad)
      dog.walk_dog
      return dog 
   end 
   
   it 'should be able to create and walk a good dog' do
      dog = create_and_walk_dog(true)
      
      expect(dog.good_dog).to be true
      expect(dog.has_been_walked).to be true 
   end 
   
   it 'should be able to create and walk a bad dog' do 
      dog = create_and_walk_dog(false)
      
      expect(dog.good_dog).to be false
      expect(dog.has_been_walked).to be true 
   end 
end

जब आप उपरोक्त कोड चलाते हैं, तो आपको यह आउटपुट दिखाई देगा -

.. 
Finished in 0.002 seconds (files took 0.11401 seconds to load) 
2 examples, 0 failures

जैसा कि आप देख सकते हैं, हम एक हेल्पर में डॉग ऑब्जेक्ट बनाने और चलने के लिए तर्क को आगे बढ़ाने में सक्षम थे जो हमारे उदाहरणों को छोटा और साफ करने की अनुमति देता है।

RSpec एक लचीला और शक्तिशाली उपकरण है। RSpec में मेटाडेटा कार्यक्षमता कोई अपवाद नहीं है। मेटाडेटा आमतौर पर "डेटा के बारे में डेटा" को संदर्भित करता है। RSpec में, इसका मतलब है आपके बारे में डेटाdescribe, context तथा it blocks

आइए एक उदाहरण देखें -

RSpec.describe "An Example Group with a metadata variable", :foo => 17 do 
   context 'and a context with another variable', :bar => 12 do 
      
      it 'can access the metadata variable of the outer Example Group' do |example| 
         expect(example.metadata[:foo]).to eq(17) 
      end
      
      it 'can access the metadata variable in the context block' do |example|  
         expect(example.metadata[:bar]).to eq(12) 
      end 
      
   end 
end

जब आप उपरोक्त कोड चलाते हैं, तो आपको यह आउटपुट दिखाई देगा -

.. 
Finished in 0.002 seconds (files took 0.11301 seconds to load) 
2 examples, 0 failures

मेटाडेटा आपकी RSpec फ़ाइलों के भीतर विभिन्न स्कोपों ​​में चर असाइन करने का एक तरीका प्रदान करता है। Example.metadata चर एक रूबी हैश है जिसमें आपके उदाहरणों और उदाहरण समूहों के बारे में अन्य जानकारी होती है।

उदाहरण के लिए, आइए उपरोक्त कोड को इस तरह से देखें -

RSpec.describe "An Example Group with a metadata variable", :foo => 17 do
   context 'and a context with another variable', :bar => 12 do 
      
      it 'can access the metadata variable in the context block' do |example|
         expect(example.metadata[:foo]).to eq(17) 
         expect(example.metadata[:bar]).to eq(12) 
         example.metadata.each do |k,v|
         puts "#{k}: #{v}"
      end
		
   end 
end

जब हम इस कोड को चलाते हैं, तो हम उदाहरण में सभी मान देखते हैं।

.execution_result: #<RSpec::Core::Example::ExecutionResult:0x00000002befd50>
block: #<Proc:0x00000002bf81a8@C:/rspec_tutorial/spec/metadata_spec.rb:7>
description_args: ["can access the metadata variable in the context block"]
description: can access the metadata variable in the context block
full_description: An Example Group with a metadata variable and a context 
   with another variable can access the metadata variable in the context block
described_class:
file_path: ./metadata_spec.rb
line_number: 7
location: ./metadata_spec.rb:7
absolute_file_path: C:/rspec_tutorial/spec/metadata_spec.rb
rerun_file_path: ./metadata_spec.rb
scoped_id: 1:1:2
foo: 17
bar: 12
example_group:
{:execution_result=>#<RSpec::Core::Example::ExecutionResult:
   0x00000002bfa0e8>, :block=>#<
   Proc:0x00000002bfac00@C:/rspec_tutorial/spec/metadata_spec.rb:2>, 
   :description_args=>["and a context with another variable"], 
	
   :description=>"and a context with another variable", 
   :full_description=>"An Example Group with a metadata variable
   and a context with another variable", :described_class=>nil, 
      :file_path=>"./metadata_spec.rb", 
		
   :line_number=>2, :location=>"./metadata_spec.rb:2", 
      :absolute_file_path=>"C:/rspec_tutorial/spec/metadata_spec.rb",
      :rerun_file_path=>"./metadata_spec.rb", 
		
   :scoped_id=>"1:1", :foo=>17, :parent_example_group=>
      {:execution_result=>#<
      RSpec::Core::Example::ExecutionResult:0x00000002c1f690>, 
      :block=>#<Proc:0x00000002baff70@C:/rspec_tutorial/spec/metadata_spec.rb:1>
      , :description_args=>["An Example Group with a metadata variable"], 
		
   :description=>"An Example Group with a metadata variable", 
   :full_description=>"An Example Group with a metadata variable", 
	:described_class=>nil, :file_path=>"./metadata_spec.rb", 
   :line_number=>1, :location=>"./metadata_spec.rb:1",
   :absolute_file_path=>
	
   "C:/rspec_tutorial/spec/metadata_spec.rb", 
   :rerun_file_path=>"./metadata_spec.rb", 
   :scoped_id=>"1", :foo=>17}, 
   :bar=>12}shared_group_inclusion_backtrace: [] 
	
last_run_status: unknown .
.
Finished in 0.004 seconds (files took 0.11101 seconds to load) 
2 examples, 0 failures

सबसे अधिक संभावना है, आपको इस सभी मेटाडेटा का उपयोग करने की आवश्यकता नहीं होगी, लेकिन पूर्ण विवरण मूल्य देखें -

एक मेटाडाटा चर के साथ एक उदाहरण समूह और दूसरे चर के साथ एक संदर्भ संदर्भ ब्लॉक में मेटाडेटा चर तक पहुंच सकता है।

यह वर्णन ब्लॉक विवरण + इसके निहित संदर्भ ब्लॉक विवरण + के लिए विवरण से निर्मित एक वाक्य है it block

यहाँ यह ध्यान रखना दिलचस्प है कि, ये तीनों तार एक साथ सामान्य अंग्रेजी वाक्य की तरह पढ़े जाते हैं। । । जो RSpec के पीछे के विचारों में से एक है, परीक्षण है कि व्यवहार के अंग्रेजी विवरण की तरह लग रहा है।

आप इस अनुभाग को पढ़ने से पहले RSpec मेटाडेटा पर अनुभाग पढ़ना चाह सकते हैं क्योंकि, जैसा कि यह पता चला है, RSpec फ़िल्टरिंग RSpec मेटाडेटा पर आधारित है।

कल्पना करें कि आपके पास एक कल्पना फ़ाइल है और इसमें दो प्रकार के परीक्षण (उदाहरण) हैं: सकारात्मक कार्यात्मक परीक्षण और नकारात्मक (त्रुटि) परीक्षण। आइए उन्हें इस तरह परिभाषित करें -

RSpec.describe "An Example Group with positive and negative Examples" do 
   context 'when testing Ruby\'s build-in math library' do
      
      it 'can do normal numeric operations' do 
         expect(1 + 1).to eq(2) 
      end 
      
      it 'generates an error when expected' do
         expect{1/0}.to raise_error(ZeroDivisionError) 
      end
      
   end 
end

अब, उपरोक्त पाठ को 'filter_spec.rb' नामक फ़ाइल के रूप में सहेजें और फिर इसे इस कमांड के साथ चलाएं -

rspec filter_spec.rb

आप आउटपुट देखेंगे जो कुछ इस तरह दिखता है -

.. 
Finished in 0.003 seconds (files took 0.11201 seconds to load) 
2 examples, 0 failures

अब क्या होगा, अगर हम इस फ़ाइल में केवल सकारात्मक परीक्षण फिर से चलाना चाहते हैं? या केवल नकारात्मक परीक्षण? हम आसानी से RSpec फ़िल्टर के साथ कर सकते हैं। उपरोक्त कोड को इसमें बदलें -

RSpec.describe "An Example Group with positive and negative Examples" do 
   context 'when testing Ruby\'s build-in math library' do
      
      it 'can do normal numeric operations', positive: true do 
         expect(1 + 1).to eq(2) 
      end 
      
      it 'generates an error when expected', negative: true do 
         expect{1/0}.to raise_error(ZeroDivisionError) 
      end
      
   end 
end

फ़िल्टर_स्पे .rb में अपने परिवर्तन सहेजें और इसे थोड़ा अलग कमांड चलाएँ -

rspec --tag positive filter_spec.rb

अब, आप आउटपुट देखेंगे जो इस तरह दिखता है -

Run options: include {:positive=>true} 
. 
Finished in 0.001 seconds (files took 0.11401 seconds to load) 
1 example, 0 failures

--Tag पॉजिटिव को निर्दिष्ट करके, हम RSpec को केवल उदाहरणों के साथ चलाने के लिए कह रहे हैं: पॉज़िटिव मेटाडेटा वेरिएबल। हम इस तरह कमांड चलाकर नकारात्मक परीक्षणों के साथ एक ही काम कर सकते हैं -

rspec --tag negative filter_spec.rb

ध्यान रखें कि ये केवल उदाहरण हैं, आप किसी भी नाम के साथ एक फ़िल्टर निर्दिष्ट कर सकते हैं जो आप चाहते हैं।

RSpec प्रारूपकर्ता

फॉर्मेटर्स RSpec को विभिन्न तरीकों से परीक्षणों से आउटपुट प्रदर्शित करने की अनुमति देते हैं। आइए इस कोड वाली एक नई RSpec फाइल बनाएं -

RSpec.describe "A spec file to demonstrate how RSpec Formatters work" do 
   context 'when running some tests' do 
      
      it 'the test usually calls the expect() method at least once' do 
         expect(1 + 1).to eq(2) 
      end
      
   end 
end

अब, इसे formatter_spec.rb नामक फ़ाइल में सहेजें और इस RSpec कमांड को चलाएँ -

rspec formatter_spec.rb

आपको इस तरह दिखने वाले आउटपुट को देखना चाहिए -

. 
Finished in 0.002 seconds (files took 0.11401 seconds to load) 
1 example, 0 failures

अब एक ही कमांड चलाएं लेकिन इस बार एक फॉर्मेट निर्दिष्ट करें, जैसे -

rspec --format progress formatter_spec.rb

आपको इस बार एक ही आउटपुट देखना चाहिए -

. 
Finished in 0.002 seconds (files took 0.11401 seconds to load) 
1 example, 0 failures

कारण यह है कि "प्रगति" फ़ॉर्मेटर डिफ़ॉल्ट फ़ॉर्मेटर है। आइए आगे एक अलग फॉर्मेटर की कोशिश करें, इस कमांड को चलाने की कोशिश करें -

rspec --format doc formatter_spec.rb

अब आपको यह आउटपुट देखना चाहिए -

A spec file to demonstrate how RSpec Formatters work 
   when running some tests 
      the test usually calls the expect() method at least once
Finished in 0.002 seconds (files took 0.11401 seconds to load) 
1 example, 0 failures

जैसा कि आप देख सकते हैं, आउटपुट "डॉक्टर" फ़ॉर्मेटर के साथ काफी भिन्न है। यह फ़ॉर्मेटर डॉक्यूमेंटेशन जैसी शैली में आउटपुट प्रस्तुत करता है। आप सोच रहे होंगे कि जब आप किसी परीक्षा में असफल होते हैं तो ये विकल्प क्या दिखते हैं (उदाहरण)। में कोड बदलते हैंformatter_spec.rb ऐसा दिखने के लिए -

RSpec.describe "A spec file to demonstrate how RSpec Formatters work" do 
   context 'when running some tests' do 
      
      it 'the test usually calls the expect() method at least once' do 
         expect(1 + 1).to eq(1) 
      end
      
   end 
end

अपेक्षा expect(1 + 1).to eq(1)असफल होना चाहिए। अपने परिवर्तन सहेजें और उपरोक्त आदेशों को फिर से चलाएँ -

rspec --format progress formatter_spec.rb और याद रखें, क्योंकि "प्रगति" फ़ॉर्मेटर डिफ़ॉल्ट है, आप बस चला सकते हैं: rspec formatter_spec.rb। आपको यह आउटपुट देखना चाहिए -

F 
Failures:
1) A spec file to demonstrate how RSpec Formatters work when running some tests 
the test usually calls the expect() method at least once
   Failure/Error: expect(1 + 1).to eq(1)
	
      expected: 1
         got: 2
			  
      (compared using ==)			  
   # ./formatter_spec.rb:4:in `block (3 levels) in <top (required)>'

Finished in 0.016 seconds (files took 0.11201 seconds to load)
1 example, 1 failure
Failed examples:

rspec ./formatter_spec.rb:3 # A spec file to demonstrate how RSpec 
   Formatters work when running some tests the test usually calls 
   the expect() method at least once

अब, डॉक फॉर्मेटर की कोशिश करते हैं, इस कमांड को चलाते हैं -

rspec --format doc formatter_spec.rb

अब, असफल परीक्षण के साथ, आपको यह आउटपुट देखना चाहिए -

A spec file to demonstrate how RSpec Formatters work
   when running some tests
      the test usually calls the expect() method at least once (FAILED - 1)
		
Failures:

1) A spec file to demonstrate how RSpec Formatters work when running some
   tests the test usually calls the expect() method at least once
   Failure/Error: expect(1 + 1).to eq(1)
	
   expected: 1
        got: 2
		  
   (compared using ==)
   # ./formatter_spec.rb:4:in `block (3 levels) in <top (required)>'
	
Finished in 0.015 seconds (files took 0.11401 seconds to load) 
1 example, 1 failure

असफल उदाहरण

rspec ./formatter_spec.rb:3 # एक युक्ति फ़ाइल यह प्रदर्शित करने के लिए कि कुछ परीक्षण चलाते समय RSpec प्रारूपकार कैसे काम करते हैं परीक्षण आमतौर पर कम से कम एक बार उम्मीद () विधि को कॉल करता है।

RSpec फ़ॉर्मेटर्स परीक्षा परिणाम प्रदर्शन के तरीके को बदलने की क्षमता प्रदान करते हैं, यह आपके स्वयं के कस्टम फ़ॉर्मेटर बनाने के लिए भी संभव है, लेकिन यह अधिक उन्नत विषय है।

जब आप RSpec सीखते हैं, तो आप उम्मीदों के बारे में बहुत कुछ पढ़ सकते हैं और यह पहली बार में थोड़ा भ्रमित हो सकता है। उम्मीद करते समय आपको दो मुख्य विवरणों को ध्यान में रखना चाहिए -

  • एक उम्मीद बस में एक बयान है it block वह उपयोग करता है expect()तरीका। बस। यह उससे अधिक जटिल नहीं है। जब आपके पास इस तरह का कोड हो:expect(1 + 1).to eq(2), आप अपने उदाहरण में एक उम्मीद है। आप उम्मीद कर रहे हैं कि अभिव्यक्ति1 + 1 का मूल्यांकन करता है 2। शब्दांकन महत्वपूर्ण है, क्योंकि RSpec एक BDD परीक्षण ढांचा है। इस कथन को एक एक्सपेक्टेशन कहकर, यह स्पष्ट है कि आपका RSpec कोड उस परीक्षण के "व्यवहार" का वर्णन कर रहा है। विचार यह है कि आप व्यक्त कर रहे हैं कि कोड को कैसे व्यवहार करना चाहिए, इस तरह से प्रलेखन की तरह पढ़ता है।

  • एक्सपेक्टेशन सिंटैक्स अपेक्षाकृत नया है। से पहलेexpect() विधि पेश की गई (2012 में वापस), आरएसपीईसी ने एक अलग सिंटैक्स का उपयोग किया था जो पर आधारित था should()तरीका। उपरोक्त अपेक्षा पुराने वाक्य रचना में इस तरह लिखी गई है:(1 + 1).should eq(2)

जब आप पुराने कोड आधारित या RSpec के पुराने संस्करण के साथ काम कर रहे हैं तो पुराने RSpec सिंटैक्स का सामना कर सकते हैं। यदि आप पुराने सिंटैक्स का उपयोग RSpec के नए संस्करण के साथ करते हैं, तो आपको एक चेतावनी दिखाई देगी।

उदाहरण के लिए, इस कोड के साथ -

RSpec.describe "An RSpec file that uses the old syntax" do
   it 'you should see a warning when you run this Example' do 
      (1 + 1).should eq(2) 
   end 
end

जब आप इसे चलाते हैं, तो आपको एक आउटपुट मिलेगा जो इस तरह दिखता है -

. Deprecation Warnings:

Using `should` from rspec-expectations' old `:should` 
   syntax without explicitly enabling the syntax is deprecated. 
   Use the new `:expect` syntax or explicitly enable 
	
`:should` with `config.expect_with( :rspec) { |c| c.syntax = :should }`
   instead. Called from C:/rspec_tutorial/spec/old_expectation.rb:3 :in 
   `block (2 levels) in <top (required)>'.

If you need more of the backtrace for any of these deprecations to
   identify where to make the necessary changes, you can configure 
`config.raise_errors_for_deprecations!`, and it will turn the deprecation 
   warnings into errors, giving you the full backtrace.

1 deprecation warning total 
Finished in 0.001 seconds (files took 0.11201 seconds to load) 
1 example, 0 failures

जब तक आपको पुराने सिंटैक्स का उपयोग करने की आवश्यकता नहीं होती है, यह अत्यधिक अनुशंसा की जाती है कि आप अपेक्षा () के बजाय उम्मीद () का उपयोग करें।