Class: ParallelTests::Saucerspec::Runner
- Inherits:
-
RSpec::Runner
- Object
- RSpec::Runner
- ParallelTests::Saucerspec::Runner
- Defined in:
- lib/parallel_tests/saucerspec/runner.rb
Class Method Summary collapse
- .run_tests(test_files, process_number, num_processes, options) ⇒ Object
- .tests_in_groups(tests, num_groups, options = {}) ⇒ Object
Class Method Details
.run_tests(test_files, process_number, num_processes, options) ⇒ Object
9 10 11 12 13 14 15 16 17 18 19 20 21 |
# File 'lib/parallel_tests/saucerspec/runner.rb', line 9 def self.run_tests(test_files, process_number, num_processes, ) = .dup exe = executable # expensive, so we cache version = (exe =~ /\brspec\b/ ? 2 : 1) cmd = [exe, [:test_options], (rspec_2_color if version == 2), spec_opts, *test_files].compact.join(" ") env = Sauce::TestBroker.next_environment(test_files) env << " #{rspec_1_color}" if version == 1 .merge!(:env => env) 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, ) end |
.tests_in_groups(tests, num_groups, options = {}) ⇒ Object
24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 |
# File 'lib/parallel_tests/saucerspec/runner.rb', line 24 def self.tests_in_groups(tests, num_groups, ={}) all_tests = super.flatten * Sauce::TestBroker.test_platforms(:rspec).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 |