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