let and let!
Use let to define a memoized helper method. The value will be cached across
multiple calls in the same example but not across examples.
Note that let is lazy-evaluated: it is not evaluated until the first time
the method it defines is invoked. You can use let! to force the method’s
invocation before each example.
By default, let is threadsafe, but you can configure it not to be
by disabling config.threadsafe, which makes let perform a bit faster.
Use let to define memoized helper method
Given a file named “let_spec.rb” with:
$count = 0
RSpec.describe "let" do
let(:count) { $count += 1 }
it "memoizes the value" do
expect(count).to eq(1)
expect(count).to eq(1)
end
it "is not cached across examples" do
expect(count).to eq(2)
end
end
When I run rspec let_spec.rb
Then the examples should all pass.
Use let! to define a memoized helper method that is called in a before hook
Given a file named “letbangspec.rb” with:
$count = 0
RSpec.describe "let!" do
invocation_order = []
let!(:count) do
invocation_order << :let!
$count += 1
end
it "calls the helper method in a before hook" do
invocation_order << :example
expect(invocation_order).to eq([:let!, :example])
expect(count).to eq(1)
end
end
When I run rspec let_bang_spec.rb
Then the examples should all pass.