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. |