RSpec - Attentes

Lorsque vous apprenez RSpec, vous pouvez lire beaucoup sur les attentes et cela peut être un peu déroutant au début. Il y a deux détails principaux que vous devez garder à l'esprit lorsque vous voyez le terme Attente -

  • Une attente est simplement une déclaration dans un it block qui utilise le expect()méthode. C'est ça. Ce n'est pas plus compliqué que ça. Lorsque vous avez un code comme celui-ci:expect(1 + 1).to eq(2), vous avez une attente dans votre exemple. Vous vous attendez à ce que l'expression1 + 1 évalue à 2. Le libellé est cependant important puisque RSpec est un cadre de test BDD. En appelant cette déclaration une attente, il est clair que votre code RSpec décrit le «comportement» du code qu'il teste. L'idée est que vous exprimez comment le code doit se comporter, d'une manière qui se lit comme de la documentation.

  • La syntaxe Expectation est relativement nouvelle. Avant leexpect() a été introduite (en 2012), RSpec a utilisé une syntaxe différente basée sur le should()méthode. L'attente ci-dessus est écrite comme ceci dans l'ancienne syntaxe:(1 + 1).should eq(2).

Vous pouvez rencontrer l'ancienne syntaxe RSpec pour les attentes lorsque vous travaillez avec un code plus ancien ou une version plus ancienne de RSpec. Si vous utilisez l'ancienne syntaxe avec une nouvelle version de RSpec, vous verrez un avertissement.

Par exemple, avec ce code -

RSpec.describe "An RSpec file that uses the old syntax" do
   it 'you should see a warning when you run this Example' do 
      (1 + 1).should eq(2) 
   end 
end

Lorsque vous l'exécutez, vous obtiendrez une sortie qui ressemble à ceci -

. Deprecation Warnings:

Using `should` from rspec-expectations' old `:should` 
   syntax without explicitly enabling the syntax is deprecated. 
   Use the new `:expect` syntax or explicitly enable 
	
`:should` with `config.expect_with( :rspec) { |c| c.syntax = :should }`
   instead. Called from C:/rspec_tutorial/spec/old_expectation.rb:3 :in 
   `block (2 levels) in <top (required)>'.

If you need more of the backtrace for any of these deprecations to
   identify where to make the necessary changes, you can configure 
`config.raise_errors_for_deprecations!`, and it will turn the deprecation 
   warnings into errors, giving you the full backtrace.

1 deprecation warning total 
Finished in 0.001 seconds (files took 0.11201 seconds to load) 
1 example, 0 failures

À moins que vous ne soyez obligé d'utiliser l'ancienne syntaxe, il est fortement recommandé d'utiliser expect () au lieu de should ().