debian-mirror-gitlab/spec/support/helpers/next_found_instance_of.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

62 lines
1.9 KiB
Ruby
Raw Normal View History

2020-11-24 15:15:51 +05:30
# frozen_string_literal: true
module NextFoundInstanceOf
ERROR_MESSAGE = 'NextFoundInstanceOf mock helpers can only be used with ActiveRecord targets'
2022-05-07 20:08:51 +05:30
HELPER_METHOD_PATTERN = /(?:allow|expect)_next_found_(?<number>\d+)_instances_of/.freeze
2020-11-24 15:15:51 +05:30
2022-05-07 20:08:51 +05:30
def method_missing(method_name, ...)
return super unless match_data = method_name.match(HELPER_METHOD_PATTERN)
helper_method = method_name.to_s.sub("_#{match_data[:number]}", '')
public_send(helper_method, *args, match_data[:number].to_i, &block)
end
def expect_next_found_instance_of(klass, &block)
expect_next_found_instances_of(klass, nil, &block)
end
def expect_next_found_instances_of(klass, number)
2020-11-24 15:15:51 +05:30
check_if_active_record!(klass)
2022-05-07 20:08:51 +05:30
stub_allocate(expect(klass), klass, number) do |expectation|
2020-11-24 15:15:51 +05:30
yield(expectation)
end
end
2022-05-07 20:08:51 +05:30
def allow_next_found_instance_of(klass, &block)
allow_next_found_instances_of(klass, nil, &block)
end
def allow_next_found_instances_of(klass, number)
2020-11-24 15:15:51 +05:30
check_if_active_record!(klass)
2022-05-07 20:08:51 +05:30
stub_allocate(allow(klass), klass, number) do |allowance|
2020-11-24 15:15:51 +05:30
yield(allowance)
end
end
private
def check_if_active_record!(klass)
2021-06-08 01:23:25 +05:30
raise ArgumentError, ERROR_MESSAGE unless klass < ActiveRecord::Base
2020-11-24 15:15:51 +05:30
end
2022-05-07 20:08:51 +05:30
def stub_allocate(target, klass, number)
stub = receive(:allocate)
stub.exactly(number).times if number
target.to stub.and_wrap_original do |method|
2021-03-11 19:13:27 +05:30
method.call.tap do |allocation|
# ActiveRecord::Core.allocate returns a frozen object:
# https://github.com/rails/rails/blob/291a3d2ef29a3842d1156ada7526f4ee60dd2b59/activerecord/lib/active_record/core.rb#L620
# It's unexpected behavior and probably a bug in Rails
# Let's work it around by setting the attributes to default to unfreeze the object for now
allocation.instance_variable_set(:@attributes, klass._default_attributes)
yield(allocation)
end
2020-11-24 15:15:51 +05:30
end
end
end