RSpec - Temel Sözdizimi
Bizim kodumuza daha yakından bakalım HelloWorldmisal. Her şeyden önce, net değilse, işlevselliğini test ediyoruz.HelloWorldsınıf. Elbette bu, yalnızca bir yöntem içeren çok basit bir sınıftır.say_hello().
İşte yine RSpec kodu -
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
Açıklamalı Anahtar Kelime
Kelime describebir RSpec anahtar kelimesidir. Bir "Örnek Grup" tanımlamak için kullanılır. Bir "Örnek Grubu" bir testler koleksiyonu olarak düşünebilirsiniz. describeanahtar kelime bir sınıf adı ve / veya dizge argümanı alabilir. Ayrıca bir blok argümanını da iletmeniz gerekir.describebu, bireysel testleri veya RSpec'te bilindiği üzere "Örnekler" i içerecektir. Blok sadece Ruby tarafından belirlenmiş bir Ruby bloğudurdo/end anahtar kelimeler.
Bağlam Anahtar Kelime
context anahtar kelime benzer describe. O da bir sınıf adını ve / veya dizge argümanını kabul edebilir. İle bir blok kullanmalısınızcontextyanı sıra. Bağlam fikri, belirli bir türdeki testleri kapsamasıdır.
Örneğin, bunun gibi farklı bağlamlara sahip Örnek grupları belirtebilirsiniz -
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 anahtar kelime zorunlu değildir, ancak içerdiği örnekler hakkında daha fazla ayrıntı eklemeye yardımcı olur.
İt Anahtar Sözcüğü
Kelime it"Örnek" tanımlamak için kullanılan başka bir RSpec anahtar kelimesidir. Bir örnek temelde bir test veya bir test vakasıdır. Yine gibidescribe ve context, it hem sınıf adını hem de dize argümanlarını kabul eder ve bir blok argümanıyla birlikte kullanılmalıdır. do/end. Bu durumudait, yalnızca bir dizge ve blok argümanını iletmek gelenekseldir. Dize argümanı genellikle "gerekir" kelimesini kullanır ve burada hangi belirli davranışın olması gerektiğini açıklamak içindir.it block. Başka bir deyişle, beklenen sonucun Örnek için olduğunu açıklar.
Not it block HelloWorld Örneğimizden -
it "The say_hello method should return 'Hello World'" do
Dize, HelloWorld sınıfının bir örneğinde merhaba deyin dediğimizde ne olması gerektiğini netleştirir. RSpec felsefesinin bu bölümü olan Örnek sadece bir test değil, aynı zamanda bir özelliktir (bir özellik). Diğer bir deyişle, bir Örnek Ruby kodunuzun beklenen davranışını hem belgeler hem de test eder.
Beklenen Anahtar Kelime
expectanahtar kelime, RSpec'de bir "Beklenti" tanımlamak için kullanılır. Bu, belirli bir beklenen koşulun karşılandığını kontrol ettiğimiz bir doğrulama adımıdır.
HelloWorld Örneğimizden, bizde -
expect(message).to eql "Hello World!"
İle fikir expectifadeler, normal İngilizce gibi okuduklarıdır. Bunu yüksek sesle söyleyebilirsiniz: "Değişken mesajının 'Merhaba Dünya' dizesine eşit olmasını bekleyin". Buradaki fikir, proje yöneticileri gibi teknik olmayan paydaşlar için bile açıklayıcı ve aynı zamanda okunması kolay olmasıdır.
The to keyword
to anahtar kelime bir parçası olarak kullanılır expectifadeler. Ayrıca kullanabileceğinizi unutmayın.not_toBeklentinin yanlış olmasını istediğinizde, tersini ifade etmek için anahtar kelime. Bunun bir nokta ile kullanıldığını görebilirsin,expect(message).to,çünkü bu aslında normal bir Ruby yöntemidir. Aslında, tüm RSpec anahtar kelimeleri gerçekten sadece Ruby yöntemleridir.
The eql keyword
eqlanahtar kelime, Eşleştirici adı verilen özel bir RSpec anahtar kelimesidir. Test ettiğiniz koşulun doğru (veya yanlış) olduğunu belirtmek için Eşleştiricileri kullanırsınız.
Merhaba Dünyamızda expect ifade, açıktır ki eqldize eşitliği anlamına gelir. Ruby'de farklı türde eşitlik operatörleri ve dolayısıyla RSpec'te farklı karşılık gelen Eşleştiriciler olduğunu unutmayın. Daha sonraki bir bölümde birçok farklı Eşleştirici türünü keşfedeceğiz.