RSpec - Pengait

Saat Anda menulis pengujian unit, seringkali lebih mudah untuk menjalankan penyiapan dan pembongkaran kode sebelum dan sesudah pengujian Anda. Kode penyiapan adalah kode yang mengonfigurasi atau "menyiapkan" kondisi untuk pengujian. Kode Teardown melakukan pembersihan, memastikan bahwa lingkungan berada dalam status yang konsisten untuk pengujian selanjutnya.

Secara umum, tes Anda harus independen satu sama lain. Saat Anda menjalankan seluruh rangkaian pengujian dan salah satunya gagal, Anda ingin yakin bahwa pengujian tersebut gagal karena kode yang diujinya memiliki bug, bukan karena pengujian sebelumnya membuat lingkungan dalam keadaan tidak konsisten.

Pengait yang paling umum digunakan di RSpec adalah pengait sebelum dan sesudah. Mereka menyediakan cara untuk mendefinisikan dan menjalankan kode penyiapan dan pembongkaran yang kita diskusikan di atas. Mari pertimbangkan kode contoh ini -

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

Saat Anda menjalankan kode ini, Anda akan mendapatkan output berikut -

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

Mari kita lihat lebih dekat apa yang terjadi. Metode before (: each) adalah tempat kami mendefinisikan kode pengaturan. Ketika Anda meneruskan: setiap argumen, Anda menginstruksikan metode before untuk dijalankan sebelum setiap contoh dalam Grup Contoh Anda yaitu dua blok itu di dalam blok gambarkan dalam kode di atas.

Di baris: @simple_class = SimpleClass.new, kami membuat instance baru dari kelas SimpleClass dan menugaskannya ke variabel instance dari suatu objek. Objek apa yang mungkin Anda tanyakan? RSpec membuat kelas khusus di belakang layar dalam cakupan blok deskripsikan. Ini memungkinkan Anda untuk menetapkan nilai ke variabel instance dari kelas ini, yang dapat Anda akses di dalam blok it di Contoh Anda. Ini juga memudahkan penulisan kode yang lebih bersih dalam pengujian kami. Jika setiap pengujian (Contoh) membutuhkan sebuah instance dari SimpleClass, kita dapat meletakkan kode tersebut di hook sebelumnya dan tidak harus menambahkannya ke setiap contoh.

Perhatikan bahwa, baris "Membuat instance baru dari kelas SimpleClass" ditulis ke konsol dua kali, ini menunjukkan bahwa, sebelum hook dipanggil di setiap it blocks.

Seperti yang telah kami sebutkan, RSpec juga memiliki hook setelah dan hook sebelum dan sesudah dapat menggunakan: all sebagai argumen. Pengait setelah akan berjalan setelah target yang ditentukan. The: all target berarti hook akan berjalan sebelum / sesudah semua Contoh. Berikut adalah contoh sederhana yang menggambarkan kapan setiap hook dipanggil.

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

Ketika Anda menjalankan kode di atas, Anda akan melihat output ini -

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