Class: Matchi::Change::To

Inherits:
Object
  • Object
show all
Defined in:
lib/matchi/change/to.rb

Overview

*Change to* matcher.

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(expected, &state) ⇒ To

Initialize the matcher with an object and a block.

Examples:

require "matchi/change/to"

object = "foo"

Matchi::Change::To.new("FOO") { object.to_s }

Parameters:

  • expected (#object_id)

    An expected new value.

  • state (Proc)

    A block of code to execute to get the state of the object.



22
23
24
25
# File 'lib/matchi/change/to.rb', line 22

def initialize(expected, &state)
  @expected = expected
  @state    = state
end

Instance Attribute Details

#expected#object_id (readonly)

Returns An expected new value.

Returns:

  • (#object_id)

    An expected new value.



8
9
10
# File 'lib/matchi/change/to.rb', line 8

def expected
  @expected
end

Instance Method Details

#inspectObject

A string containing a human-readable representation of the matcher.



52
53
54
# File 'lib/matchi/change/to.rb', line 52

def inspect
  "#{self.class}(#{expected.inspect})"
end

#matches?Boolean

Boolean comparison on the expected change by comparing the value before and after the code execution.

Examples:

require "matchi/change/to"

object = "foo"

matcher = Matchi::Change::To.new("FOO") { object.to_s }

matcher.expected                    # => "FOO"
matcher.matches? { object.upcase! } # => true

Yield Returns:

  • (#object_id)

    The block of code to execute.

Returns:

  • (Boolean)

    Comparison between the value before and after the code execution.



44
45
46
47
48
49
# File 'lib/matchi/change/to.rb', line 44

def matches?
  yield
  value_after = @state.call

  expected == value_after
end

#to_sObject

Returns a string representing the matcher.



57
58
59
# File 'lib/matchi/change/to.rb', line 57

def to_s
  "change to #{expected.inspect}"
end