Skip to content

Commit

Permalink
Change tests to native parallel runner
Browse files Browse the repository at this point in the history
  • Loading branch information
mbj committed Mar 8, 2024
1 parent e1bd86a commit af6e764
Show file tree
Hide file tree
Showing 9 changed files with 88 additions and 72 deletions.
2 changes: 1 addition & 1 deletion lib/mutant/parallel.rb
Original file line number Diff line number Diff line change
Expand Up @@ -109,7 +109,7 @@ class Config
end # Config

class Response
include Anima.new(:error, :log, :result)
include Anima.new(:error, :job, :log, :result)
end

# Parallel execution status
Expand Down
5 changes: 3 additions & 2 deletions lib/mutant/parallel/connection.rb
Original file line number Diff line number Diff line change
Expand Up @@ -41,12 +41,13 @@ def initialize(*)
@results = []
end

def self.read_response(**attributes)
def self.read_response(job:, **attributes)
reader = new(**attributes).read_till_final

Response.new(
log: reader.log,
error: reader.error,
job: job,
log: reader.log,
result: reader.result
)
end
Expand Down
1 change: 1 addition & 0 deletions lib/mutant/parallel/worker.rb
Original file line number Diff line number Diff line change
Expand Up @@ -98,6 +98,7 @@ def call
response = Connection::Reader.read_response(
deadline: config.world.deadline(config.timeout),
io: config.world.io,
job: job,
log_reader: log_reader,
marshal: config.world.marshal,
response_reader: response_reader
Expand Down
19 changes: 16 additions & 3 deletions spec/integration/mutant/parallel_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -51,16 +51,19 @@ def status
[
Mutant::Parallel::Response.new(
error: nil,
job: Mutant::Parallel::Source::Job.new(index: 0, payload: 1),
log: "Booting: 0\nPayload: 1\n",
result: 2
),
Mutant::Parallel::Response.new(
error: nil,
job: Mutant::Parallel::Source::Job.new(index: 1, payload: 2),
log: "Payload: 2\n",
result: 4
),
Mutant::Parallel::Response.new(
error: nil,
job: Mutant::Parallel::Source::Job.new(index: 2, payload: 3),
log: "Payload: 3\n",
result: 6
)
Expand Down Expand Up @@ -98,7 +101,14 @@ def status

response_a, response_b = responses

expect(response_a).to eql(Mutant::Parallel::Response.new(log: '', result: nil, error: nil))
expect(response_a).to eql(
Mutant::Parallel::Response.new(
error: nil,
job: Mutant::Parallel::Source::Job.new(index: 0, payload: 1),
log: '',
result: nil
)
)
expect(response_b.error).to be(EOFError)
expect(response_b.result).to be(nil)
expect(response_b.log.match?('<main>')).to be(true)
Expand Down Expand Up @@ -134,11 +144,13 @@ def status
[
Mutant::Parallel::Response.new(
error: nil,
job: Mutant::Parallel::Source::Job.new(index: 0, payload: 1),
log: "#{b}\n#{b}\n",
result: b
),
Mutant::Parallel::Response.new(
error: nil,
job: Mutant::Parallel::Source::Job.new(index: 1, payload: 2),
log: "#{b}#{b}\n",
result: b * 2
)
Expand Down Expand Up @@ -233,9 +245,10 @@ def status
expect(sink.status).to eql(
[
Mutant::Parallel::Response.new(
error: Timeout,
job: Mutant::Parallel::Source::Job.new(index: 0, payload: 1),
log: '',
result: nil,
error: Timeout
result: nil
)
]
)
Expand Down
65 changes: 17 additions & 48 deletions spec/support/corpus.rb
Original file line number Diff line number Diff line change
Expand Up @@ -22,8 +22,7 @@ class Project
MUTEX = Mutex.new

MUTATION_GENERATION_MESSAGE = 'Total Mutations/Time/Parse-Errors: %s/%0.2fs - %0.2f/s'
START_MESSAGE = 'Starting - %s'
FINISH_MESSAGE = 'Mutations - %4i - %s'
FINISH_MESSAGE = '%4i - %s'
RUBY_GLOB_PATTERN = '**/*.rb'

include Adamantium, Anima.new(
Expand Down Expand Up @@ -94,6 +93,7 @@ def response(response)
Mutant::WORLD.stderr.puts(response.log)
fail response.error
end
puts(FINISH_MESSAGE % [response.result, response.job.payload])
@total += response.result
end
end
Expand All @@ -109,30 +109,13 @@ def verify_mutation_generation
checkout
timer = Mutant::Timer.new(process: Process)

start = timer.now

options = {
finish: method(:finish),
start: method(:start),
in_processes: Etc.nprocessors
}
timer.now

sink = Sink.new

parallel_config = Mutant::Parallel::Config.new(
block: method(:check_generation),
jobs: Etc.nprocessors,
sink: sink,
timeout: nil,
process_name: 'mutation-generation',
source: Mutant::Parallel::Source::Array.new(jobs: effective_ruby_paths),
on_process_start: ->(_) {},
thread_name: 'mutation-generation'
)

elapsed = Mutant::WORLD.timer.elapsed do
driver = Mutant::Parallel.async(
config: parallel_config,
config: parallel_config(sink),
world: Mutant::WORLD
)

Expand All @@ -146,6 +129,19 @@ def verify_mutation_generation
self
end

def parallel_config(sink)
Mutant::Parallel::Config.new(
block: method(:check_generation),
jobs: Etc.nprocessors,
sink: sink,
timeout: nil,
process_name: 'mutation-generation',
source: Mutant::Parallel::Source::Array.new(jobs: effective_ruby_paths),
on_process_start: ->(_) {},
thread_name: 'mutation-generation'
)
end

# Checkout repository
#
# @return [self]
Expand Down Expand Up @@ -266,33 +262,6 @@ def noinstall?
ENV.key?('NOINSTALL')
end

# Print start progress
#
# @param [Pathname] path
# @param [Integer] _index
#
# @return [undefined]
#
def start(path, _index)
MUTEX.synchronize do
puts START_MESSAGE % path
end
end

# Print finish progress
#
# @param [Pathname] path
# @param [Integer] _index
# @param [Integer] count
#
# @return [undefined]
#
def finish(path, _index, count)
MUTEX.synchronize do
puts FINISH_MESSAGE % [count, path]
end
end

# Helper method to execute system commands
#
# @param [Array<String>] arguments
Expand Down
10 changes: 6 additions & 4 deletions spec/unit/mutant/mutation/runner/sink_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -5,17 +5,19 @@

let(:mutation_a_index_response) do
Mutant::Parallel::Response.new(
result: mutation_a_index_result,
error: nil,
job: 0,
log: '',
error: nil
result: mutation_a_index_result
)
end

let(:mutation_b_index_response) do
Mutant::Parallel::Response.new(
result: mutation_b_index_result,
error: nil,
job: 0,
log: '',
error: nil
result: mutation_b_index_result
)
end

Expand Down
25 changes: 17 additions & 8 deletions spec/unit/mutant/parallel/connection/reader_spec.rb
Original file line number Diff line number Diff line change
@@ -1,20 +1,22 @@
# frozen_string_literal: true

RSpec.describe Mutant::Parallel::Connection::Reader do
let(:deadline) { instance_double(Mutant::Timer::Deadline) }
let(:header_segment) { [result_segment.bytesize].pack('N') }
let(:io) { class_double(IO) }
let(:marshal) { class_double(Marshal) }
let(:log_reader) { instance_double(IO) }
let(:response_reader) { instance_double(IO) }
let(:result) { double('reader-result') }
let(:result_segment) { '<result-segment>' }
let(:deadline) { instance_double(Mutant::Timer::Deadline) }
let(:header_segment) { [result_segment.bytesize].pack('N') }
let(:io) { class_double(IO) }
let(:job) { Mutant::Parallel::Source::Job.new(index: 0, payload: nil) }
let(:log_reader) { instance_double(IO) }
let(:marshal) { class_double(Marshal) }
let(:response_reader) { instance_double(IO) }
let(:result) { double('reader-result') }
let(:result_segment) { '<result-segment>' }

describe '.read_response' do
def apply
described_class.read_response(
deadline: deadline,
io: io,
job: job,
log_reader: log_reader,
marshal: marshal,
response_reader: response_reader
Expand Down Expand Up @@ -90,6 +92,7 @@ def marshal_load
expect(apply).to eql(
Mutant::Parallel::Response.new(
error: nil,
job: job,
log: '',
result: result
)
Expand Down Expand Up @@ -121,6 +124,7 @@ def marshal_load
expect(apply).to eql(
Mutant::Parallel::Response.new(
error: nil,
job: job,
log: '',
result: result
)
Expand Down Expand Up @@ -157,6 +161,7 @@ def marshal_load
expect(apply).to eql(
Mutant::Parallel::Response.new(
error: nil,
job: job,
log: '',
result: result
)
Expand Down Expand Up @@ -187,6 +192,7 @@ def marshal_load
expect(apply).to eql(
Mutant::Parallel::Response.new(
error: Timeout,
job: job,
log: '<log>',
result: nil
)
Expand Down Expand Up @@ -214,6 +220,7 @@ def marshal_load
expect(apply).to eql(
Mutant::Parallel::Response.new(
error: EOFError,
job: job,
log: '',
result: nil
)
Expand All @@ -235,6 +242,7 @@ def marshal_load
expect(apply).to eql(
Mutant::Parallel::Response.new(
error: Timeout,
job: job,
log: '',
result: nil
)
Expand All @@ -255,6 +263,7 @@ def marshal_load
expect(apply).to eql(
Mutant::Parallel::Response.new(
error: Timeout,
job: job,
log: '',
result: nil
)
Expand Down
16 changes: 10 additions & 6 deletions spec/unit/mutant/parallel/worker_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -209,15 +209,16 @@ def finalize
end

# rubocop:disable Metrics/MethodLength
def read_response(response)
def read_response(job, response)
{
receiver: Mutant::Parallel::Connection::Reader,
arguments: [
{
deadline: deadline,
io: world.io,
marshal: world.marshal,
job: job,
log_reader: log_pipe.to_reader,
marshal: world.marshal,
response_reader: response_pipe.to_reader
}
],
Expand All @@ -239,6 +240,7 @@ def new_deadline
let(:response_a) do
Mutant::Parallel::Response.new(
error: nil,
job: 0,
log: 'log-a',
result: result_a
)
Expand All @@ -247,6 +249,7 @@ def new_deadline
let(:response_b) do
Mutant::Parallel::Response.new(
error: nil,
job: 0,
log: 'log-b',
result: result_b
)
Expand All @@ -262,7 +265,7 @@ def new_deadline
add_job(job_a),
send_value(payload_a),
new_deadline,
read_response(response_a),
read_response(job_a, response_a),
with(var_active_jobs, active_jobs),
remove_job(job_a),
with(var_sink, sink),
Expand All @@ -285,7 +288,7 @@ def new_deadline
add_job(job_a),
send_value(payload_a),
new_deadline,
read_response(response_a),
read_response(job_a, response_a),
with(var_active_jobs, active_jobs),
remove_job(job_a),
with(var_sink, sink),
Expand All @@ -298,7 +301,7 @@ def new_deadline
add_job(job_b),
send_value(payload_b),
new_deadline,
read_response(response_b),
read_response(job_b, response_b),
with(var_active_jobs, active_jobs),
remove_job(job_b),
with(var_sink, sink),
Expand All @@ -315,6 +318,7 @@ def new_deadline
let(:response_a) do
Mutant::Parallel::Response.new(
error: Timeout,
job: 0,
log: 'log',
result: nil
)
Expand All @@ -329,7 +333,7 @@ def new_deadline
add_job(job_a),
send_value(payload_a),
new_deadline,
read_response(response_a),
read_response(job_a, response_a),
with(var_active_jobs, active_jobs),
remove_job(job_a),
with(var_sink, sink),
Expand Down
Loading

0 comments on commit af6e764

Please sign in to comment.