Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'spec/models/factories_spec.rb')
-rw-r--r--spec/models/factories_spec.rb211
1 files changed, 0 insertions, 211 deletions
diff --git a/spec/models/factories_spec.rb b/spec/models/factories_spec.rb
deleted file mode 100644
index d6e746986d6..00000000000
--- a/spec/models/factories_spec.rb
+++ /dev/null
@@ -1,211 +0,0 @@
-# frozen_string_literal: true
-
-require 'spec_helper'
-
-# `:saas` is used to test `gitlab_subscription` factory.
-# It's not available on FOSS but also this very factory is not.
-RSpec.describe 'factories', :saas, :with_license, feature_category: :tooling do
- include Database::DatabaseHelpers
-
- # Used in `skipped` and indicates whether to skip any traits including the
- # plain factory.
- any = Object.new
-
- # https://gitlab.com/groups/gitlab-org/-/epics/5464 tracks the remaining
- # skipped factories or traits.
- #
- # Consider adding a code comment if a trait cannot produce a valid object.
- skipped = [
- [:audit_event, :unauthenticated],
- [:ci_build_trace_chunk, :fog_with_data],
- [:ci_job_artifact, :remote_store],
- [:ci_job_artifact, :raw],
- [:ci_job_artifact, :gzip],
- [:ci_job_artifact, :correct_checksum],
- [:dependency_proxy_blob, :remote_store],
- [:environment, :non_playable],
- [:composer_cache_file, :object_storage],
- [:debian_project_component_file, :object_storage],
- [:debian_project_distribution, :object_storage],
- [:debian_file_metadatum, :unknown],
- [:issue_customer_relations_contact, :for_contact],
- [:issue_customer_relations_contact, :for_issue],
- [:package_file, :object_storage],
- [:rpm_repository_file, :object_storage],
- [:pages_domain, :without_certificate],
- [:pages_domain, :without_key],
- [:pages_domain, :with_missing_chain],
- [:pages_domain, :with_trusted_chain],
- [:pages_domain, :with_trusted_expired_chain],
- [:pages_domain, :explicit_ecdsa],
- [:project_member, :blocked],
- [:remote_mirror, :ssh],
- [:user_preference, :only_comments],
- [:ci_pipeline_artifact, :remote_store],
- # EE
- [:dast_profile, :with_dast_site_validation],
- [:dependency_proxy_manifest, :remote_store],
- [:geo_dependency_proxy_manifest_state, any],
- [:ee_ci_build, :dependency_scanning_report],
- [:ee_ci_build, :license_scan_v1],
- [:ee_ci_job_artifact, :v1],
- [:ee_ci_job_artifact, :v1_1],
- [:ee_ci_job_artifact, :v2],
- [:ee_ci_job_artifact, :v2_1],
- [:geo_ci_secure_file_state, any],
- [:geo_dependency_proxy_blob_state, any],
- [:geo_event_log, :geo_event],
- [:geo_job_artifact_state, any],
- [:geo_lfs_object_state, any],
- [:geo_pages_deployment_state, any],
- [:geo_upload_state, any],
- [:geo_ci_secure_file_state, any],
- [:lfs_object, :checksum_failure],
- [:lfs_object, :checksummed],
- [:merge_request, :blocked],
- [:merge_request_diff, :verification_failed],
- [:merge_request_diff, :verification_succeeded],
- [:package_file, :verification_failed],
- [:package_file, :verification_succeeded],
- [:project, :with_vulnerabilities],
- [:scan_execution_policy, :with_schedule_and_agent],
- [:vulnerability, :with_cluster_image_scanning_finding],
- [:vulnerability, :with_findings],
- [:vulnerability_export, :finished]
- ].freeze
-
- shared_examples 'factory' do |factory|
- skip_any = skipped.include?([factory.name, any])
-
- describe "#{factory.name} factory" do
- it 'does not raise error when built' do
- # We use `skip` here because using `build` mostly work even if
- # factories break when creating them.
- skip 'Factory skipped linting due to legacy error' if skip_any
-
- expect { build(factory.name) }.not_to raise_error
- end
-
- it 'does not raise error when created' do
- pending 'Factory skipped linting due to legacy error' if skip_any
-
- expect { create(factory.name) }.not_to raise_error # rubocop:disable Rails/SaveBang
- end
-
- factory.definition.defined_traits.map(&:name).each do |trait_name|
- skip_trait = skip_any || skipped.include?([factory.name, trait_name.to_sym])
-
- describe "linting :#{trait_name} trait" do
- it 'does not raise error when created' do
- pending 'Trait skipped linting due to legacy error' if skip_trait
-
- expect { create(factory.name, trait_name) }.not_to raise_error
- end
- end
- end
- end
- end
-
- # FactoryDefault speed up specs by creating associations only once
- # and reuse them in other factories.
- #
- # However, for some factories we cannot use FactoryDefault because the
- # associations must be unique and cannot be reused, or the factory default
- # is being mutated.
- skip_factory_defaults = %i[
- ci_job_token_project_scope_link
- ci_subscriptions_project
- evidence
- exported_protected_branch
- fork_network_member
- group_member
- import_state
- issue_customer_relations_contact
- member_task
- merge_request_block
- milestone_release
- namespace
- project_namespace
- project_repository
- project_security_setting
- prometheus_alert
- prometheus_alert_event
- prometheus_metric
- protected_branch
- protected_branch_merge_access_level
- protected_branch_push_access_level
- protected_branch_unprotect_access_level
- protected_tag
- protected_tag_create_access_level
- release
- release_link
- self_managed_prometheus_alert_event
- shard
- users_star_project
- vulnerabilities_finding_identifier
- wiki_page
- wiki_page_meta
- ].to_set.freeze
-
- # Some factories and their corresponding models are based on
- # database views. In order to use those, we have to swap the
- # view out with a table of the same structure.
- factories_based_on_view = %i[
- postgres_index
- postgres_index_bloat_estimate
- postgres_autovacuum_activity
- ].to_set.freeze
-
- without_fd, with_fd = FactoryBot.factories
- .partition { |factory| skip_factory_defaults.include?(factory.name) }
-
- # Some EE models check licensed features so stub them.
- shared_context 'with licensed features' do
- licensed_features = %i[
- board_milestone_lists
- board_assignee_lists
- ].index_with(true)
-
- if Gitlab.jh?
- licensed_features.merge! %i[
- dingtalk_integration
- feishu_bot_integration
- ].index_with(true)
- end
-
- before do
- stub_licensed_features(licensed_features)
- end
- end
-
- include_context 'with licensed features' if Gitlab.ee?
-
- context 'with factory defaults', factory_default: :keep do
- let_it_be(:namespace) { create_default(:namespace).freeze }
- let_it_be(:project) { create_default(:project, :repository).freeze }
- let_it_be(:user) { create_default(:user).freeze }
-
- before do
- factories_based_on_view.each do |factory|
- view = build(factory).class.table_name
- view_gitlab_schema = Gitlab::Database::GitlabSchema.table_schema(view)
- Gitlab::Database.database_base_models.each_value.select do |base_model|
- connection = base_model.connection
- next unless Gitlab::Database.gitlab_schemas_for_connection(connection).include?(view_gitlab_schema)
-
- swapout_view_for_table(view, connection: connection)
- end
- end
- end
-
- with_fd.each do |factory|
- it_behaves_like 'factory', factory
- end
- end
-
- context 'without factory defaults' do
- without_fd.each do |factory|
- it_behaves_like 'factory', factory
- end
- end
-end