debian-mirror-gitlab/spec/tooling/rspec_flaky/config_spec.rb

107 lines
3.3 KiB
Ruby
Raw Normal View History

2019-12-04 20:38:33 +05:30
# frozen_string_literal: true
2021-04-17 20:07:23 +05:30
require 'rspec-parameterized'
require_relative '../../support/helpers/stub_env'
require_relative '../../../tooling/rspec_flaky/config'
2018-03-17 18:26:18 +05:30
2020-07-28 23:09:34 +05:30
RSpec.describe RspecFlaky::Config, :aggregate_failures do
2021-04-17 20:07:23 +05:30
include StubENV
2018-03-17 18:26:18 +05:30
before do
# Stub these env variables otherwise specs don't behave the same on the CI
stub_env('FLAKY_RSPEC_GENERATE_REPORT', nil)
stub_env('SUITE_FLAKY_RSPEC_REPORT_PATH', nil)
stub_env('FLAKY_RSPEC_REPORT_PATH', nil)
stub_env('NEW_FLAKY_RSPEC_REPORT_PATH', nil)
2021-04-17 20:07:23 +05:30
# 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
2018-03-17 18:26:18 +05:30
end
describe '.generate_report?' do
context "when ENV['FLAKY_RSPEC_GENERATE_REPORT'] is not set" do
it 'returns false' do
expect(described_class).not_to be_generate_report
end
end
2018-10-15 14:42:47 +05:30
context "when ENV['FLAKY_RSPEC_GENERATE_REPORT'] is set" do
using RSpec::Parameterized::TableSyntax
2018-03-17 18:26:18 +05:30
2018-10-15 14:42:47 +05:30
where(:env_value, :result) do
'1' | true
'true' | true
'foo' | false
'0' | false
'false' | false
2018-03-17 18:26:18 +05:30
end
2018-10-15 14:42:47 +05:30
with_them do
before do
stub_env('FLAKY_RSPEC_GENERATE_REPORT', env_value)
end
2018-03-17 18:26:18 +05:30
2018-10-15 14:42:47 +05:30
it 'returns false' do
expect(described_class.generate_report?).to be(result)
end
2018-03-17 18:26:18 +05:30
end
end
end
describe '.suite_flaky_examples_report_path' do
context "when ENV['SUITE_FLAKY_RSPEC_REPORT_PATH'] is not set" do
it 'returns the default path' do
2021-04-17 20:07:23 +05:30
expect(described_class.suite_flaky_examples_report_path).to eq('rspec_flaky/suite-report.json')
2018-03-17 18:26:18 +05:30
end
end
context "when ENV['SUITE_FLAKY_RSPEC_REPORT_PATH'] is set" do
before do
stub_env('SUITE_FLAKY_RSPEC_REPORT_PATH', 'foo/suite-report.json')
end
it 'returns the value of the env variable' do
expect(described_class.suite_flaky_examples_report_path).to eq('foo/suite-report.json')
end
end
end
describe '.flaky_examples_report_path' do
context "when ENV['FLAKY_RSPEC_REPORT_PATH'] is not set" do
it 'returns the default path' do
2021-04-17 20:07:23 +05:30
expect(described_class.flaky_examples_report_path).to eq('rspec_flaky/report.json')
2018-03-17 18:26:18 +05:30
end
end
context "when ENV['FLAKY_RSPEC_REPORT_PATH'] is set" do
before do
stub_env('FLAKY_RSPEC_REPORT_PATH', 'foo/report.json')
end
it 'returns the value of the env variable' do
expect(described_class.flaky_examples_report_path).to eq('foo/report.json')
end
end
end
describe '.new_flaky_examples_report_path' do
context "when ENV['NEW_FLAKY_RSPEC_REPORT_PATH'] is not set" do
it 'returns the default path' do
2021-04-17 20:07:23 +05:30
expect(described_class.new_flaky_examples_report_path).to eq('rspec_flaky/new-report.json')
2018-03-17 18:26:18 +05:30
end
end
context "when ENV['NEW_FLAKY_RSPEC_REPORT_PATH'] is set" do
before do
stub_env('NEW_FLAKY_RSPEC_REPORT_PATH', 'foo/new-report.json')
end
it 'returns the value of the env variable' do
expect(described_class.new_flaky_examples_report_path).to eq('foo/new-report.json')
end
end
end
end