class WebMock::RequestExecutionVerifier

def self.executed_requests_message

def self.executed_requests_message
  "\n\nThe following requests were made:\n\n#{RequestRegistry.instance}\n" + "="*60
end

def description

def description
  "request #{request_pattern} #{quantity_phrase.strip}"
end

def does_not_match?

def does_not_match?
  @times_executed =
  RequestRegistry.instance.times_executed(@request_pattern)
  if @expected_times_executed
    @times_executed != @expected_times_executed
  else
    @times_executed == 0
  end
end

def failure_message

def failure_message
  failure_message_phrase(false)
end

def failure_message_phrase(is_negated=false)

def failure_message_phrase(is_negated=false)
  negation = is_negated ? "was not" : "was"
  "The request #{request_pattern} #{negation} expected to execute #{quantity_phrase(is_negated)}but it executed #{times(times_executed)}" +
    self.class.executed_requests_message
end

def failure_message_when_negated

def failure_message_when_negated
  failure_message_phrase(true)
end

def initialize(request_pattern = nil, expected_times_executed = nil, at_least_times_executed = nil, at_most_times_executed = nil)

def initialize(request_pattern = nil, expected_times_executed = nil, at_least_times_executed = nil, at_most_times_executed = nil)
  @request_pattern = request_pattern
  @expected_times_executed = expected_times_executed
  @at_least_times_executed = at_least_times_executed
  @at_most_times_executed = at_most_times_executed
end

def matches?

def matches?
  @times_executed =
    RequestRegistry.instance.times_executed(@request_pattern)
  if @at_least_times_executed
    @times_executed >= @at_least_times_executed
  elsif @at_most_times_executed
    @times_executed <= @at_most_times_executed
  else
    @times_executed == (@expected_times_executed || 1)
  end
end

def quantity_phrase(is_negated=false)

def quantity_phrase(is_negated=false)
  if @at_least_times_executed
    "at least #{times(@at_least_times_executed)} "
  elsif @at_most_times_executed
    "at most #{times(@at_most_times_executed)} "
  elsif @expected_times_executed
    "#{times(@expected_times_executed)} "
  else
    is_negated ? "" : "#{times(1)} "
  end
end

def times(times)

def times(times)
  "#{times} time#{ (times == 1) ? '' : 's'}"
end