KnapsackPro/knapsack_pro-ruby

View on GitHub
lib/knapsack_pro/slow_test_file_determiner.rb

Summary

Maintainability
A
1 hr
Test Coverage
# frozen_string_literal: true

module KnapsackPro
  class SlowTestFileDeterminer
    TIME_THRESHOLD_PER_CI_NODE = 0.7 # 70%

    # test_files: { 'path' => 'a_spec.rb', 'time_execution' => 0.0 }
    def self.call(test_files)
      total_execution_time = test_files.sum { |test_file| test_file.fetch('time_execution') }
      time_threshold = (total_execution_time / KnapsackPro::Config::Env.ci_node_total) * TIME_THRESHOLD_PER_CI_NODE

      test_files.select do |test_file|
        execution_time = test_file.fetch('time_execution')
        next false if execution_time.zero?
        next true if execution_time >= time_threshold
        next false unless KnapsackPro::Config::Env.slow_test_file_threshold?

        execution_time >= KnapsackPro::Config::Env.slow_test_file_threshold
      end
    end

    def self.save_to_json_report(test_files)
      KnapsackPro::Config::TempFiles.ensure_temp_directory_exists!
      FileUtils.mkdir_p(report_dir)
      File.write(report_path, test_files.to_json)
    end

    def self.read_from_json_report
      raise "The report with slow test files has not been generated yet. If you have enabled split by test cases #{KnapsackPro::Urls::SPLIT_BY_TEST_EXAMPLES} and you see this error it means that your tests accidentally cleaned up the .knapsack_pro directory. Please do not remove this directory during tests runtime!" unless File.exist?(report_path)
      slow_test_files_json_report = File.read(report_path)
      JSON.parse(slow_test_files_json_report)
    end

    private

    def self.report_path
      "#{report_dir}/slow_test_files_node_#{KnapsackPro::Config::Env.ci_node_index}.json"
    end

    def self.report_dir
      "#{KnapsackPro::Config::TempFiles::TEMP_DIRECTORY_PATH}/slow_test_file_determiner"
    end
  end
end