Sha256: 46b643580ae2650d879f955bb4d64b5de798cf651e52901d55eaed5446bd32cc
Contents?: true
Size: 1.43 KB
Versions: 2
Compression:
Stored size: 1.43 KB
Contents
Feature: 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. Scenario: use let to define memoized helper method Given a file named "let_spec.rb" with: """ruby $count = 0 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 Scenario: use let! to define a memoized helper method that is called in a before hook Given a file named "let_bang_spec.rb" with: """ruby $count = 0 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
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
rspec-core-3.0.0.beta2 | features/helper_methods/let.feature |
rspec-core-3.0.0.beta1 | features/helper_methods/let.feature |