Module: Minitest
- Defined in:
- lib/minitest/parallel_fork/interrupt.rb,
lib/minitest/parallel_fork.rb
Defined Under Namespace
Modules: ParalleForkFailFast, ParallelForkHalt, ParallelForkInterrupt, Unparallelize
Class Attribute Summary collapse
Class Method Summary
collapse
-
.__run(reporter, options) ⇒ Object
Override __run to use a child forks to run the speeds, which allows for parallel spec execution on MRI.
-
.after_parallel_fork(i = nil, &block) ⇒ Object
Set the after_parallel_fork block to the given block.
-
.before_parallel_fork(&block) ⇒ Object
Set the before_parallel_fork block to the given block.
-
.on_parallel_fork_marshal_failure(&block) ⇒ Object
Set the on_parallel_fork_marshal_failure block to the given block.
-
.parallel_fork_child_data(data) ⇒ Object
-
.parallel_fork_data_from_marshal(data) ⇒ Object
-
.parallel_fork_data_to_marshal ⇒ Object
-
.parallel_fork_fork_child(i, suites, reporter, options) ⇒ Object
-
.parallel_fork_number ⇒ Object
-
.parallel_fork_run_test_suite(suite, reporter, options) ⇒ Object
-
.parallel_fork_run_test_suites(suites, reporter, options) ⇒ Object
-
.parallel_fork_setup_children(suites, reporter, options) ⇒ Object
-
.parallel_fork_suites ⇒ Object
-
.parallel_fork_wait_for_children(child_info, reporter) ⇒ Object
-
.run_after_parallel_fork_hook(i) ⇒ Object
-
.run_before_parallel_fork_hook ⇒ Object
-
.set_parallel_fork_stat_reporter(reporter) ⇒ Object
Class Attribute Details
.parallel_fork_stat_reporter ⇒ Object
Returns the value of attribute parallel_fork_stat_reporter.
29
30
31
|
# File 'lib/minitest/parallel_fork.rb', line 29
def parallel_fork_stat_reporter
@parallel_fork_stat_reporter
end
|
Class Method Details
.__run(reporter, options) ⇒ Object
Override __run to use a child forks to run the speeds, which allows for parallel spec execution on MRI.
132
|
# File 'lib/minitest/parallel_fork.rb', line 132
alias __run __run
|
.after_parallel_fork(i = nil, &block) ⇒ Object
Set the after_parallel_fork block to the given block
20
21
22
|
# File 'lib/minitest/parallel_fork.rb', line 20
def after_parallel_fork(i=nil, &block)
@after_parallel_fork = block
end
|
.before_parallel_fork(&block) ⇒ Object
Set the before_parallel_fork block to the given block
15
16
17
|
# File 'lib/minitest/parallel_fork.rb', line 15
def before_parallel_fork(&block)
@before_parallel_fork = block
end
|
.on_parallel_fork_marshal_failure(&block) ⇒ Object
Set the on_parallel_fork_marshal_failure block to the given block
25
26
27
|
# File 'lib/minitest/parallel_fork.rb', line 25
def on_parallel_fork_marshal_failure(&block)
@on_parallel_fork_marshal_failure = block
end
|
.parallel_fork_child_data(data) ⇒ Object
.parallel_fork_data_from_marshal(data) ⇒ Object
57
58
59
60
61
62
63
64
|
# File 'lib/minitest/parallel_fork.rb', line 57
def parallel_fork_data_from_marshal(data)
Marshal.load(data)
rescue ArgumentError
if @on_parallel_fork_marshal_failure
@on_parallel_fork_marshal_failure.call
end
raise
end
|
.parallel_fork_data_to_marshal ⇒ Object
53
54
55
|
# File 'lib/minitest/parallel_fork.rb', line 53
def parallel_fork_data_to_marshal
%i'count assertions results'.map{|meth| parallel_fork_stat_reporter.send(meth)}
end
|
.parallel_fork_fork_child(i, suites, reporter, options) ⇒ Object
.parallel_fork_number ⇒ Object
123
124
125
|
# File 'lib/minitest/parallel_fork.rb', line 123
def parallel_fork_number
(ENV['NCPU'] || 4).to_i
end
|
.parallel_fork_run_test_suite(suite, reporter, options) ⇒ Object
.parallel_fork_run_test_suites(suites, reporter, options) ⇒ Object
.parallel_fork_setup_children(suites, reporter, options) ⇒ Object
80
81
82
83
84
85
86
87
|
# File 'lib/minitest/parallel_fork.rb', line 80
def parallel_fork_setup_children(suites, reporter, options)
set_parallel_fork_stat_reporter(reporter)
run_before_parallel_fork_hook
parallel_fork_number.times.map do |i|
parallel_fork_fork_child(i, suites, reporter, options)
end
end
|
.parallel_fork_suites ⇒ Object
37
38
39
|
# File 'lib/minitest/parallel_fork.rb', line 37
def parallel_fork_suites
Minitest::Runnable.runnables.shuffle
end
|
.parallel_fork_wait_for_children(child_info, reporter) ⇒ Object
111
112
113
114
115
116
117
118
119
120
121
|
# File 'lib/minitest/parallel_fork.rb', line 111
def parallel_fork_wait_for_children(child_info, reporter)
parallel_fork_child_data(child_info).each do |data|
count, assertions, results = data
reporter.reporters.each do |rep|
next unless %i'count assertions results count= assertions='.all?{|meth| rep.respond_to?(meth)}
rep.count += count
rep.assertions += assertions
rep.results.concat(results)
end
end
end
|
.run_after_parallel_fork_hook(i) ⇒ Object
47
48
49
50
51
|
# File 'lib/minitest/parallel_fork.rb', line 47
def run_after_parallel_fork_hook(i)
if @after_parallel_fork
@after_parallel_fork.call(i)
end
end
|
.run_before_parallel_fork_hook ⇒ Object
41
42
43
44
45
|
# File 'lib/minitest/parallel_fork.rb', line 41
def run_before_parallel_fork_hook
if @before_parallel_fork
@before_parallel_fork.call
end
end
|
.set_parallel_fork_stat_reporter(reporter) ⇒ Object
31
32
33
34
35
|
# File 'lib/minitest/parallel_fork.rb', line 31
def set_parallel_fork_stat_reporter(reporter)
@parallel_fork_stat_reporter = reporter.reporters.detect do |rep|
%w'count assertions results count= assertions='.all?{|meth| rep.respond_to?(meth)}
end
end
|