RSpec - Filtrage

Vous voudrez peut-être lire la section sur les métadonnées RSpec avant de lire cette section car, en fin de compte, le filtrage RSpec est basé sur les métadonnées RSpec.

Imaginez que vous ayez un fichier de spécifications et qu'il contienne deux types de tests (exemples): des tests fonctionnels positifs et des tests négatifs (erreur). Définissons-les comme ça -

RSpec.describe "An Example Group with positive and negative Examples" do 
   context 'when testing Ruby\'s build-in math library' do
      
      it 'can do normal numeric operations' do 
         expect(1 + 1).to eq(2) 
      end 
      
      it 'generates an error when expected' do
         expect{1/0}.to raise_error(ZeroDivisionError) 
      end
      
   end 
end

Maintenant, enregistrez le texte ci-dessus dans un fichier appelé 'filter_spec.rb', puis exécutez-le avec cette commande -

rspec filter_spec.rb

Vous verrez une sortie qui ressemble à ceci -

.. 
Finished in 0.003 seconds (files took 0.11201 seconds to load) 
2 examples, 0 failures

Et si, nous voulions réexécuter uniquement les tests positifs dans ce fichier? Ou seulement les tests négatifs? Nous pouvons facilement le faire avec les filtres RSpec. Changez le code ci-dessus en ceci -

RSpec.describe "An Example Group with positive and negative Examples" do 
   context 'when testing Ruby\'s build-in math library' do
      
      it 'can do normal numeric operations', positive: true do 
         expect(1 + 1).to eq(2) 
      end 
      
      it 'generates an error when expected', negative: true do 
         expect{1/0}.to raise_error(ZeroDivisionError) 
      end
      
   end 
end

Enregistrez vos modifications dans filter_spec.rb et exécutez cette commande légèrement différente -

rspec --tag positive filter_spec.rb

Maintenant, vous verrez une sortie qui ressemble à ceci -

Run options: include {:positive=>true} 
. 
Finished in 0.001 seconds (files took 0.11401 seconds to load) 
1 example, 0 failures

En spécifiant --tag positive, nous demandons à RSpec d'exécuter uniquement des exemples avec la variable de métadonnées: positive définie. Nous pourrions faire la même chose avec des tests négatifs en exécutant la commande comme ceci -

rspec --tag negative filter_spec.rb

Gardez à l'esprit que ce ne sont que des exemples, vous pouvez spécifier un filtre avec le nom de votre choix.

Formateurs RSpec

Les formateurs permettent à RSpec d'afficher la sortie des tests de différentes manières. Créons un nouveau fichier RSpec contenant ce code -

RSpec.describe "A spec file to demonstrate how RSpec Formatters work" do 
   context 'when running some tests' do 
      
      it 'the test usually calls the expect() method at least once' do 
         expect(1 + 1).to eq(2) 
      end
      
   end 
end

Maintenant, enregistrez-le dans un fichier appelé formatter_spec.rb et exécutez cette commande RSpec -

rspec formatter_spec.rb

Vous devriez voir une sortie qui ressemble à ceci -

. 
Finished in 0.002 seconds (files took 0.11401 seconds to load) 
1 example, 0 failures

Maintenant, exécutez la même commande mais cette fois spécifiez un formateur, comme celui-ci -

rspec --format progress formatter_spec.rb

Vous devriez voir la même sortie cette fois -

. 
Finished in 0.002 seconds (files took 0.11401 seconds to load) 
1 example, 0 failures

La raison en est que le formateur «progress» est le formateur par défaut. Essayons ensuite un autre formateur, essayez d'exécuter cette commande -

rspec --format doc formatter_spec.rb

Vous devriez maintenant voir cette sortie -

A spec file to demonstrate how RSpec Formatters work 
   when running some tests 
      the test usually calls the expect() method at least once
Finished in 0.002 seconds (files took 0.11401 seconds to load) 
1 example, 0 failures

Comme vous pouvez le voir, la sortie est assez différente avec le formateur «doc». Ce formateur présente la sortie dans un style semblable à une documentation. Vous vous demandez peut-être à quoi ressemblent ces options en cas d'échec d'un test (exemple). Changeons le code enformatter_spec.rb ressembler à ça -

RSpec.describe "A spec file to demonstrate how RSpec Formatters work" do 
   context 'when running some tests' do 
      
      it 'the test usually calls the expect() method at least once' do 
         expect(1 + 1).to eq(1) 
      end
      
   end 
end

L'attente expect(1 + 1).to eq(1)devrait échouer. Enregistrez vos modifications et réexécutez les commandes ci-dessus -

rspec --format progress formatter_spec.rb et rappelez-vous, puisque le formateur «progress» est la valeur par défaut, vous pouvez simplement exécuter: rspec formatter_spec.rb. Vous devriez voir cette sortie -

F 
Failures:
1) A spec file to demonstrate how RSpec Formatters work when running some tests 
the test usually calls the expect() method at least once
   Failure/Error: expect(1 + 1).to eq(1)
	
      expected: 1
         got: 2
			  
      (compared using ==)			  
   # ./formatter_spec.rb:4:in `block (3 levels) in <top (required)>'

Finished in 0.016 seconds (files took 0.11201 seconds to load)
1 example, 1 failure
Failed examples:

rspec ./formatter_spec.rb:3 # A spec file to demonstrate how RSpec 
   Formatters work when running some tests the test usually calls 
   the expect() method at least once

Maintenant, essayons le formateur de doc, exécutez cette commande -

rspec --format doc formatter_spec.rb

Maintenant, avec le test échoué, vous devriez voir cette sortie -

A spec file to demonstrate how RSpec Formatters work
   when running some tests
      the test usually calls the expect() method at least once (FAILED - 1)
		
Failures:

1) A spec file to demonstrate how RSpec Formatters work when running some
   tests the test usually calls the expect() method at least once
   Failure/Error: expect(1 + 1).to eq(1)
	
   expected: 1
        got: 2
		  
   (compared using ==)
   # ./formatter_spec.rb:4:in `block (3 levels) in <top (required)>'
	
Finished in 0.015 seconds (files took 0.11401 seconds to load) 
1 example, 1 failure

Exemples d'échec

rspec ./formatter_spec.rb:3 # Un fichier de spécifications pour montrer comment les formateurs RSpec fonctionnent lors de l'exécution de certains tests, le test appelle généralement la méthode expect () au moins une fois.

Les formateurs RSpec offrent la possibilité de changer la façon dont les résultats des tests s'affichent, il est même possible de créer votre propre formateur personnalisé, mais c'est un sujet plus avancé.