free_mutant/spec/unit/mutant/runner_spec.rb

75 lines
2.7 KiB
Ruby
Raw Normal View History

RSpec.describe Mutant::Runner do
2014-10-23 07:37:53 -04:00
describe '.call' do
let(:integration) { instance_double(Mutant::Integration) }
let(:reporter) { instance_double(Mutant::Reporter, delay: delay) }
let(:driver) { instance_double(Mutant::Parallel::Driver) }
let(:delay) { instance_double(Float) }
let(:env) { instance_double(Mutant::Env, mutations: []) }
let(:env_result) { instance_double(Mutant::Result::Env) }
let(:actor_env) { instance_double(Mutant::Actor::Env) }
2014-12-08 19:10:31 -05:00
let(:config) do
instance_double(
Mutant::Config,
2014-12-08 19:10:31 -05:00
integration: integration,
reporter: reporter,
jobs: 1
)
end
2014-12-08 19:10:31 -05:00
before do
allow(env).to receive_messages(config: config, actor_env: actor_env)
allow(env).to receive(:method).with(:kill).and_return(parallel_config.processor)
2014-12-08 19:10:31 -05:00
end
2014-12-08 19:10:31 -05:00
let(:parallel_config) do
Mutant::Parallel::Config.new(
jobs: 1,
env: actor_env,
source: Mutant::Parallel::Source::Array.new(env.mutations),
sink: Mutant::Runner::Sink.new(env),
processor: ->(_object) { fail }
2014-12-08 19:10:31 -05:00
)
end
2014-12-08 19:10:31 -05:00
before do
expect(reporter).to receive(:start).with(env).ordered
expect(Mutant::Parallel).to receive(:async).with(parallel_config).and_return(driver).ordered
end
2014-12-08 19:10:31 -05:00
subject { described_class.call(env) }
2014-12-08 19:10:31 -05:00
context 'when runner finishes immediately' do
let(:status) { instance_double(Mutant::Parallel::Status, done: true, payload: env_result) }
2014-12-08 19:10:31 -05:00
before do
expect(driver).to receive(:status).and_return(status)
expect(reporter).to receive(:progress).with(status).ordered
expect(driver).to receive(:stop).ordered
expect(reporter).to receive(:report).with(env_result).ordered
2014-10-23 07:37:53 -04:00
end
end
2014-12-08 19:10:31 -05:00
context 'when report iterations are done' do
let(:status_a) { instance_double(Mutant::Parallel::Status, done: false) }
let(:status_b) { instance_double(Mutant::Parallel::Status, done: true, payload: env_result) }
2014-10-23 07:37:53 -04:00
before do
2014-12-08 19:10:31 -05:00
expect(driver).to receive(:status).and_return(status_a).ordered
expect(reporter).to receive(:progress).with(status_a).ordered
expect(Kernel).to receive(:sleep).with(reporter.delay).ordered
2014-12-08 19:10:31 -05:00
expect(driver).to receive(:status).and_return(status_b).ordered
expect(reporter).to receive(:progress).with(status_b).ordered
expect(driver).to receive(:stop).ordered
2014-12-08 19:10:31 -05:00
expect(reporter).to receive(:report).with(env_result).ordered
end
2014-10-23 07:37:53 -04:00
it 'returns env result' do
2014-12-08 19:10:31 -05:00
should be(env_result)
2014-10-23 07:37:53 -04:00
end
end
end
end