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:
authorGitLab Bot <gitlab-bot@gitlab.com>2023-12-19 14:01:45 +0300
committerGitLab Bot <gitlab-bot@gitlab.com>2023-12-19 14:01:45 +0300
commit9297025d0b7ddf095eb618dfaaab2ff8f2018d8b (patch)
tree865198c01d1824a9b098127baa3ab980c9cd2c06 /spec/lib/gitlab/background_migration/backfill_vs_code_settings_uuid_spec.rb
parent6372471f43ee03c05a7c1f8b0c6ac6b8a7431dbe (diff)
Add latest changes from gitlab-org/gitlab@16-7-stable-eev16.7.0-rc42
Diffstat (limited to 'spec/lib/gitlab/background_migration/backfill_vs_code_settings_uuid_spec.rb')
-rw-r--r--spec/lib/gitlab/background_migration/backfill_vs_code_settings_uuid_spec.rb74
1 files changed, 74 insertions, 0 deletions
diff --git a/spec/lib/gitlab/background_migration/backfill_vs_code_settings_uuid_spec.rb b/spec/lib/gitlab/background_migration/backfill_vs_code_settings_uuid_spec.rb
new file mode 100644
index 00000000000..bf1fce4094e
--- /dev/null
+++ b/spec/lib/gitlab/background_migration/backfill_vs_code_settings_uuid_spec.rb
@@ -0,0 +1,74 @@
+# frozen_string_literal: true
+
+require 'spec_helper'
+
+RSpec.describe Gitlab::BackgroundMigration::BackfillVsCodeSettingsUuid, schema: 20231130140901, feature_category: :web_ide do
+ let!(:vs_code_settings) { table(:vs_code_settings) }
+ let!(:users) { table(:users) }
+
+ let!(:user) do
+ users.create!(
+ email: "test1@example.com",
+ username: "test1",
+ notification_email: "test@example.com",
+ name: "test",
+ state: "active",
+ projects_limit: 10)
+ end
+
+ subject(:migration) do
+ described_class.new(
+ start_id: vs_code_setting_one.id,
+ end_id: vs_code_setting_two.id,
+ batch_table: :vs_code_settings,
+ batch_column: :id,
+ sub_batch_size: 100,
+ pause_ms: 0,
+ connection: ActiveRecord::Base.connection
+ )
+ end
+
+ describe "#perform" do
+ context 'when it finds vs_code_setting rows with empty uuid' do
+ let(:vs_code_setting_one) do
+ vs_code_settings.create!(user_id: user.id, setting_type: 'profiles', content: '{}')
+ end
+
+ let(:vs_code_setting_two) do
+ vs_code_settings.create!(user_id: user.id, setting_type: 'tasks', content: '{}')
+ end
+
+ it 'populates uuid column with a generated uuid' do
+ expect(vs_code_setting_one.uuid).to be_nil
+ expect(vs_code_setting_two.uuid).to be_nil
+
+ migration.perform
+
+ expect(vs_code_setting_one.reload.uuid).not_to be_nil
+ expect(vs_code_setting_two.reload.uuid).not_to be_nil
+ end
+ end
+
+ context 'when it finds vs_code_setting rows with non-empty uuid' do
+ let(:vs_code_setting_one) do
+ vs_code_settings.create!(user_id: user.id, setting_type: 'profiles', content: '{}', uuid: SecureRandom.uuid)
+ end
+
+ let(:vs_code_setting_two) do
+ vs_code_settings.create!(user_id: user.id, setting_type: 'tasks', content: '{}')
+ end
+
+ it 'populates uuid column with a generated uuid' do
+ expect(vs_code_setting_one.uuid).not_to be_nil
+ expect(vs_code_setting_two.uuid).to be_nil
+
+ previous_uuid = vs_code_setting_one.uuid
+
+ migration.perform
+
+ expect(vs_code_setting_one.reload.uuid).to eq(previous_uuid)
+ expect(vs_code_setting_two.reload.uuid).not_to be_nil
+ end
+ end
+ end
+end