# frozen_string_literal: true return unless ENV['CI'] return unless ENV['SKIP_FLAKY_TESTS_AUTOMATICALLY'] == "true" return if ENV['CI_MERGE_REQUEST_LABELS'].to_s.include?('pipeline:run-flaky-tests') require_relative '../../tooling/rspec_flaky/report' RSpec.configure do |config| $flaky_test_example_ids = begin # rubocop:disable Style/GlobalVars raise "$SUITE_FLAKY_RSPEC_REPORT_PATH is empty." if ENV['SUITE_FLAKY_RSPEC_REPORT_PATH'].to_s.empty? raise "#{ENV['SUITE_FLAKY_RSPEC_REPORT_PATH']} doesn't exist" unless File.exist?(ENV['SUITE_FLAKY_RSPEC_REPORT_PATH']) RspecFlaky::Report.load(ENV['SUITE_FLAKY_RSPEC_REPORT_PATH']).map { |_, flaky_test_data| flaky_test_data["example_id"] } rescue => e # rubocop:disable Style/RescueStandardError puts e [] end $skipped_flaky_tests_report = [] # rubocop:disable Style/GlobalVars config.around do |example| # Skip flaky tests automatically if $flaky_test_example_ids.include?(example.id) # rubocop:disable Style/GlobalVars puts "Skipping #{example.id} '#{example.full_description}' because it's flaky." $skipped_flaky_tests_report << example.id # rubocop:disable Style/GlobalVars else example.run end end config.after(:suite) do next unless ENV['SKIPPED_FLAKY_TESTS_REPORT_PATH'] File.write(ENV['SKIPPED_FLAKY_TESTS_REPORT_PATH'], "#{$skipped_flaky_tests_report.join("\n")}\n") # rubocop:disable Style/GlobalVars end end