RSpec - Sintaks Dasar

Mari kita lihat lebih dekat kode kami HelloWorldcontoh. Pertama-tama, jika tidak jelas, kami menguji fungsionalitas fileHelloWorldkelas. Ini tentu saja, adalah kelas yang sangat sederhana yang hanya berisi satu metodesay_hello().

Ini kode RSpec lagi -

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

Kata kunci mendeskripsikan

Kata describeadalah kata kunci RSpec. Ini digunakan untuk mendefinisikan "Grup Contoh". Anda dapat menganggap "Grup Contoh" sebagai kumpulan tes. Itudescribekata kunci dapat mengambil nama kelas dan / atau argumen string. Anda juga perlu meneruskan argumen blok kedescribe, ini akan berisi tes individu, atau seperti yang dikenal di RSpec, "Contoh". Blok tersebut hanyalah sebuah blok Ruby yang ditunjuk oleh Rubydo/end kata kunci.

Kata Kunci Konteks

Itu context kata kunci mirip dengan describe. Itu juga dapat menerima nama kelas dan / atau argumen string. Anda harus menggunakan satu blok dengancontextdemikian juga. Gagasan tentang konteks adalah bahwa ia melingkupi pengujian jenis tertentu.

Misalnya, Anda dapat menentukan grup Contoh dengan konteks berbeda seperti ini -

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”

Itu context kata kunci tidak wajib, tetapi membantu menambahkan lebih banyak detail tentang contoh yang dikandungnya.

Itu Kata Kunci

Kata itadalah kata kunci RSpec lain yang digunakan untuk mendefinisikan "Contoh". Contoh pada dasarnya adalah tes atau kasus uji. Sekali lagi, sukadescribe dan context, it menerima kedua nama kelas dan argumen string dan harus digunakan dengan argumen blok, ditunjuk dengan do/end. Dalam kasusit, biasanya hanya melewatkan argumen string dan blok. Argumen string sering kali menggunakan kata "harus" dan dimaksudkan untuk menggambarkan perilaku spesifik apa yang harus terjadi di dalamit block. Dengan kata lain, ini menjelaskan bahwa hasil yang diharapkan adalah untuk Contoh.

Perhatikan it block dari Contoh HelloWorld kami -

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

String tersebut menjelaskan apa yang harus terjadi ketika kita memanggil say hello pada sebuah instance dari kelas HelloWorld. Ini bagian dari filosofi RSpec, Contoh bukan hanya tes, itu juga spesifikasi (spesifikasi). Dengan kata lain, Contoh mendokumentasikan dan menguji perilaku yang diharapkan dari kode Ruby Anda.

Kata kunci yang diharapkan

Itu expectKata kunci digunakan untuk mendefinisikan "Harapan" di RSpec. Ini adalah langkah verifikasi di mana kami memeriksa, bahwa kondisi tertentu yang diharapkan telah terpenuhi.

Dari Contoh HelloWorld kami, kami memiliki -

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

Ide dengan expectpernyataannya adalah bahwa mereka membaca seperti bahasa Inggris normal. Anda bisa mengatakan ini dengan lantang sebagai "Harapkan pesan variabel sama dengan string 'Hello World'". Idenya adalah bahwa sifatnya deskriptif dan juga mudah dibaca, bahkan untuk pemangku kepentingan non-teknis seperti manajer proyek.

The to keyword

Itu to kata kunci digunakan sebagai bagian dari expectpernyataan. Perhatikan bahwa Anda juga dapat menggunakannot_tokata kunci untuk mengekspresikan sebaliknya, bila Anda ingin Ekspektasi menjadi salah. Anda dapat melihat bahwa to digunakan dengan titik,expect(message).to,karena ini sebenarnya hanya metode Ruby biasa. Faktanya, semua kata kunci RSpec sebenarnya hanyalah metode Ruby.

The eql keyword

Itu eqlkata kunci adalah kata kunci RSpec khusus yang disebut Matcher. Anda menggunakan Matcher untuk menentukan jenis kondisi apa yang Anda uji benar (atau salah).

Di HelloWorld kami expect pernyataan, jelas itu eqlberarti persamaan string. Perhatikan bahwa, ada berbagai jenis operator kesetaraan di Ruby dan akibatnya Matcher terkait yang berbeda di RSpec juga berbeda. Kita akan mempelajari berbagai jenis Matcher di bagian selanjutnya.