RSpec - Syntaxe de base

Regardons de plus près le code de notre HelloWorldexemple. Tout d'abord, au cas où ce ne serait pas clair, nous testons la fonctionnalité duHelloWorldclasse. Ceci bien sûr, est une classe très simple qui ne contient qu'une seule méthodesay_hello().

Voici à nouveau le code 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

Le mot-clé décrire

Le mot describeest un mot clé RSpec. Il est utilisé pour définir un «Groupe d'exemples». Vous pouvez considérer un «groupe d'exemples» comme une collection de tests. ledescribeLe mot clé peut prendre un nom de classe et / ou un argument de chaîne. Vous devez également passer un argument de bloc àdescribe, celui-ci contiendra les tests individuels, ou comme ils sont connus dans RSpec, les «exemples». Le bloc est juste un bloc Ruby désigné par le Rubydo/end mots clés.

Le mot-clé de contexte

le context mot-clé est similaire à describe. Il peut également accepter un nom de classe et / ou un argument de chaîne. Vous devez utiliser un bloc aveccontextainsi que. L'idée de contexte est qu'il renferme des tests d'un certain type.

Par exemple, vous pouvez spécifier des groupes d'exemples avec différents contextes comme celui-ci -

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”

le context Le mot-clé n'est pas obligatoire, mais il permet d'ajouter plus de détails sur les exemples qu'il contient.

Le mot-clé it

Le mot itest un autre mot clé RSpec qui est utilisé pour définir un «Exemple». Un exemple est essentiellement un test ou un cas de test. Encore une fois, commedescribe et context, it accepte à la fois le nom de classe et les arguments de chaîne et doit être utilisé avec un argument de bloc, désigné par do/end. Dans le cas deit, il est habituel de ne transmettre qu'une chaîne et un argument de bloc. L'argument chaîne utilise souvent le mot «devrait» et est destiné à décrire le comportement spécifique qui devrait se produire dans leit block. En d'autres termes, il décrit que le résultat attendu est pour l'exemple.

Noter la it block de notre exemple HelloWorld -

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

La chaîne indique clairement ce qui doit se passer lorsque nous appelons say hello sur une instance de la classe HelloWorld. Cette partie de la philosophie RSpec, un exemple n'est pas seulement un test, c'est aussi une spécification (une spécification). En d'autres termes, un exemple documente et teste à la fois le comportement attendu de votre code Ruby.

Le mot-clé attendu

le expectLe mot clé est utilisé pour définir une «attente» dans RSpec. Il s'agit d'une étape de vérification où nous vérifions qu'une condition spécifique attendue a été remplie.

De notre exemple HelloWorld, nous avons -

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

L'idée avec expectdéclarations, c'est qu'ils se lisent comme un anglais normal. Vous pouvez dire cela à voix haute comme «Attendez-vous à ce que le message variable soit égal à la chaîne« Hello World »». L'idée est que c'est descriptif et aussi facile à lire, même pour les parties prenantes non techniques telles que les chefs de projet.

The to keyword

le to Le mot-clé est utilisé dans le cadre de expectdéclarations. Notez que vous pouvez également utiliser lenot_tomot-clé pour exprimer le contraire, lorsque vous voulez que l'attente soit fausse. Vous pouvez voir que to est utilisé avec un point,expect(message).to,car il s'agit en fait d'une méthode Ruby classique. En fait, tous les mots-clés RSpec ne sont en réalité que des méthodes Ruby.

The eql keyword

le eqlmot-clé est un mot-clé RSpec spécial appelé Matcher. Vous utilisez Matchers pour spécifier le type de condition que vous testez pour être vrai (ou faux).

Dans notre HelloWorld expect déclaration, il est clair que eqlsignifie l'égalité des chaînes. Notez qu'il existe différents types d'opérateurs d'égalité dans Ruby et par conséquent différents Matchers correspondants dans RSpec. Nous explorerons les différents types de Matchers dans une section ultérieure.