free_mutant/spec/unit/mutant/require_highjack_spec.rb

73 lines
1.8 KiB
Ruby
Raw Normal View History

# frozen_string_literal: true
RSpec.describe Mutant::RequireHighjack do
2014-04-04 12:38:06 +00:00
let(:highjacked_calls) { [] }
let(:require_calls) { [] }
let(:target_module) do
2015-01-14 11:57:53 +00:00
acc = require_calls
2014-04-04 12:38:06 +00:00
Module.new do
2015-01-14 11:57:53 +00:00
define_method(:require, &acc.method(:<<))
define_singleton_method(:require, &acc.method(:<<))
2014-04-04 12:38:06 +00:00
end
end
def singleton_require(logical_name)
target_module.require(logical_name)
end
def instance_require(logical_name)
Object.new.extend(target_module).require(logical_name)
end
describe '.call' do
let(:logical_name) { instance_double(String) }
2014-04-04 12:38:06 +00:00
def apply
described_class.call(target_module, highjacked_calls.method(:<<))
2014-04-04 12:38:06 +00:00
end
it 'prevents warnings' do
expect(Mutant::WarningFilter.use(&method(:apply))).to eql([])
end
it 'returns the original implementation from singleton' do
expect { apply.call(logical_name) }
.to change { require_calls }
.from([])
.to([logical_name])
2014-04-04 12:38:06 +00:00
end
context '#require' do
it 'does highjack calls' do
apply
expect { instance_require(logical_name) }
.to change { highjacked_calls }
.from([])
.to([logical_name])
end
it 'does not call original require' do
apply
expect { instance_require(logical_name) }
.not_to change { require_calls }.from([])
end
2014-04-04 12:38:06 +00:00
end
context '.require' do
it 'does highjack calls' do
apply
expect { singleton_require(logical_name) }
.to change { highjacked_calls }
.from([])
.to([logical_name])
end
it 'does not call original require' do
apply
expect { singleton_require(logical_name) }
.not_to change { require_calls }.from([])
end
2014-04-04 12:38:06 +00:00
end
end
end