Module: RSpec::Mocks::Methods
- Included in:
- Mock
- Defined in:
- lib/rspec/mocks/methods.rb
Instance Method Summary collapse
- #as_null_object ⇒ Object
- #null_object? ⇒ Boolean
-
#received_message?(sym, *args, &block) ⇒ Boolean
:nodoc:.
-
#rspec_reset ⇒ Object
:nodoc:.
-
#rspec_verify ⇒ Object
:nodoc:.
- #should_not_receive(sym, &block) ⇒ Object
- #should_receive(sym, opts = {}, &block) ⇒ Object
- #stub(sym_or_hash, opts = {}, &block) ⇒ Object (also: #stub!)
-
#stub_chain(*chain, &blk) ⇒ Object
:call-seq: double.stub_chain(“foo.bar”) { :baz } double.stub_chain(:foo, :bar) { :baz }.
- #unstub(sym) ⇒ Object (also: #unstub!)
Instance Method Details
#as_null_object ⇒ Object
65 66 67 |
# File 'lib/rspec/mocks/methods.rb', line 65 def as_null_object __mock_proxy.as_null_object end |
#null_object? ⇒ Boolean
69 70 71 |
# File 'lib/rspec/mocks/methods.rb', line 69 def null_object? __mock_proxy.null_object? end |
#received_message?(sym, *args, &block) ⇒ Boolean
:nodoc:
53 54 55 |
# File 'lib/rspec/mocks/methods.rb', line 53 def (sym, *args, &block) #:nodoc: __mock_proxy.(sym.to_sym, *args, &block) end |
#rspec_reset ⇒ Object
:nodoc:
61 62 63 |
# File 'lib/rspec/mocks/methods.rb', line 61 def rspec_reset #:nodoc: __mock_proxy.reset end |
#rspec_verify ⇒ Object
:nodoc:
57 58 59 |
# File 'lib/rspec/mocks/methods.rb', line 57 def rspec_verify #:nodoc: __mock_proxy.verify end |
#should_not_receive(sym, &block) ⇒ Object
8 9 10 |
# File 'lib/rspec/mocks/methods.rb', line 8 def should_not_receive(sym, &block) __mock_proxy.(caller(1)[0], sym.to_sym, &block) end |
#should_receive(sym, opts = {}, &block) ⇒ Object
4 5 6 |
# File 'lib/rspec/mocks/methods.rb', line 4 def should_receive(sym, opts={}, &block) __mock_proxy.(opts[:expected_from] || caller(1)[0], sym.to_sym, opts, &block) end |
#stub(sym_or_hash, opts = {}, &block) ⇒ Object Also known as: stub!
12 13 14 15 16 17 18 |
# File 'lib/rspec/mocks/methods.rb', line 12 def stub(sym_or_hash, opts={}, &block) if Hash === sym_or_hash sym_or_hash.each {|method, value| stub!(method).and_return value } else __mock_proxy.add_stub(caller(1)[0], sym_or_hash.to_sym, opts, &block) end end |
#stub_chain(*chain, &blk) ⇒ Object
:call-seq:
double.stub_chain("foo.bar") { :baz }
double.stub_chain(:foo, :bar) { :baz }
Stubs a chain of methods. Especially useful with fluent and/or composable interfaces.
Examples
Article.stub_chain("recent.published") { [Article.new] }
37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 |
# File 'lib/rspec/mocks/methods.rb', line 37 def stub_chain(*chain, &blk) chain, blk = format_chain(*chain, &blk) if chain.length > 1 if matching_stub = __mock_proxy.__send__(:find_matching_method_stub, chain[0].to_sym) chain.shift matching_stub.invoke.stub_chain(*chain, &blk) else next_in_chain = Object.new stub(chain.shift) { next_in_chain } next_in_chain.stub_chain(*chain, &blk) end else stub(chain.shift, &blk) end end |
#unstub(sym) ⇒ Object Also known as: unstub!
20 21 22 |
# File 'lib/rspec/mocks/methods.rb', line 20 def unstub(sym) __mock_proxy.remove_stub(sym) end |