Sha256: 6d9f28d2535889b1be9838767fe830aa35525ada35530a7073fb0cbacfb530f4
Contents?: true
Size: 1.27 KB
Versions: 2
Compression:
Stored size: 1.27 KB
Contents
module KnapsackPro class SlowTestFileDeterminer TIME_THRESHOLD_PER_CI_NODE = 0.7 # 70% REPORT_DIR = 'tmp/knapsack_pro/slow_test_file_determiner' REPORT_PATH = "#{REPORT_DIR}/slow_test_files.json" # test_files: { 'path' => 'a_spec.rb', 'time_execution' => 0.0 } # time_execution: of build distribution (total time of CI build run) def self.call(test_files, time_execution) time_threshold = (time_execution / KnapsackPro::Config::Env.ci_node_total) * TIME_THRESHOLD_PER_CI_NODE test_files.select do |test_file| test_file.fetch('time_execution') >= time_threshold end end def self.save_to_json_report(test_files) FileUtils.mkdir_p(REPORT_DIR) File.write(REPORT_PATH, test_files.to_json) end def self.read_from_json_report raise 'Report with slow test files was not generated yet. If you have enabled split by test cases https://github.com/KnapsackPro/knapsack_pro-ruby#split-test-files-by-test-cases and you see this error it means that your tests accidentally cleaned up tmp/knapsack_pro directory. Please do not remove this directory during tests runtime!' unless File.exists?(REPORT_PATH) slow_test_files_json_report = File.read(REPORT_PATH) JSON.parse(slow_test_files_json_report) end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
knapsack_pro-1.22.0 | lib/knapsack_pro/slow_test_file_determiner.rb |
knapsack_pro-1.21.0 | lib/knapsack_pro/slow_test_file_determiner.rb |