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 का उदाहरण चाहिए, तो हम उस कोड को पहले के हुक में रख सकते हैं और उसे प्रत्येक उदाहरण में नहीं जोड़ सकते।

ध्यान दें कि, लाइन "सिंपलक्लास क्लास का एक नया उदाहरण बनाना" कंसोल को दो बार लिखा गया है, इससे पता चलता है कि, हुक से पहले प्रत्येक में कॉल किया गया था। 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