Class: ParallelTests::Gherkin::Runner
Constant Summary
Constants inherited
from Test::Runner
Test::Runner::NAME
Class Method Summary
collapse
execute_command, execute_command_and_capture_output, find_results, name, test_env_number
Class Method Details
.cucumber_opts(given) ⇒ Object
53
54
55
56
57
58
59
|
# File 'lib/parallel_tests/gherkin/runner.rb', line 53
def cucumber_opts(given)
if given =~ /--profile/ or given =~ /(^|\s)-p /
given
else
[given, profile_from_config].compact.join(" ")
end
end
|
.determine_executable ⇒ Object
86
87
88
89
90
91
92
93
94
95
96
97
|
# File 'lib/parallel_tests/gherkin/runner.rb', line 86
def determine_executable
case
when File.exists?("bin/#{name}")
"bin/#{name}"
when ParallelTests.bundler_enabled?
"bundle exec #{name}"
when File.file?("script/#{name}")
"script/#{name}"
else
"#{name}"
end
end
|
.line_is_result?(line) ⇒ Boolean
29
30
31
|
# File 'lib/parallel_tests/gherkin/runner.rb', line 29
def line_is_result?(line)
line =~ /^\d+ (steps?|scenarios?)/
end
|
.profile_from_config ⇒ Object
61
62
63
64
65
66
67
|
# File 'lib/parallel_tests/gherkin/runner.rb', line 61
def profile_from_config
config = Dir.glob("{,.config/,config/}#{name}{.yml,.yaml}").first
if config && File.read(config) =~ /^parallel:/
"--profile parallel"
end
end
|
.run_tests(test_files, process_number, num_processes, options) ⇒ Object
9
10
11
12
13
14
15
16
17
18
19
|
# File 'lib/parallel_tests/gherkin/runner.rb', line 9
def run_tests(test_files, process_number, num_processes, options)
sanitized_test_files = test_files.map { |val| Shellwords.escape(val) }
options = options.merge(:env => {"AUTOTEST" => "1"}) if $stdout.tty? cmd = [
executable,
(runtime_logging if File.directory?(File.dirname(runtime_log))),
cucumber_opts(options[:test_options]),
*sanitized_test_files
].compact.join(" ")
execute_command(cmd, process_number, num_processes, options)
end
|
.runtime_log ⇒ Object
82
83
84
|
# File 'lib/parallel_tests/gherkin/runner.rb', line 82
def runtime_log
"tmp/parallel_runtime_#{name}.log"
end
|
.runtime_logging ⇒ Object
78
79
80
|
# File 'lib/parallel_tests/gherkin/runner.rb', line 78
def runtime_logging
" --format ParallelTests::Gherkin::RuntimeLogger --out #{runtime_log}"
end
|
.summarize_results(results) ⇒ Object
cucumber has 2 result lines per test run, that cannot be added 1 scenario (1 failed) 1 step (1 failed)
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
|
# File 'lib/parallel_tests/gherkin/runner.rb', line 36
def summarize_results(results)
sort_order = %w[scenario step failed undefined skipped pending passed]
%w[scenario step].map do |group|
group_results = results.grep /^\d+ #{group}/
next if group_results.empty?
sums = sum_up_results(group_results)
sums = sums.sort_by { |word, _| sort_order.index(word) || 999 }
sums.map! do |word, number|
plural = "s" if word == group and number != 1
"#{number} #{word}#{plural}"
end
"#{sums[0]} (#{sums[1..-1].join(", ")})"
end.compact.join("\n")
end
|
.test_file_name ⇒ Object
21
22
23
|
# File 'lib/parallel_tests/gherkin/runner.rb', line 21
def test_file_name
"feature"
end
|
.test_suffix ⇒ Object
25
26
27
|
# File 'lib/parallel_tests/gherkin/runner.rb', line 25
def test_suffix
".feature"
end
|
.tests_in_groups(tests, num_groups, options = {}) ⇒ Object
69
70
71
72
73
74
75
|
# File 'lib/parallel_tests/gherkin/runner.rb', line 69
def tests_in_groups(tests, num_groups, options={})
if options[:group_by] == :steps
Grouper.by_steps(find_tests(tests, options), num_groups, options)
else
super
end
end
|