Commit 54bc8f6a authored by Rémy Coutable's avatar Rémy Coutable

Move RSpecFlaky from lib/ to tooling/

This avoids autoloading non-production tooling code in production.
Signed-off-by: default avatarRémy Coutable <remy@rymai.me>
parent 229a8457
...@@ -243,7 +243,7 @@ Gitlab/Json: ...@@ -243,7 +243,7 @@ Gitlab/Json:
- 'db/**/*' - 'db/**/*'
- 'qa/**/*' - 'qa/**/*'
- 'scripts/**/*' - 'scripts/**/*'
- 'lib/rspec_flaky/**/*' - 'tooling/rspec_flaky/**/*'
- 'lib/quality/**/*' - 'lib/quality/**/*'
- 'tooling/danger/**/*' - 'tooling/danger/**/*'
......
...@@ -485,8 +485,8 @@ Rails/TimeZone: ...@@ -485,8 +485,8 @@ Rails/TimeZone:
- 'lib/json_web_token/token.rb' - 'lib/json_web_token/token.rb'
- 'lib/object_storage/direct_upload.rb' - 'lib/object_storage/direct_upload.rb'
- 'lib/quality/seeders/issues.rb' - 'lib/quality/seeders/issues.rb'
- 'lib/rspec_flaky/flaky_example.rb' - 'tooling/rspec_flaky/flaky_example.rb'
- 'lib/rspec_flaky/report.rb' - 'tooling/rspec_flaky/report.rb'
- 'lib/tasks/gitlab/assets.rake' - 'lib/tasks/gitlab/assets.rake'
- 'lib/tasks/gitlab/backup.rake' - 'lib/tasks/gitlab/backup.rake'
- 'lib/tasks/gitlab/cleanup.rake' - 'lib/tasks/gitlab/cleanup.rake'
...@@ -552,9 +552,9 @@ Rails/TimeZone: ...@@ -552,9 +552,9 @@ Rails/TimeZone:
- 'spec/lib/gitlab/x509/signature_spec.rb' - 'spec/lib/gitlab/x509/signature_spec.rb'
- 'spec/lib/grafana/time_window_spec.rb' - 'spec/lib/grafana/time_window_spec.rb'
- 'spec/lib/json_web_token/hmac_token_spec.rb' - 'spec/lib/json_web_token/hmac_token_spec.rb'
- 'spec/lib/rspec_flaky/flaky_example_spec.rb' - 'spec/tooling/rspec_flaky/flaky_example_spec.rb'
- 'spec/lib/rspec_flaky/listener_spec.rb' - 'spec/tooling/rspec_flaky/listener_spec.rb'
- 'spec/lib/rspec_flaky/report_spec.rb' - 'spec/tooling/rspec_flaky/report_spec.rb'
RSpec/TimecopFreeze: RSpec/TimecopFreeze:
Exclude: Exclude:
...@@ -627,8 +627,8 @@ RSpec/TimecopFreeze: ...@@ -627,8 +627,8 @@ RSpec/TimecopFreeze:
- 'spec/lib/gitlab/puma_logging/json_formatter_spec.rb' - 'spec/lib/gitlab/puma_logging/json_formatter_spec.rb'
- 'spec/lib/gitlab/sidekiq_logging/structured_logger_spec.rb' - 'spec/lib/gitlab/sidekiq_logging/structured_logger_spec.rb'
- 'spec/lib/json_web_token/hmac_token_spec.rb' - 'spec/lib/json_web_token/hmac_token_spec.rb'
- 'spec/lib/rspec_flaky/flaky_example_spec.rb' - 'spec/tooling/rspec_flaky/flaky_example_spec.rb'
- 'spec/lib/rspec_flaky/listener_spec.rb' - 'spec/tooling/rspec_flaky/listener_spec.rb'
- 'spec/models/active_session_spec.rb' - 'spec/models/active_session_spec.rb'
- 'spec/serializers/entity_date_helper_spec.rb' - 'spec/serializers/entity_date_helper_spec.rb'
- 'spec/support/cycle_analytics_helpers/test_generation.rb' - 'spec/support/cycle_analytics_helpers/test_generation.rb'
......
#!/usr/bin/env ruby #!/usr/bin/env ruby
# frozen_string_literal: true # frozen_string_literal: true
# lib/rspec_flaky/flaky_examples_collection.rb is requiring # tooling/rspec_flaky/flaky_examples_collection.rb is requiring
# `active_support/hash_with_indifferent_access`, and we install the `activesupport` # `active_support/hash_with_indifferent_access`, and we install the `activesupport`
# gem manually on the CI # gem manually on the CI
require 'rubygems' require 'rubygems'
require_relative '../../tooling/rspec_flaky/report'
# In newer Ruby, alias_method is not private then we don't need __send__
singleton_class.__send__(:alias_method, :require_dependency, :require) # rubocop:disable GitlabSecurity/PublicSend
$:.unshift(File.expand_path('../../lib', __dir__))
require 'rspec_flaky/report'
report_file = ARGV.shift report_file = ARGV.shift
unless report_file unless report_file
......
...@@ -180,6 +180,8 @@ RSpec.configure do |config| ...@@ -180,6 +180,8 @@ RSpec.configure do |config|
end end
if ENV['FLAKY_RSPEC_GENERATE_REPORT'] if ENV['FLAKY_RSPEC_GENERATE_REPORT']
require_relative '../tooling/rspec_flaky/listener'
config.reporter.register_listener( config.reporter.register_listener(
RspecFlaky::Listener.new, RspecFlaky::Listener.new,
:example_passed, :example_passed,
......
# frozen_string_literal: true # frozen_string_literal: true
require 'spec_helper' require 'rspec-parameterized'
require_relative '../../support/helpers/stub_env'
require_relative '../../../tooling/rspec_flaky/config'
RSpec.describe RspecFlaky::Config, :aggregate_failures do RSpec.describe RspecFlaky::Config, :aggregate_failures do
include StubENV
before do before do
# Stub these env variables otherwise specs don't behave the same on the CI # Stub these env variables otherwise specs don't behave the same on the CI
stub_env('FLAKY_RSPEC_GENERATE_REPORT', nil) stub_env('FLAKY_RSPEC_GENERATE_REPORT', nil)
stub_env('SUITE_FLAKY_RSPEC_REPORT_PATH', nil) stub_env('SUITE_FLAKY_RSPEC_REPORT_PATH', nil)
stub_env('FLAKY_RSPEC_REPORT_PATH', nil) stub_env('FLAKY_RSPEC_REPORT_PATH', nil)
stub_env('NEW_FLAKY_RSPEC_REPORT_PATH', nil) stub_env('NEW_FLAKY_RSPEC_REPORT_PATH', nil)
# Ensure the behavior is the same locally and on CI (where Rails is defined since we run this test as part of the whole suite), i.e. Rails isn't defined
allow(described_class).to receive(:rails_path).and_wrap_original do |method, path|
path
end
end end
describe '.generate_report?' do describe '.generate_report?' do
...@@ -44,10 +53,7 @@ RSpec.describe RspecFlaky::Config, :aggregate_failures do ...@@ -44,10 +53,7 @@ RSpec.describe RspecFlaky::Config, :aggregate_failures do
describe '.suite_flaky_examples_report_path' do describe '.suite_flaky_examples_report_path' do
context "when ENV['SUITE_FLAKY_RSPEC_REPORT_PATH'] is not set" do context "when ENV['SUITE_FLAKY_RSPEC_REPORT_PATH'] is not set" do
it 'returns the default path' do it 'returns the default path' do
expect(Rails.root).to receive(:join).with('rspec_flaky/suite-report.json') expect(described_class.suite_flaky_examples_report_path).to eq('rspec_flaky/suite-report.json')
.and_return('root/rspec_flaky/suite-report.json')
expect(described_class.suite_flaky_examples_report_path).to eq('root/rspec_flaky/suite-report.json')
end end
end end
...@@ -65,10 +71,7 @@ RSpec.describe RspecFlaky::Config, :aggregate_failures do ...@@ -65,10 +71,7 @@ RSpec.describe RspecFlaky::Config, :aggregate_failures do
describe '.flaky_examples_report_path' do describe '.flaky_examples_report_path' do
context "when ENV['FLAKY_RSPEC_REPORT_PATH'] is not set" do context "when ENV['FLAKY_RSPEC_REPORT_PATH'] is not set" do
it 'returns the default path' do it 'returns the default path' do
expect(Rails.root).to receive(:join).with('rspec_flaky/report.json') expect(described_class.flaky_examples_report_path).to eq('rspec_flaky/report.json')
.and_return('root/rspec_flaky/report.json')
expect(described_class.flaky_examples_report_path).to eq('root/rspec_flaky/report.json')
end end
end end
...@@ -86,10 +89,7 @@ RSpec.describe RspecFlaky::Config, :aggregate_failures do ...@@ -86,10 +89,7 @@ RSpec.describe RspecFlaky::Config, :aggregate_failures do
describe '.new_flaky_examples_report_path' do describe '.new_flaky_examples_report_path' do
context "when ENV['NEW_FLAKY_RSPEC_REPORT_PATH'] is not set" do context "when ENV['NEW_FLAKY_RSPEC_REPORT_PATH'] is not set" do
it 'returns the default path' do it 'returns the default path' do
expect(Rails.root).to receive(:join).with('rspec_flaky/new-report.json') expect(described_class.new_flaky_examples_report_path).to eq('rspec_flaky/new-report.json')
.and_return('root/rspec_flaky/new-report.json')
expect(described_class.new_flaky_examples_report_path).to eq('root/rspec_flaky/new-report.json')
end end
end end
......
# frozen_string_literal: true # frozen_string_literal: true
require 'spec_helper' require_relative '../../../tooling/rspec_flaky/example'
RSpec.describe RspecFlaky::Example do RSpec.describe RspecFlaky::Example do
let(:example_attrs) do let(:example_attrs) do
......
# frozen_string_literal: true # frozen_string_literal: true
require 'spec_helper' require 'active_support/testing/time_helpers'
require_relative '../../support/helpers/stub_env'
require_relative '../../../tooling/rspec_flaky/flaky_example'
RSpec.describe RspecFlaky::FlakyExample, :aggregate_failures do RSpec.describe RspecFlaky::FlakyExample, :aggregate_failures do
include ActiveSupport::Testing::TimeHelpers
include StubENV
let(:flaky_example_attrs) do let(:flaky_example_attrs) do
{ {
example_id: 'spec/foo/bar_spec.rb:2', example_id: 'spec/foo/bar_spec.rb:2',
...@@ -30,7 +36,7 @@ RSpec.describe RspecFlaky::FlakyExample, :aggregate_failures do ...@@ -30,7 +36,7 @@ RSpec.describe RspecFlaky::FlakyExample, :aggregate_failures do
} }
end end
let(:example) { double(example_attrs) } let(:example) { OpenStruct.new(example_attrs) }
before do before do
# Stub these env variables otherwise specs don't behave the same on the CI # Stub these env variables otherwise specs don't behave the same on the CI
...@@ -77,19 +83,33 @@ RSpec.describe RspecFlaky::FlakyExample, :aggregate_failures do ...@@ -77,19 +83,33 @@ RSpec.describe RspecFlaky::FlakyExample, :aggregate_failures do
shared_examples 'an up-to-date FlakyExample instance' do shared_examples 'an up-to-date FlakyExample instance' do
let(:flaky_example) { described_class.new(args) } let(:flaky_example) { described_class.new(args) }
it 'updates the first_flaky_at' do it 'sets the first_flaky_at if none exists' do
now = Time.now args[:first_flaky_at] = nil
expected_first_flaky_at = flaky_example.first_flaky_at || now
Timecop.freeze(now) { flaky_example.update_flakiness! }
expect(flaky_example.first_flaky_at).to eq(expected_first_flaky_at) freeze_time do
flaky_example.update_flakiness!
expect(flaky_example.first_flaky_at).to eq(Time.now)
end
end
it 'maintains the first_flaky_at if exists' do
flaky_example.update_flakiness!
expected_first_flaky_at = flaky_example.first_flaky_at
travel_to(Time.now + 42) do
flaky_example.update_flakiness!
expect(flaky_example.first_flaky_at).to eq(expected_first_flaky_at)
end
end end
it 'updates the last_flaky_at' do it 'updates the last_flaky_at' do
now = Time.now travel_to(Time.now + 42) do
Timecop.freeze(now) { flaky_example.update_flakiness! } the_future = Time.now
flaky_example.update_flakiness!
expect(flaky_example.last_flaky_at).to eq(now) expect(flaky_example.last_flaky_at).to eq(the_future)
end
end end
it 'updates the flaky_reports' do it 'updates the flaky_reports' do
......
# frozen_string_literal: true # frozen_string_literal: true
require 'spec_helper' require_relative '../../../tooling/rspec_flaky/flaky_examples_collection'
RSpec.describe RspecFlaky::FlakyExamplesCollection, :aggregate_failures do RSpec.describe RspecFlaky::FlakyExamplesCollection, :aggregate_failures do
let(:collection_hash) do let(:collection_hash) do
......
# frozen_string_literal: true # frozen_string_literal: true
require 'spec_helper' require 'active_support/testing/time_helpers'
require_relative '../../support/helpers/stub_env'
require_relative '../../../tooling/rspec_flaky/listener'
RSpec.describe RspecFlaky::Listener, :aggregate_failures do RSpec.describe RspecFlaky::Listener, :aggregate_failures do
include ActiveSupport::Testing::TimeHelpers
include StubENV
let(:already_flaky_example_uid) { '6e869794f4cfd2badd93eb68719371d1' } let(:already_flaky_example_uid) { '6e869794f4cfd2badd93eb68719371d1' }
let(:suite_flaky_example_report) do let(:suite_flaky_example_report) do
{ {
...@@ -130,14 +136,13 @@ RSpec.describe RspecFlaky::Listener, :aggregate_failures do ...@@ -130,14 +136,13 @@ RSpec.describe RspecFlaky::Listener, :aggregate_failures do
it 'changes the flaky examples hash' do it 'changes the flaky examples hash' do
new_example = RspecFlaky::Example.new(rspec_example) new_example = RspecFlaky::Example.new(rspec_example)
now = Time.now travel_to(Time.now + 42) do
Timecop.freeze(now) do the_future = Time.now
expect { listener.example_passed(notification) } expect { listener.example_passed(notification) }
.to change { listener.flaky_examples[new_example.uid].to_h } .to change { listener.flaky_examples[new_example.uid].to_h }
expect(listener.flaky_examples[new_example.uid].to_h)
.to eq(expected_flaky_example.merge(last_flaky_at: the_future))
end end
expect(listener.flaky_examples[new_example.uid].to_h)
.to eq(expected_flaky_example.merge(last_flaky_at: now))
end end
end end
...@@ -157,14 +162,13 @@ RSpec.describe RspecFlaky::Listener, :aggregate_failures do ...@@ -157,14 +162,13 @@ RSpec.describe RspecFlaky::Listener, :aggregate_failures do
it 'changes the all flaky examples hash' do it 'changes the all flaky examples hash' do
new_example = RspecFlaky::Example.new(rspec_example) new_example = RspecFlaky::Example.new(rspec_example)
now = Time.now travel_to(Time.now + 42) do
Timecop.freeze(now) do the_future = Time.now
expect { listener.example_passed(notification) } expect { listener.example_passed(notification) }
.to change { listener.flaky_examples[new_example.uid].to_h } .to change { listener.flaky_examples[new_example.uid].to_h }
expect(listener.flaky_examples[new_example.uid].to_h)
.to eq(expected_flaky_example.merge(first_flaky_at: the_future, last_flaky_at: the_future))
end end
expect(listener.flaky_examples[new_example.uid].to_h)
.to eq(expected_flaky_example.merge(first_flaky_at: now, last_flaky_at: now))
end end
end end
...@@ -198,6 +202,10 @@ RSpec.describe RspecFlaky::Listener, :aggregate_failures do ...@@ -198,6 +202,10 @@ RSpec.describe RspecFlaky::Listener, :aggregate_failures do
let(:notification_new_flaky_rspec_example) { double(example: new_flaky_rspec_example) } let(:notification_new_flaky_rspec_example) { double(example: new_flaky_rspec_example) }
let(:notification_already_flaky_rspec_example) { double(example: already_flaky_rspec_example) } let(:notification_already_flaky_rspec_example) { double(example: already_flaky_rspec_example) }
before do
allow(Kernel).to receive(:warn)
end
context 'when a report file path is set by FLAKY_RSPEC_REPORT_PATH' do context 'when a report file path is set by FLAKY_RSPEC_REPORT_PATH' do
it 'delegates the writes to RspecFlaky::Report' do it 'delegates the writes to RspecFlaky::Report' do
listener.example_passed(notification_new_flaky_rspec_example) listener.example_passed(notification_new_flaky_rspec_example)
......
# frozen_string_literal: true # frozen_string_literal: true
require 'spec_helper' require 'tempfile'
require_relative '../../../tooling/rspec_flaky/report'
RSpec.describe RspecFlaky::Report, :aggregate_failures do RSpec.describe RspecFlaky::Report, :aggregate_failures do
let(:thirty_one_days) { 3600 * 24 * 31 } let(:thirty_one_days) { 3600 * 24 * 31 }
...@@ -30,10 +32,14 @@ RSpec.describe RspecFlaky::Report, :aggregate_failures do ...@@ -30,10 +32,14 @@ RSpec.describe RspecFlaky::Report, :aggregate_failures do
let(:flaky_examples) { RspecFlaky::FlakyExamplesCollection.new(collection_hash) } let(:flaky_examples) { RspecFlaky::FlakyExamplesCollection.new(collection_hash) }
let(:report) { described_class.new(flaky_examples) } let(:report) { described_class.new(flaky_examples) }
before do
allow(Kernel).to receive(:warn)
end
describe '.load' do describe '.load' do
let!(:report_file) do let!(:report_file) do
Tempfile.new(%w[rspec_flaky_report .json]).tap do |f| Tempfile.new(%w[rspec_flaky_report .json]).tap do |f|
f.write(Gitlab::Json.pretty_generate(suite_flaky_example_report)) f.write(JSON.pretty_generate(suite_flaky_example_report)) # rubocop:disable Gitlab/Json
f.rewind f.rewind
end end
end end
...@@ -50,7 +56,7 @@ RSpec.describe RspecFlaky::Report, :aggregate_failures do ...@@ -50,7 +56,7 @@ RSpec.describe RspecFlaky::Report, :aggregate_failures do
describe '.load_json' do describe '.load_json' do
let(:report_json) do let(:report_json) do
Gitlab::Json.pretty_generate(suite_flaky_example_report) JSON.pretty_generate(suite_flaky_example_report) # rubocop:disable Gitlab/Json
end end
it 'loads the report file' do it 'loads the report file' do
...@@ -73,7 +79,7 @@ RSpec.describe RspecFlaky::Report, :aggregate_failures do ...@@ -73,7 +79,7 @@ RSpec.describe RspecFlaky::Report, :aggregate_failures do
end end
describe '#write' do describe '#write' do
let(:report_file_path) { Rails.root.join('tmp', 'rspec_flaky_report.json') } let(:report_file_path) { File.join('tmp', 'rspec_flaky_report.json') }
before do before do
FileUtils.rm(report_file_path) if File.exist?(report_file_path) FileUtils.rm(report_file_path) if File.exist?(report_file_path)
...@@ -105,7 +111,7 @@ RSpec.describe RspecFlaky::Report, :aggregate_failures do ...@@ -105,7 +111,7 @@ RSpec.describe RspecFlaky::Report, :aggregate_failures do
expect(File.exist?(report_file_path)).to be(true) expect(File.exist?(report_file_path)).to be(true)
expect(File.read(report_file_path)) expect(File.read(report_file_path))
.to eq(Gitlab::Json.pretty_generate(report.flaky_examples.to_h)) .to eq(JSON.pretty_generate(report.flaky_examples.to_h)) # rubocop:disable Gitlab/Json
end end
end end
end end
......
...@@ -7,15 +7,21 @@ module RspecFlaky ...@@ -7,15 +7,21 @@ module RspecFlaky
end end
def self.suite_flaky_examples_report_path def self.suite_flaky_examples_report_path
ENV['SUITE_FLAKY_RSPEC_REPORT_PATH'] || Rails.root.join("rspec_flaky/suite-report.json") ENV['SUITE_FLAKY_RSPEC_REPORT_PATH'] || rails_path("rspec_flaky/suite-report.json")
end end
def self.flaky_examples_report_path def self.flaky_examples_report_path
ENV['FLAKY_RSPEC_REPORT_PATH'] || Rails.root.join("rspec_flaky/report.json") ENV['FLAKY_RSPEC_REPORT_PATH'] || rails_path("rspec_flaky/report.json")
end end
def self.new_flaky_examples_report_path def self.new_flaky_examples_report_path
ENV['NEW_FLAKY_RSPEC_REPORT_PATH'] || Rails.root.join("rspec_flaky/new-report.json") ENV['NEW_FLAKY_RSPEC_REPORT_PATH'] || rails_path("rspec_flaky/new-report.json")
end
def self.rails_path(path)
return path unless defined?(Rails)
Rails.root.join(path)
end end
end end
end end
# frozen_string_literal: true # frozen_string_literal: true
require 'forwardable'
require 'digest'
module RspecFlaky module RspecFlaky
# This is a wrapper class for RSpec::Core::Example # This is a wrapper class for RSpec::Core::Example
class Example class Example
delegate :status, :exception, to: :execution_result extend Forwardable
def_delegators :execution_result, :status, :exception
def initialize(rspec_example) def initialize(rspec_example)
@rspec_example = rspec_example.try(:example) || rspec_example @rspec_example = rspec_example.respond_to?(:example) ? rspec_example.example : rspec_example
end end
def uid def uid
...@@ -30,7 +35,7 @@ module RspecFlaky ...@@ -30,7 +35,7 @@ module RspecFlaky
end end
def attempts def attempts
rspec_example.try(:attempts) || 1 rspec_example.respond_to?(:attempts) ? rspec_example.attempts : 1
end end
private private
......
# frozen_string_literal: true # frozen_string_literal: true
require 'ostruct'
module RspecFlaky module RspecFlaky
# This represents a flaky RSpec example and is mainly meant to be saved in a JSON file # This represents a flaky RSpec example and is mainly meant to be saved in a JSON file
class FlakyExample < OpenStruct class FlakyExample < OpenStruct
......
...@@ -2,11 +2,11 @@ ...@@ -2,11 +2,11 @@
require 'json' require 'json'
require_dependency 'rspec_flaky/config' require_relative 'config'
require_dependency 'rspec_flaky/example' require_relative 'example'
require_dependency 'rspec_flaky/flaky_example' require_relative 'flaky_example'
require_dependency 'rspec_flaky/flaky_examples_collection' require_relative 'flaky_examples_collection'
require_dependency 'rspec_flaky/report' require_relative 'report'
module RspecFlaky module RspecFlaky
class Listener class Listener
...@@ -32,21 +32,19 @@ module RspecFlaky ...@@ -32,21 +32,19 @@ module RspecFlaky
flaky_examples[current_example.uid] = flaky_example flaky_examples[current_example.uid] = flaky_example
end end
# rubocop:disable Gitlab/RailsLogger
def dump_summary(_) def dump_summary(_)
RspecFlaky::Report.new(flaky_examples).write(RspecFlaky::Config.flaky_examples_report_path) RspecFlaky::Report.new(flaky_examples).write(RspecFlaky::Config.flaky_examples_report_path)
# write_report_file(flaky_examples, RspecFlaky::Config.flaky_examples_report_path) # write_report_file(flaky_examples, RspecFlaky::Config.flaky_examples_report_path)
new_flaky_examples = flaky_examples - suite_flaky_examples new_flaky_examples = flaky_examples - suite_flaky_examples
if new_flaky_examples.any? if new_flaky_examples.any?
Rails.logger.warn "\nNew flaky examples detected:\n" rails_logger_warn("\nNew flaky examples detected:\n")
Rails.logger.warn Gitlab::Json.pretty_generate(new_flaky_examples.to_h) rails_logger_warn(JSON.pretty_generate(new_flaky_examples.to_h)) # rubocop:disable Gitlab/Json
RspecFlaky::Report.new(new_flaky_examples).write(RspecFlaky::Config.new_flaky_examples_report_path) RspecFlaky::Report.new(new_flaky_examples).write(RspecFlaky::Config.new_flaky_examples_report_path)
# write_report_file(new_flaky_examples, RspecFlaky::Config.new_flaky_examples_report_path) # write_report_file(new_flaky_examples, RspecFlaky::Config.new_flaky_examples_report_path)
end end
end end
# rubocop:enable Gitlab/RailsLogger
private private
...@@ -59,5 +57,11 @@ module RspecFlaky ...@@ -59,5 +57,11 @@ module RspecFlaky
RspecFlaky::Report.load(RspecFlaky::Config.suite_flaky_examples_report_path).flaky_examples RspecFlaky::Report.load(RspecFlaky::Config.suite_flaky_examples_report_path).flaky_examples
end end
end end
def rails_logger_warn(text)
target = defined?(Rails) ? Rails.logger : Kernel
target.warn(text)
end
end end
end end
...@@ -3,8 +3,8 @@ ...@@ -3,8 +3,8 @@
require 'json' require 'json'
require 'time' require 'time'
require_dependency 'rspec_flaky/config' require_relative 'config'
require_dependency 'rspec_flaky/flaky_examples_collection' require_relative 'flaky_examples_collection'
module RspecFlaky module RspecFlaky
# This class is responsible for loading/saving JSON reports, and pruning # This class is responsible for loading/saving JSON reports, and pruning
...@@ -33,7 +33,7 @@ module RspecFlaky ...@@ -33,7 +33,7 @@ module RspecFlaky
def write(file_path) def write(file_path)
unless RspecFlaky::Config.generate_report? unless RspecFlaky::Config.generate_report?
puts "! Generating reports is disabled. To enable it, please set the `FLAKY_RSPEC_GENERATE_REPORT=1` !" # rubocop:disable Rails/Output Kernel.warn "! Generating reports is disabled. To enable it, please set the `FLAKY_RSPEC_GENERATE_REPORT=1` !"
return return
end end
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment