debian-mirror-gitlab/spec/spec_helper.rb

518 lines
19 KiB
Ruby
Raw Normal View History

2019-12-21 20:55:43 +05:30
# frozen_string_literal: true
2022-11-25 23:54:43 +05:30
if $LOADED_FEATURES.include?(File.expand_path('fast_spec_helper.rb', __dir__))
2021-01-29 00:20:46 +05:30
warn 'Detected fast_spec_helper is loaded first than spec_helper.'
warn 'If running test files using both spec_helper and fast_spec_helper,'
2022-06-21 17:19:12 +05:30
warn 'make sure spec_helper is loaded first, or run rspec with `-r spec_helper`.'
2021-01-29 00:20:46 +05:30
abort 'Aborting...'
end
2023-05-27 22:25:52 +05:30
require './spec/deprecation_warnings'
2021-02-22 17:27:13 +05:30
require './spec/deprecation_toolkit_env'
2021-03-11 19:13:27 +05:30
DeprecationToolkitEnv.configure!
2021-02-22 17:27:13 +05:30
2021-04-29 21:17:54 +05:30
require './spec/knapsack_env'
KnapsackEnv.configure!
2016-09-13 17:45:13 +05:30
require './spec/simplecov_env'
SimpleCovEnv.start!
2014-09-02 18:07:02 +05:30
2021-01-29 00:20:46 +05:30
require './spec/crystalball_env'
CrystalballEnv.start!
2018-03-17 18:26:18 +05:30
ENV["RAILS_ENV"] = 'test'
2017-08-17 22:00:37 +05:30
ENV["IN_MEMORY_APPLICATION_SETTINGS"] = 'true'
2019-07-31 22:56:46 +05:30
ENV["RSPEC_ALLOW_INVALID_URLS"] = 'true'
2015-09-11 14:41:01 +05:30
2021-04-29 21:17:54 +05:30
require_relative '../config/environment'
2020-05-24 23:13:21 +05:30
require 'rspec/mocks'
2014-09-02 18:07:02 +05:30
require 'rspec/rails'
2016-06-02 11:05:42 +05:30
require 'rspec/retry'
2018-03-17 18:26:18 +05:30
require 'rspec-parameterized'
2020-05-24 23:13:21 +05:30
require 'shoulda/matchers'
2019-12-21 20:55:43 +05:30
require 'test_prof/recipes/rspec/let_it_be'
2020-11-24 15:15:51 +05:30
require 'test_prof/factory_default'
2022-10-11 01:57:18 +05:30
require 'test_prof/factory_prof/nate_heckler'
2021-03-11 19:13:27 +05:30
require 'parslet/rig/rspec'
2023-05-27 22:25:52 +05:30
require 'axe-rspec'
2014-09-02 18:07:02 +05:30
2017-08-17 22:00:37 +05:30
rspec_profiling_is_configured =
2017-09-10 17:25:29 +05:30
ENV['RSPEC_PROFILING_POSTGRES_URL'].present? ||
2017-08-17 22:00:37 +05:30
ENV['RSPEC_PROFILING']
branch_can_be_profiled =
(ENV['CI_COMMIT_REF_NAME'] == 'master' ||
2023-04-23 21:23:45 +05:30
ENV['CI_COMMIT_REF_NAME']&.include?('rspec-profile'))
2017-08-17 22:00:37 +05:30
if rspec_profiling_is_configured && (!ENV.key?('CI') || branch_can_be_profiled)
require 'rspec_profiling/rspec'
end
2017-09-10 17:25:29 +05:30
# require rainbow gem String monkeypatch, so we can test SystemChecks
require 'rainbow/ext/string'
2018-11-20 20:47:30 +05:30
Rainbow.enabled = false
2017-09-10 17:25:29 +05:30
2022-10-11 01:57:18 +05:30
# Enable zero monkey patching mode before loading any other RSpec code.
RSpec.configure(&:disable_monkey_patching!)
2022-07-23 23:45:48 +05:30
require_relative('../ee/spec/spec_helper') if Gitlab.ee?
2022-08-27 11:52:29 +05:30
require_relative('../jh/spec/spec_helper') if Gitlab.jh?
2019-12-04 20:38:33 +05:30
2014-09-02 18:07:02 +05:30
# Requires supporting ruby files with custom matchers and macros, etc,
# in spec/support/ and its subdirectories.
2018-10-15 14:42:47 +05:30
# Requires helpers, and shared contexts/examples first since they're used in other support files
2018-12-05 23:21:45 +05:30
# Load these first since they may be required by other helpers
2021-01-29 00:20:46 +05:30
require Rails.root.join("spec/support/helpers/stub_requests.rb")
2018-12-05 23:21:45 +05:30
# Then the rest
2020-11-24 15:15:51 +05:30
Dir[Rails.root.join("spec/support/helpers/*.rb")].sort.each { |f| require f }
Dir[Rails.root.join("spec/support/shared_contexts/*.rb")].sort.each { |f| require f }
Dir[Rails.root.join("spec/support/shared_examples/*.rb")].sort.each { |f| require f }
Dir[Rails.root.join("spec/support/**/*.rb")].sort.each { |f| require f }
2014-09-02 18:07:02 +05:30
2021-04-29 21:17:54 +05:30
require_relative '../tooling/quality/test_level'
2019-09-04 21:01:54 +05:30
quality_level = Quality::TestLevel.new
2014-09-02 18:07:02 +05:30
RSpec.configure do |config|
2019-09-30 21:07:59 +05:30
config.use_transactional_fixtures = true
2021-04-29 21:17:54 +05:30
config.use_instantiated_fixtures = false
2018-11-20 20:47:30 +05:30
config.fixture_path = Rails.root
2014-09-02 18:07:02 +05:30
2016-06-02 11:05:42 +05:30
config.verbose_retry = true
config.display_try_failure_messages = true
2015-04-26 12:48:37 +05:30
config.infer_spec_type_from_file_location!
2021-01-03 14:25:43 +05:30
# Add :full_backtrace tag to an example if full_backtrace output is desired
config.before(:each, full_backtrace: true) do |example|
config.full_backtrace = true
end
2017-08-17 22:00:37 +05:30
2022-04-04 11:22:00 +05:30
# Attempt to troubleshoot https://gitlab.com/gitlab-org/gitlab/-/issues/351531
config.after do |example|
if example.exception.is_a?(Gitlab::Database::QueryAnalyzers::PreventCrossDatabaseModification::CrossDatabaseModificationAcrossUnsupportedTablesError)
::CrossDatabaseModification::TransactionStackTrackRecord.log_gitlab_transactions_stack(action: :after_failure, example: example.description)
else
::CrossDatabaseModification::TransactionStackTrackRecord.log_gitlab_transactions_stack(action: :after_example, example: example.description)
end
2019-12-26 22:10:19 +05:30
end
2019-09-04 21:01:54 +05:30
config.define_derived_metadata(file_path: %r{(ee)?/spec/.+_spec\.rb\z}) do |metadata|
2018-03-17 18:26:18 +05:30
location = metadata[:location]
2019-09-04 21:01:54 +05:30
metadata[:level] = quality_level.level_for(location)
2023-04-23 21:23:45 +05:30
metadata[:api] = true if location.include?('/spec/requests/api/')
2018-03-17 18:26:18 +05:30
2020-04-08 14:13:33 +05:30
# Do not overwrite migration if it's already set
unless metadata.key?(:migration)
2023-03-17 16:20:25 +05:30
metadata[:migration] = true if metadata[:level] == :migration || metadata[:level] == :background_migration
2020-04-08 14:13:33 +05:30
end
# Do not overwrite schema if it's already set
unless metadata.key?(:schema)
2023-03-17 16:20:25 +05:30
metadata[:schema] = :latest if metadata[:level] == :background_migration
2020-04-08 14:13:33 +05:30
end
2018-03-17 18:26:18 +05:30
2020-04-08 14:13:33 +05:30
# Do not overwrite type if it's already set
unless metadata.key?(:type)
match = location.match(%r{/spec/([^/]+)/})
metadata[:type] = match[1].singularize.to_sym if match
end
2020-04-22 19:07:51 +05:30
# Admin controller specs get auto admin mode enabled since they are
# protected by the 'EnforcesAdminAuthentication' concern
metadata[:enable_admin_mode] = true if location =~ %r{(ee)?/spec/controllers/admin/}
2017-08-17 22:00:37 +05:30
end
2020-11-24 15:15:51 +05:30
config.define_derived_metadata(file_path: %r{(ee)?/spec/.+_docs\.rb\z}) do |metadata|
metadata[:type] = :feature
end
2019-07-07 11:18:12 +05:30
config.include LicenseHelpers
2018-10-15 14:42:47 +05:30
config.include ActiveJob::TestHelper
config.include ActiveSupport::Testing::TimeHelpers
config.include FactoryBot::Syntax::Methods
config.include FixtureHelpers
2020-04-22 19:07:51 +05:30
config.include NonExistingRecordsHelpers
2018-10-15 14:42:47 +05:30
config.include GitlabRoutingHelper
config.include StubGitlabCalls
2020-11-24 15:15:51 +05:30
config.include NextFoundInstanceOf
2019-12-21 20:55:43 +05:30
config.include NextInstanceOf
2018-10-15 14:42:47 +05:30
config.include TestEnv
2021-02-22 17:27:13 +05:30
config.include FileReadHelpers
2023-01-13 00:05:48 +05:30
config.include Database::MultipleDatabasesHelpers
2022-10-11 01:57:18 +05:30
config.include Database::WithoutCheckConstraint
2018-10-15 14:42:47 +05:30
config.include Devise::Test::ControllerHelpers, type: :controller
2021-02-22 17:27:13 +05:30
config.include Devise::Test::ControllerHelpers, type: :view
2018-10-15 14:42:47 +05:30
config.include Devise::Test::IntegrationHelpers, type: :feature
2021-02-22 17:27:13 +05:30
config.include Devise::Test::IntegrationHelpers, type: :request
2018-10-15 14:42:47 +05:30
config.include LoginHelpers, type: :feature
config.include SearchHelpers, type: :feature
2019-07-31 22:56:46 +05:30
config.include WaitHelpers, type: :feature
2021-01-03 14:25:43 +05:30
config.include WaitForRequests, type: :feature
2018-10-15 14:42:47 +05:30
config.include EmailHelpers, :mailer, type: :mailer
config.include Warden::Test::Helpers, type: :request
config.include Gitlab::Routing, type: :routing
config.include ApiHelpers, :api
config.include CookieHelper, :js
config.include InputHelper, :js
config.include SelectionHelper, :js
config.include InspectRequests, :js
config.include LiveDebugger, :js
config.include MigrationsHelpers, :migration
config.include RedisHelpers
2018-11-08 19:23:39 +05:30
config.include Rails.application.routes.url_helpers, type: :routing
2022-06-21 17:19:12 +05:30
config.include Rails.application.routes.url_helpers, type: :component
2019-07-07 11:18:12 +05:30
config.include PolicyHelpers, type: :policy
2019-10-12 21:52:04 +05:30
config.include ExpectRequestWithStatus, type: :request
2020-04-08 14:13:33 +05:30
config.include IdempotentWorkerHelper, type: :worker
2019-12-04 20:38:33 +05:30
config.include RailsHelpers
2020-04-22 19:07:51 +05:30
config.include SidekiqMiddleware
2020-06-23 00:09:42 +05:30
config.include StubActionCableConnection, type: :channel
2023-06-20 00:43:36 +05:30
config.include StubMemberAccessLevel
2021-09-30 23:02:18 +05:30
config.include StubSpamServices
2022-08-13 15:12:31 +05:30
config.include SnowplowHelpers
2022-07-16 23:28:13 +05:30
config.include RenderedHelpers
2022-05-07 20:08:51 +05:30
config.include RSpec::Benchmark::Matchers, type: :benchmark
2022-08-13 15:12:31 +05:30
config.include DetailedErrorHelpers
2023-05-27 22:25:52 +05:30
config.include RequestUrgencyMatcher, type: :controller
config.include RequestUrgencyMatcher, type: :request
2023-06-20 00:43:36 +05:30
config.include Capybara::RSpecMatchers, type: :request
2014-09-02 18:07:02 +05:30
2022-11-25 23:54:43 +05:30
config.include_context 'when rendered has no HTML escapes', type: :view
2020-10-24 23:57:45 +05:30
include StubFeatureFlags
2022-08-13 15:12:31 +05:30
include StubSnowplow
2022-08-27 11:52:29 +05:30
include StubMember
2020-10-24 23:57:45 +05:30
2020-03-13 15:44:24 +05:30
if ENV['CI'] || ENV['RETRIES']
2022-11-25 23:54:43 +05:30
# This includes the first try, i.e. tests will be run 2 times before failing.
config.default_retry_count = ENV.fetch('RETRIES', 1).to_i + 1
2021-12-11 22:18:48 +05:30
# Do not retry controller tests because rspec-retry cannot properly
# reset the controller which may contain data from last attempt. See
# https://gitlab.com/gitlab-org/gitlab/-/merge_requests/73360
config.prepend_before(:each, type: :controller) do |example|
example.metadata[:retry] = 1
end
2021-03-11 19:13:27 +05:30
config.exceptions_to_hard_fail = [DeprecationToolkitEnv::DeprecationBehaviors::SelectiveRaise::RaiseDisallowedDeprecation]
2020-03-13 15:44:24 +05:30
end
2022-04-04 11:22:00 +05:30
require_relative '../tooling/rspec_flaky/config'
if RspecFlaky::Config.generate_report?
2021-04-17 20:07:23 +05:30
require_relative '../tooling/rspec_flaky/listener'
2018-03-17 18:26:18 +05:30
config.reporter.register_listener(
RspecFlaky::Listener.new,
:example_passed,
:dump_summary)
2014-09-02 18:07:02 +05:30
end
2016-08-24 12:49:21 +05:30
2018-03-17 18:26:18 +05:30
config.before(:suite) do
TestEnv.init
2020-07-28 23:09:34 +05:30
# Reload all feature flags definitions
Feature.register_definitions
2020-10-24 23:57:45 +05:30
# Enable all features by default for testing
# Reset any changes in after hook.
stub_all_feature_flags
2022-06-21 17:19:12 +05:30
stub_feature_flags(main_branch_over_master: false)
2021-11-11 11:23:49 +05:30
TestEnv.seed_db
2017-08-17 22:00:37 +05:30
end
2018-05-09 12:01:36 +05:30
config.after(:all) do
TestEnv.clean_test_path
end
2020-03-13 15:44:24 +05:30
# We can't use an `around` hook here because the wrapping transaction
# is not yet opened at the time that is triggered
config.prepend_before do
2021-12-11 22:18:48 +05:30
ApplicationRecord.set_open_transactions_baseline
2022-01-26 12:08:38 +05:30
::Ci::ApplicationRecord.set_open_transactions_baseline
2020-03-13 15:44:24 +05:30
end
2022-05-07 20:08:51 +05:30
config.around do |example|
example.run
end
2020-03-13 15:44:24 +05:30
config.append_after do
2021-12-11 22:18:48 +05:30
ApplicationRecord.reset_open_transactions_baseline
2022-01-26 12:08:38 +05:30
::Ci::ApplicationRecord.reset_open_transactions_baseline
2020-03-13 15:44:24 +05:30
end
2019-05-03 19:53:19 +05:30
config.before do |example|
2020-06-23 00:09:42 +05:30
if example.metadata.fetch(:stub_feature_flags, true)
# The following can be removed when we remove the staged rollout strategy
# and we can just enable it using instance wide settings
# (ie. ApplicationSetting#auto_devops_enabled)
stub_feature_flags(force_autodevops_on_by_default: false)
2022-08-13 15:12:31 +05:30
# The survey popover can block the diffs causing specs to fail
stub_feature_flags(mr_experience_survey: false)
2021-01-03 14:25:43 +05:30
# Using FortiAuthenticator as OTP provider is disabled by default in
# tests, until we introduce it in user settings
stub_feature_flags(forti_authenticator: false)
2021-02-22 17:27:13 +05:30
# Using FortiToken Cloud as OTP provider is disabled by default in
# tests, until we introduce it in user settings
stub_feature_flags(forti_token_cloud: false)
2021-09-30 23:02:18 +05:30
# These feature flag are by default disabled and used in disaster recovery mode
stub_feature_flags(ci_queueing_disaster_recovery_disable_fair_scheduling: false)
stub_feature_flags(ci_queueing_disaster_recovery_disable_quota: false)
2021-06-08 01:23:25 +05:30
2022-08-13 15:12:31 +05:30
# It's disabled in specs because we don't support certain features which
# cause spec failures.
stub_feature_flags(use_click_house_database_for_error_tracking: false)
2023-03-04 22:38:38 +05:30
# Disable this to avoid the Web IDE modals popping up in tests:
# https://gitlab.com/gitlab-org/gitlab/-/issues/385453
stub_feature_flags(vscode_web_ide: false)
2020-06-23 00:09:42 +05:30
enable_rugged = example.metadata[:enable_rugged].present?
# Disable Rugged features by default
Gitlab::Git::RuggedImpl::Repository::FEATURE_FLAGS.each do |flag|
stub_feature_flags(flag => enable_rugged)
end
2021-06-08 01:23:25 +05:30
# Disable `main_branch_over_master` as we migrate
# from `master` to `main` accross our codebase.
# It's done in order to preserve the concistency in tests
# As we're ready to change `master` usages to `main`, let's enable it
stub_feature_flags(main_branch_over_master: false)
# Disable issue respositioning to avoid heavy load on database when importing big projects.
# This is only turned on when app is handling heavy project imports.
# Can be removed when we find a better way to deal with the problem.
# For more information check https://gitlab.com/gitlab-com/gl-infra/production/-/issues/4321
stub_feature_flags(block_issue_repositioning: false)
2021-11-11 11:23:49 +05:30
# These are ops feature flags that are disabled by default
stub_feature_flags(disable_anonymous_project_search: false)
2022-06-21 17:19:12 +05:30
# Specs should not get a CAPTCHA challenge by default, this makes the sign-in flow simpler in
# most cases. We do test the CAPTCHA flow in the appropriate specs.
stub_feature_flags(arkose_labs_login_challenge: false)
2021-11-11 11:23:49 +05:30
2022-08-13 15:12:31 +05:30
# Specs should not require email verification by default, this makes the sign-in flow simpler in
# most cases. We do test the email verification flow in the appropriate specs.
stub_feature_flags(require_email_verification: false)
# This feature flag is for selectively disabling by actor, therefore we don't enable it by default.
# See https://docs.gitlab.com/ee/development/feature_flags/#selectively-disable-by-actor
stub_feature_flags(legacy_merge_request_state_check_for_merged_result_pipelines: false)
2023-01-13 00:05:48 +05:30
# Disable the `vue_issues_dashboard` feature flag in specs as we migrate the issues
# dashboard page to Vue. https://gitlab.com/gitlab-org/gitlab/-/issues/379025
stub_feature_flags(vue_issues_dashboard: false)
2020-06-23 00:09:42 +05:30
allow(Gitlab::GitalyClient).to receive(:can_use_disk?).and_return(enable_rugged)
2020-10-24 23:57:45 +05:30
else
unstub_all_feature_flags
2019-05-03 19:53:19 +05:30
end
2019-12-04 20:38:33 +05:30
# Stub these calls due to being expensive operations
# It can be reenabled for specific tests via:
#
2020-03-13 15:44:24 +05:30
# expect(Gitlab::Git::KeepAround).to receive(:execute).and_call_original
2019-12-04 20:38:33 +05:30
allow(Gitlab::Git::KeepAround).to receive(:execute)
2021-01-03 14:25:43 +05:30
# Stub these calls due to being expensive operations
# It can be reenabled for specific tests via:
#
# expect(Gitlab::JobWaiter).to receive(:wait).and_call_original
allow_any_instance_of(Gitlab::JobWaiter).to receive(:wait)
2020-05-24 23:13:21 +05:30
Gitlab::ProcessMemoryCache.cache_backend.clear
2020-04-08 14:13:33 +05:30
2020-03-13 15:44:24 +05:30
Sidekiq::Worker.clear_all
2019-12-21 20:55:43 +05:30
2020-04-22 19:07:51 +05:30
# Administrators have to re-authenticate in order to access administrative
2021-04-29 21:17:54 +05:30
# functionality when application setting admin_mode is active. Any spec
2020-04-22 19:07:51 +05:30
# that requires administrative access can use the tag :enable_admin_mode
# to avoid the second auth step (provided the user is already an admin):
#
# context 'some test that requires admin mode', :enable_admin_mode do ... end
#
2021-03-08 18:12:59 +05:30
# Some specs do get admin mode enabled automatically (e.g. `spec/controllers/admin`).
# In this case, specs that need to test both admin mode states can use the
# :do_not_mock_admin_mode tag to disable auto admin mode.
#
2020-04-22 19:07:51 +05:30
# See also spec/support/helpers/admin_mode_helpers.rb
if example.metadata[:enable_admin_mode] && !example.metadata[:do_not_mock_admin_mode]
2019-12-21 20:55:43 +05:30
allow_any_instance_of(Gitlab::Auth::CurrentUserMode).to receive(:admin_mode?) do |current_user_mode|
current_user_mode.send(:user)&.admin?
end
end
2021-03-11 19:13:27 +05:30
2023-04-23 21:23:45 +05:30
# See https://gitlab.com/gitlab-org/gitlab/-/issues/42692
# The ongoing implementation of Admin Mode for API is behind the :admin_mode_for_api feature flag.
# All API specs will be adapted continuously. The following list contains the specs that have not yet been adapted.
# The feature flag is disabled for these specs as long as they are not yet adapted.
2023-06-20 00:43:36 +05:30
admin_mode_for_api_feature_flag_paths = %w[]
2023-04-23 21:23:45 +05:30
if example.metadata[:file_path].start_with?(*admin_mode_for_api_feature_flag_paths)
stub_feature_flags(admin_mode_for_api: false)
end
2021-04-29 21:17:54 +05:30
# Make sure specs test by default admin mode setting on, unless forced to the opposite
stub_application_setting(admin_mode: true) unless example.metadata[:do_not_mock_admin_mode_setting]
2021-03-11 19:13:27 +05:30
allow(Gitlab::CurrentSettings).to receive(:current_application_settings?).and_return(false)
2022-08-13 15:12:31 +05:30
# Ensure that Snowplow is enabled by default unless forced to the opposite
stub_snowplow unless example.metadata[:do_not_stub_snowplow_by_default]
2017-09-10 17:25:29 +05:30
end
2019-10-12 21:52:04 +05:30
config.around(:example, :quarantine) do |example|
2019-03-02 22:35:43 +05:30
# Skip tests in quarantine unless we explicitly focus on them.
2019-10-12 21:52:04 +05:30
example.run if config.inclusion_filter[:quarantine]
2019-03-02 22:35:43 +05:30
end
2020-03-13 15:44:24 +05:30
config.around(:example, :request_store) do |example|
2020-05-24 23:13:21 +05:30
Gitlab::WithRequestStore.with_request_store { example.run }
2017-09-10 17:25:29 +05:30
end
2022-08-27 11:52:29 +05:30
config.around(:example, :enable_rugged) do |example|
# Skip tests that need rugged when using praefect DB.
example.run unless GitalySetup.praefect_with_db?
end
2022-10-11 01:57:18 +05:30
config.around(:example, :yaml_processor_feature_flag_corectness) do |example|
::Gitlab::Ci::YamlProcessor::FeatureFlags.ensure_correct_usage do
example.run
end
end
2021-09-04 01:27:46 +05:30
# previous test runs may have left some resources throttled
config.before do
::Gitlab::ExclusiveLease.reset_all!("el:throttle:*")
end
config.before(:example, :assume_throttled) do |example|
allow(::Gitlab::ExclusiveLease).to receive(:throttle).and_return(nil)
end
2021-02-22 17:27:13 +05:30
config.before(:example, :request_store) do
# Clear request store before actually starting the spec (the
# `around` above will have the request store enabled for all
# `before` blocks)
RequestStore.clear!
end
2020-03-13 15:44:24 +05:30
config.around do |example|
# Wrap each example in it's own context to make sure the contexts don't
# leak
2021-04-29 21:17:54 +05:30
Gitlab::ApplicationContext.with_raw_context { example.run }
2018-11-08 19:23:39 +05:30
end
2020-04-22 19:07:51 +05:30
config.around do |example|
with_sidekiq_server_middleware do |chain|
Gitlab::SidekiqMiddleware.server_configurator(
metrics: false, # The metrics don't go anywhere in tests
2022-11-25 23:54:43 +05:30
arguments_logger: false # We're not logging the regular messages for inline jobs
2020-04-22 19:07:51 +05:30
).call(chain)
chain.add DisableQueryLimit
2020-05-24 23:13:21 +05:30
chain.insert_after ::Gitlab::SidekiqMiddleware::RequestStoreMiddleware, IsolatedRequestStore
2020-04-22 19:07:51 +05:30
example.run
end
end
2019-02-15 15:39:39 +05:30
config.after do
2020-03-13 15:44:24 +05:30
Fog.unmock! if Fog.mock?
2018-11-20 20:47:30 +05:30
Gitlab::CurrentSettings.clear_in_memory_application_settings!
2020-10-24 23:57:45 +05:30
# Reset all feature flag stubs to default for testing
stub_all_feature_flags
2021-04-29 21:17:54 +05:30
# Re-enable query limiting in case it was disabled
Gitlab::QueryLimiting.enable!
2018-11-20 20:47:30 +05:30
end
2017-09-10 17:25:29 +05:30
config.before(:example, :mailer) do
reset_delivered_emails!
end
2018-11-08 19:23:39 +05:30
config.before(:example, :prometheus) do
2021-01-29 00:20:46 +05:30
matching_files = File.join(::Prometheus::Client.configuration.multiprocess_files_dir, "**/*.db")
2018-11-08 19:23:39 +05:30
Dir[matching_files].map { |filename| File.delete(filename) if File.file?(filename) }
Gitlab::Metrics.reset_registry!
end
2021-12-11 22:18:48 +05:30
config.before(:example, :eager_load) do
Rails.application.eager_load!
end
2018-03-27 19:54:05 +05:30
# This makes sure the `ApplicationController#can?` method is stubbed with the
# original implementation for all view specs.
config.before(:each, type: :view) do
allow(view).to receive(:can?) do |*args|
Ability.allowed?(*args)
end
end
2020-07-28 23:09:34 +05:30
2022-03-02 08:16:31 +05:30
# Ensures that any Javascript script that tries to make the external VersionCheck API call skips it and returns a response
config.before(:each, :js) do
allow_any_instance_of(VersionCheck).to receive(:response).and_return({ "severity" => "success" })
end
2014-09-02 18:07:02 +05:30
end
2015-04-26 12:48:37 +05:30
2023-05-27 22:25:52 +05:30
# Disabled because it's causing N+1 queries.
# See https://gitlab.com/gitlab-org/gitlab/-/issues/396352.
# Support::AbilityCheck.inject(Ability.singleton_class)
Support::PermissionsCheck.inject(Ability.singleton_class)
2015-04-26 12:48:37 +05:30
ActiveRecord::Migration.maintain_test_schema!
2017-09-10 17:25:29 +05:30
Shoulda::Matchers.configure do |config|
config.integrate do |with|
with.test_framework :rspec
with.library :rails
end
end
2018-03-17 18:26:18 +05:30
# Prevent Rugged from picking up local developer gitconfig.
Rugged::Settings['search_path_global'] = Rails.root.join('tmp/tests').to_s
2019-12-21 20:55:43 +05:30
2020-11-24 15:15:51 +05:30
# Initialize FactoryDefault to use create_default helper
TestProf::FactoryDefault.init
2021-12-07 22:27:20 +05:30
2022-01-26 12:08:38 +05:30
# Exclude the Geo proxy API request from getting on_next_request Warden handlers,
# necessary to prevent race conditions with feature tests not getting authenticated.
::Warden.asset_paths << %r{^/api/v4/geo/proxy$}
2021-12-07 22:27:20 +05:30
module TouchRackUploadedFile
def initialize_from_file_path(path)
super
# This is a no-op workaround for https://github.com/docker/for-linux/issues/1015
File.utime @tempfile.atime, @tempfile.mtime, @tempfile.path # rubocop:disable Gitlab/ModuleWithInstanceVariables
end
end
Rack::Test::UploadedFile.prepend(TouchRackUploadedFile)
2022-08-27 11:52:29 +05:30
# Monkey-patch to enable ActiveSupport::Notifications for Redis commands
module RedisCommands
module Instrumentation
def process(commands, &block)
ActiveSupport::Notifications.instrument('redis.process_commands', commands: commands) do
super(commands, &block)
end
end
end
end
Redis::Client.prepend(RedisCommands::Instrumentation)