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/lib/gitlab/background_migration/disable_legacy_open_source_license_for_no_issues_no_repo_projects_spec.rb')
-rw-r--r--spec/lib/gitlab/background_migration/disable_legacy_open_source_license_for_no_issues_no_repo_projects_spec.rb63
1 files changed, 0 insertions, 63 deletions
diff --git a/spec/lib/gitlab/background_migration/disable_legacy_open_source_license_for_no_issues_no_repo_projects_spec.rb b/spec/lib/gitlab/background_migration/disable_legacy_open_source_license_for_no_issues_no_repo_projects_spec.rb
deleted file mode 100644
index 8afbd7403d3..00000000000
--- a/spec/lib/gitlab/background_migration/disable_legacy_open_source_license_for_no_issues_no_repo_projects_spec.rb
+++ /dev/null
@@ -1,63 +0,0 @@
-# frozen_string_literal: true
-
-require 'spec_helper'
-
-RSpec.describe Gitlab::BackgroundMigration::DisableLegacyOpenSourceLicenseForNoIssuesNoRepoProjects,
- :migration,
- schema: 20221111123146 do
- let(:namespaces_table) { table(:namespaces) }
- let(:projects_table) { table(:projects) }
- let(:project_settings_table) { table(:project_settings) }
- let(:project_statistics_table) { table(:project_statistics) }
- let(:issues_table) { table(:issues) }
-
- subject(:perform_migration) do
- described_class.new(
- start_id: projects_table.minimum(:id),
- end_id: projects_table.maximum(:id),
- batch_table: :projects,
- batch_column: :id,
- sub_batch_size: 2,
- pause_ms: 0,
- connection: ActiveRecord::Base.connection
- ).perform
- end
-
- it 'sets `legacy_open_source_license_available` to false only for public projects with no issues and no repo',
- :aggregate_failures do
- project_with_no_issues_no_repo = create_legacy_license_public_project('project-with-no-issues-no-repo')
- project_with_repo = create_legacy_license_public_project('project-with-repo', repo_size: 1)
- project_with_issues = create_legacy_license_public_project('project-with-issues', with_issue: true)
- project_with_issues_and_repo =
- create_legacy_license_public_project('project-with-issues-and-repo', repo_size: 1, with_issue: true)
-
- queries = ActiveRecord::QueryRecorder.new { perform_migration }
-
- expect(queries.count).to eq(7)
- expect(migrated_attribute(project_with_no_issues_no_repo)).to be_falsey
- expect(migrated_attribute(project_with_repo)).to be_truthy
- expect(migrated_attribute(project_with_issues)).to be_truthy
- expect(migrated_attribute(project_with_issues_and_repo)).to be_truthy
- end
-
- def create_legacy_license_public_project(path, repo_size: 0, with_issue: false)
- namespace = namespaces_table.create!(name: "namespace-#{path}", path: "namespace-#{path}")
- project_namespace = namespaces_table.create!(
- name: "-project-namespace-#{path}", path: "project-namespace-#{path}", type: 'Project'
- )
- project = projects_table.create!(
- name: path, path: path, namespace_id: namespace.id,
- project_namespace_id: project_namespace.id, visibility_level: 20
- )
-
- project_statistics_table.create!(project_id: project.id, namespace_id: namespace.id, repository_size: repo_size)
- issues_table.create!(project_id: project.id, namespace_id: project.project_namespace_id) if with_issue
- project_settings_table.create!(project_id: project.id, legacy_open_source_license_available: true)
-
- project
- end
-
- def migrated_attribute(project)
- project_settings_table.find(project.id).legacy_open_source_license_available
- end
-end