Class: ParallelTests::Saucecucumber::Runner

Inherits:
Cucumber::Runner
  • Object
show all
Defined in:
lib/parallel_tests/saucecucumber/runner.rb

Class Method Summary collapse

Class Method Details

.run_tests(test_files, process_number, num_processes, options) ⇒ Object



8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
# File 'lib/parallel_tests/saucecucumber/runner.rb', line 8

def self.run_tests(test_files, process_number, num_processes, options)
  our_options = options.dup
  sanitized_test_files = test_files.map { |val| Shellwords.escape(val) }
  env = Sauce::TestBroker.next_environment(test_files)
  env.merge!({"AUTOTEST" => "1"}) if $stdout.tty? # display color when we are in a terminal
  our_options.merge!({:env => env})
  cmd = [
      executable,
      (runtime_logging if File.directory?(File.dirname(runtime_log))),
      cucumber_opts(our_options[:test_options]),
      *sanitized_test_files
  ].compact.join(" ")
  Sauce.logger.debug "Starting parallel process #{process_number} of #{num_processes}"
  Sauce.logger.debug "  #{cmd}"
  Sauce.logger.debug "  #{our_options}"
  execute_command(cmd, process_number, num_processes, our_options)
end

.tests_in_groups(tests, num_groups, options = {}) ⇒ Object



26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
# File 'lib/parallel_tests/saucecucumber/runner.rb', line 26

def self.tests_in_groups(tests, num_groups, options={})
  originals = (options[:group_by] == :steps) ? Grouper.by_steps(find_tests(tests, options), num_groups, options) : super
  all_tests = originals.flatten * Sauce::TestBroker.test_platforms(:cucumber).length
  base_group_size = all_tests.length / num_groups
  num_full_groups = all_tests.length - (base_group_size * num_groups)

  curpos = 0
  groups = []
  num_groups.times do |i|
    group_size = base_group_size
    if i < num_full_groups
      group_size += 1
    end
    groups << all_tests.slice(curpos, group_size)
    curpos += group_size
  end

  groups
end