RSpec - Rédaction de spécifications

Dans ce chapitre, nous allons créer une nouvelle classe Ruby, l'enregistrer dans son propre fichier et créer un fichier de spécification séparé pour tester cette classe.

Premièrement, dans notre nouvelle classe, il s'appelle StringAnalyzer. C'est une classe simple qui, vous l'avez deviné, analyse les chaînes. Notre classe n'a qu'une seule méthodehas_vowels?qui, comme son nom l'indique, renvoie true si une chaîne contient des voyelles et false si ce n'est pas le cas. Voici l'implémentation pourStringAnalyzer -

class StringAnalyzer 
   def has_vowels?(str) 
      !!(str =~ /[aeio]+/i) 
   end 
end

Si vous avez suivi la section HelloWorld, vous avez créé un dossier appelé C: \ rspec_tutorial \ spec.

Supprimez le fichier hello_world.rb si vous l'avez et enregistrez le code StringAnalyzer ci-dessus dans un fichier appelé string_analyzer.rb dans le dossier C: \ rspec_tutorial \ spec.

Voici la source de notre fichier de spécifications pour tester StringAnalyzer -

require 'string_analyzer' 

describe StringAnalyzer do 
   context "With valid input" do 
      
      it "should detect when a string contains vowels" do 
         sa = StringAnalyzer.new 
         test_string = 'uuu' 
         expect(sa.has_vowels? test_string).to be true 
      end 
		
      it "should detect when a string doesn't contain vowels" do 
         sa = StringAnalyzer.new 
         test_string = 'bcdfg' 
         expect(sa.has_vowels? test_string).to be false
      end 
      
   end 
end

Enregistrez-le dans le même répertoire de spécification, en lui donnant le nom string_analyzer_test.rb.

Dans votre fenêtre cmd.exe, accédez au dossier C: \ rspec_tutorial et exécutez cette commande: dir spec

Vous devriez voir ce qui suit -

Répertoire de C: \ rspec_tutorial \ spec

09/13/2015 08:22 AM  <DIR>    .
09/13/2015 08:22 AM  <DIR>    ..
09/12/2015 11:44 PM                 81 string_analyzer.rb
09/12/2015 11:46 PM              451 string_analyzer_test.rb

Maintenant, nous allons exécuter nos tests, exécutez cette commande: rspec spec

Lorsque vous transmettez le nom d'un dossier à rspec, il exécute tous les fichiers de spécifications à l'intérieur du dossier. Vous devriez voir ce résultat -

No examples found.

Finished in 0 seconds (files took 0.068 seconds to load)
0 examples, 0 failures

La raison pour laquelle cela s'est produit est que, par défaut, rspecexécute uniquement les fichiers dont les noms se terminent par «_spec.rb». Renommez string_analyzer_test.rb en string_analyzer_spec.rb. Vous pouvez le faire facilement en exécutant cette commande -

ren spec\string_analyzer_test.rb string_analyzer_spec.rb

Maintenant, cours rspec spec encore une fois, vous devriez voir une sortie qui ressemble à ceci -

F.
Failures:

   1) StringAnalyzer With valid input should detect when a string contains vowels
      Failure/Error: expect(sa.has_vowels? test_string).to be true 
         expected true
            got false
      # ./spec/string_analyzer_spec.rb:9:in `block (3 levels) in <top (required)>'

Finished in 0.015 seconds (files took 0.12201 seconds to load)
2 examples, 1 failure

Failed examples:
rspec ./spec/string_analyzer_spec.rb:6 # StringAnalyzer With valid 
   input should detect when a string contains vowels
Do you see what just happened? Our spec failed because we have a bug in 
   StringAnalyzer. The bug is simple to fix, open up string_analyzer.rb
   in a text editor and change this line:
!!(str =~ /[aeio]+/i)
to this:
!!(str =~ /[aeiou]+/i)

Maintenant, enregistrez les modifications que vous venez de faire dans string_analyizer.rb et exécutez à nouveau la commande rspec spec, vous devriez maintenant voir une sortie qui ressemble à -

..
Finished in 0.002 seconds (files took 0.11401 seconds to load)
2 examples, 0 failures

Félicitations, les exemples (tests) dans votre fichier de spécifications sont maintenant réussis. Nous avons corrigé un bug dans l'expression régulière qui a la méthode des voyelles mais nos tests sont loin d'être terminés.

Il serait judicieux d'ajouter plus d'exemples qui testent différents types de chaînes d'entrée avec la méthode has voyelles.

Le tableau suivant montre certaines des permutations qui pourraient être ajoutées dans de nouveaux exemples (il bloque)

Chaîne d'entrée La description Résultat attendu avec has_vowels?
'aaa', 'eee', 'iii', 'o' Une seule voyelle et pas d'autres lettres. vrai
'abcefg' 'Au moins une voyelle et quelques consonnes' vrai
«mnklp» Seulement des consonnes. faux
'' Chaîne vide (pas de lettres) faux
'abcde55345 & ??' Voyelles, consonnes, chiffres et caractères de ponctuation. vrai
«423432 %%% ^ &» Chiffres et caractères de ponctuation uniquement. faux
«AEIOU» Voyelles majuscules uniquement. vrai
«AeiOuuuA» Voyelles majuscules et minuscules uniquement. vrai
«AbCdEfghI» Voyelles et consonnes majuscules et minuscules. vrai
«BCDFG» Consonnes majuscules uniquement. faux
'' Caractères d'espaces blancs uniquement. faux

C'est à vous de décider quels exemples ajouter à votre fichier de spécifications. Il existe de nombreuses conditions à tester, vous devez déterminer quel sous-ensemble de conditions est le plus important et tester votre code le mieux.

le rspec La commande offre de nombreuses options différentes, pour les voir toutes, tapez rspec-Aidez-moi. Le tableau suivant répertorie les options les plus courantes et décrit leur fonction.

N ° Sr. Option / drapeau et description
1

-I PATH

Ajoute PATH au chemin de chargement (requis) qui rspec utilise lors de la recherche de fichiers source Ruby.

2

-r, --require PATH

Ajoute un fichier source spécifique à exiger dans vos spécifications. des dossiers).

3

--fail-fast

Avec cette option, rspec arrêtera d'exécuter des specs après l'échec du premier exemple. Par défaut, rspec exécute tous les fichiers de spécifications spécifiés, quel que soit le nombre d'échecs.

4

-f, --format FORMATTER

Cette option vous permet de spécifier différents formats de sortie. Voir la section sur les formateurs pour plus de détails sur les formats de sortie.

5

-o, --out FILE

Cette option demande à rspec d'écrire les résultats du test dans le fichier de sortie FILE plutôt que dans la sortie standard.

6

-c, --color

Active la couleur dans la sortie de rspec. Les résultats des exemples réussis s'afficheront en texte vert, les échecs seront imprimés en texte rouge.

sept

-b, --backtrace

Affiche les retours arrière d'erreur complets dans la sortie de rspec.

8

-w, --warnings

Affiche les avertissements Ruby dans la sortie de rspec.

9

-P, --pattern PATTERN

Chargez et exécutez les fichiers de spécifications qui correspondent au modèle PATTERN. Par exemple, si vous passez -p «* .rb», rspec exécutera tous les fichiers Ruby, pas seulement ceux qui se terminent par «_spec.rb».

dix

-e, --example STRING

Cette option demande à rspec d'exécuter tous les exemples contenant le texte STRING dans leurs descriptions.

11

-t, --tag TAG

Avec cette option, rspec n'exécutera que les exemples contenant la balise TAG. Notez que TAG est spécifié comme un symbole Ruby. Voir la section sur les balises RSpec pour plus de détails.