1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36
|
# frozen_string_literal: true
# @!method include_output_string(string)
# This matchers checks if the output string of a command includes string.
#
# @param [String] string
# The value of the output string
#
# @return [Boolean] The result
#
# False:
# * if the output string does not include string
# True:
# * if the output string includes string
#
# @example Use matcher
# RSpec.describe do
# it { expect(last_command_started).to have_output an_output_string_including string) }
# it { expect(last_command_started).to have_output include_output_string string) }
# end
RSpec::Matchers.define :include_output_string do |expected|
match do |actual|
actual.force_encoding('UTF-8')
@expected = Regexp.new(Regexp.escape(sanitize_text(expected.to_s)), Regexp::MULTILINE)
@actual = sanitize_text(actual)
values_match? @expected, @actual
end
diffable
description { "string includes: #{description_of expected}" }
end
RSpec::Matchers.alias_matcher :an_output_string_including, :include_output_string
RSpec::Matchers.alias_matcher :file_content_including, :include_output_string
|