RSpec - Métadonnées
RSpec est un outil flexible et puissant. La fonctionnalité de métadonnées de RSpec ne fait pas exception. Les métadonnées font généralement référence aux «données sur les données». Dans RSpec, cela signifie des données sur votredescribe, context et it blocks.
Jetons un coup d'œil à un exemple -
RSpec.describe "An Example Group with a metadata variable", :foo => 17 do
context 'and a context with another variable', :bar => 12 do
it 'can access the metadata variable of the outer Example Group' do |example|
expect(example.metadata[:foo]).to eq(17)
end
it 'can access the metadata variable in the context block' do |example|
expect(example.metadata[:bar]).to eq(12)
end
end
end
Lorsque vous exécutez le code ci-dessus, vous verrez cette sortie -
..
Finished in 0.002 seconds (files took 0.11301 seconds to load)
2 examples, 0 failures
Les métadonnées offrent un moyen d'attribuer des variables à différentes portées dans vos fichiers RSpec. La variable example.metadata est un hachage Ruby qui contient d'autres informations sur vos groupes d'exemples et d'exemples.
Par exemple, réécrivons le code ci-dessus pour ressembler à ceci -
RSpec.describe "An Example Group with a metadata variable", :foo => 17 do
context 'and a context with another variable', :bar => 12 do
it 'can access the metadata variable in the context block' do |example|
expect(example.metadata[:foo]).to eq(17)
expect(example.metadata[:bar]).to eq(12)
example.metadata.each do |k,v|
puts "#{k}: #{v}"
end
end
end
Lorsque nous exécutons ce code, nous voyons toutes les valeurs dans le hachage example.metadata -
.execution_result: #<RSpec::Core::Example::ExecutionResult:0x00000002befd50>
block: #<Proc:0x00000002bf81a8@C:/rspec_tutorial/spec/metadata_spec.rb:7>
description_args: ["can access the metadata variable in the context block"]
description: can access the metadata variable in the context block
full_description: An Example Group with a metadata variable and a context
with another variable can access the metadata variable in the context block
described_class:
file_path: ./metadata_spec.rb
line_number: 7
location: ./metadata_spec.rb:7
absolute_file_path: C:/rspec_tutorial/spec/metadata_spec.rb
rerun_file_path: ./metadata_spec.rb
scoped_id: 1:1:2
foo: 17
bar: 12
example_group:
{:execution_result=>#<RSpec::Core::Example::ExecutionResult:
0x00000002bfa0e8>, :block=>#<
Proc:0x00000002bfac00@C:/rspec_tutorial/spec/metadata_spec.rb:2>,
:description_args=>["and a context with another variable"],
:description=>"and a context with another variable",
:full_description=>"An Example Group with a metadata variable
and a context with another variable", :described_class=>nil,
:file_path=>"./metadata_spec.rb",
:line_number=>2, :location=>"./metadata_spec.rb:2",
:absolute_file_path=>"C:/rspec_tutorial/spec/metadata_spec.rb",
:rerun_file_path=>"./metadata_spec.rb",
:scoped_id=>"1:1", :foo=>17, :parent_example_group=>
{:execution_result=>#<
RSpec::Core::Example::ExecutionResult:0x00000002c1f690>,
:block=>#<Proc:0x00000002baff70@C:/rspec_tutorial/spec/metadata_spec.rb:1>
, :description_args=>["An Example Group with a metadata variable"],
:description=>"An Example Group with a metadata variable",
:full_description=>"An Example Group with a metadata variable",
:described_class=>nil, :file_path=>"./metadata_spec.rb",
:line_number=>1, :location=>"./metadata_spec.rb:1",
:absolute_file_path=>
"C:/rspec_tutorial/spec/metadata_spec.rb",
:rerun_file_path=>"./metadata_spec.rb",
:scoped_id=>"1", :foo=>17},
:bar=>12}shared_group_inclusion_backtrace: []
last_run_status: unknown .
.
Finished in 0.004 seconds (files took 0.11101 seconds to load)
2 examples, 0 failures
Très probablement, vous n'aurez pas besoin d'utiliser toutes ces métadonnées, mais regardez la valeur de la description complète -
Un groupe d'exemples avec une variable de métadonnées et un contexte avec une autre variable peut accéder à la variable de métadonnées dans le bloc de contexte.
Il s'agit d'une phrase créée à partir de la description du bloc de description + de la description du bloc de contexte qu'il contient + de la description du it block.
Ce qui est intéressant à noter ici, c'est que ces trois chaînes se lisent ensemble comme une phrase anglaise normale. . . qui est l'une des idées derrière RSpec, ayant des tests qui ressemblent à des descriptions de comportement en anglais.