diff options
Diffstat (limited to 'db/migrate')
44 files changed, 877 insertions, 13 deletions
| diff --git a/db/migrate/20160419122101_add_only_allow_merge_if_build_succeeds_to_projects.rb b/db/migrate/20160419122101_add_only_allow_merge_if_build_succeeds_to_projects.rb index 22bac46e25c..1716b6e8153 100644 --- a/db/migrate/20160419122101_add_only_allow_merge_if_build_succeeds_to_projects.rb +++ b/db/migrate/20160419122101_add_only_allow_merge_if_build_succeeds_to_projects.rb @@ -1,4 +1,4 @@ -# rubocop:disable Migration/AddColumnWithDefaultToLargeTable +# rubocop:disable Migration/UpdateLargeTable  class AddOnlyAllowMergeIfBuildSucceedsToProjects < ActiveRecord::Migration    include Gitlab::Database::MigrationHelpers    disable_ddl_transaction! diff --git a/db/migrate/20160608195742_add_repository_storage_to_projects.rb b/db/migrate/20160608195742_add_repository_storage_to_projects.rb index 0f3664c13ef..e4febd1614d 100644 --- a/db/migrate/20160608195742_add_repository_storage_to_projects.rb +++ b/db/migrate/20160608195742_add_repository_storage_to_projects.rb @@ -1,4 +1,4 @@ -# rubocop:disable Migration/AddColumnWithDefaultToLargeTable +# rubocop:disable Migration/UpdateLargeTable  class AddRepositoryStorageToProjects < ActiveRecord::Migration    include Gitlab::Database::MigrationHelpers    disable_ddl_transaction! diff --git a/db/migrate/20160615191922_set_missing_stage_on_ci_builds.rb b/db/migrate/20160615191922_set_missing_stage_on_ci_builds.rb index 5336b036bca..c58cb957df4 100644 --- a/db/migrate/20160615191922_set_missing_stage_on_ci_builds.rb +++ b/db/migrate/20160615191922_set_missing_stage_on_ci_builds.rb @@ -1,3 +1,4 @@ +# rubocop:disable Migration/UpdateLargeTable  # rubocop:disable Migration/UpdateColumnInBatches  class SetMissingStageOnCiBuilds < ActiveRecord::Migration    include Gitlab::Database::MigrationHelpers diff --git a/db/migrate/20160715154212_add_request_access_enabled_to_projects.rb b/db/migrate/20160715154212_add_request_access_enabled_to_projects.rb index 5dc26f8982a..22c925799a3 100644 --- a/db/migrate/20160715154212_add_request_access_enabled_to_projects.rb +++ b/db/migrate/20160715154212_add_request_access_enabled_to_projects.rb @@ -1,4 +1,4 @@ -# rubocop:disable Migration/AddColumnWithDefaultToLargeTable +# rubocop:disable Migration/UpdateLargeTable  class AddRequestAccessEnabledToProjects < ActiveRecord::Migration    include Gitlab::Database::MigrationHelpers    disable_ddl_transaction! diff --git a/db/migrate/20160715204316_add_request_access_enabled_to_groups.rb b/db/migrate/20160715204316_add_request_access_enabled_to_groups.rb index 4a317646788..4fcb29e1325 100644 --- a/db/migrate/20160715204316_add_request_access_enabled_to_groups.rb +++ b/db/migrate/20160715204316_add_request_access_enabled_to_groups.rb @@ -1,4 +1,4 @@ -# rubocop:disable Migration/AddColumnWithDefaultToLargeTable +# rubocop:disable Migration/UpdateLargeTable  class AddRequestAccessEnabledToGroups < ActiveRecord::Migration    include Gitlab::Database::MigrationHelpers    disable_ddl_transaction! diff --git a/db/migrate/20160721081015_drop_and_readd_has_external_wiki_in_projects.rb b/db/migrate/20160721081015_drop_and_readd_has_external_wiki_in_projects.rb index abe8e701e23..58f7f2a2841 100644 --- a/db/migrate/20160721081015_drop_and_readd_has_external_wiki_in_projects.rb +++ b/db/migrate/20160721081015_drop_and_readd_has_external_wiki_in_projects.rb @@ -1,3 +1,4 @@ +# rubocop:disable Migration/UpdateLargeTable  # rubocop:disable Migration/UpdateColumnInBatches  class DropAndReaddHasExternalWikiInProjects < ActiveRecord::Migration    include Gitlab::Database::MigrationHelpers diff --git a/db/migrate/20160831223750_remove_features_enabled_from_projects.rb b/db/migrate/20160831223750_remove_features_enabled_from_projects.rb index 7414a28ac97..aec709aaf59 100644 --- a/db/migrate/20160831223750_remove_features_enabled_from_projects.rb +++ b/db/migrate/20160831223750_remove_features_enabled_from_projects.rb @@ -1,7 +1,7 @@  # See http://doc.gitlab.com/ce/development/migration_style_guide.html  # for more information on how to write migrations for GitLab. -# rubocop:disable Migration/AddColumnWithDefaultToLargeTable +# rubocop:disable Migration/UpdateLargeTable  class RemoveFeaturesEnabledFromProjects < ActiveRecord::Migration    include Gitlab::Database::MigrationHelpers    disable_ddl_transaction! diff --git a/db/migrate/20160913162434_remove_projects_pushes_since_gc.rb b/db/migrate/20160913162434_remove_projects_pushes_since_gc.rb index 0100e30a733..df7d922b816 100644 --- a/db/migrate/20160913162434_remove_projects_pushes_since_gc.rb +++ b/db/migrate/20160913162434_remove_projects_pushes_since_gc.rb @@ -1,7 +1,7 @@  # See http://doc.gitlab.com/ce/development/migration_style_guide.html  # for more information on how to write migrations for GitLab. -# rubocop:disable Migration/AddColumnWithDefaultToLargeTable +# rubocop:disable Migration/UpdateLargeTable  class RemoveProjectsPushesSinceGc < ActiveRecord::Migration    include Gitlab::Database::MigrationHelpers diff --git a/db/migrate/20170124193147_add_two_factor_columns_to_namespaces.rb b/db/migrate/20170124193147_add_two_factor_columns_to_namespaces.rb index ae37da275fd..27ebe0af33b 100644 --- a/db/migrate/20170124193147_add_two_factor_columns_to_namespaces.rb +++ b/db/migrate/20170124193147_add_two_factor_columns_to_namespaces.rb @@ -1,4 +1,4 @@ -# rubocop:disable Migration/AddColumnWithDefaultToLargeTable +# rubocop:disable Migration/UpdateLargeTable  class AddTwoFactorColumnsToNamespaces < ActiveRecord::Migration    include Gitlab::Database::MigrationHelpers diff --git a/db/migrate/20170124193205_add_two_factor_columns_to_users.rb b/db/migrate/20170124193205_add_two_factor_columns_to_users.rb index 8d4aefa4365..558a1837c79 100644 --- a/db/migrate/20170124193205_add_two_factor_columns_to_users.rb +++ b/db/migrate/20170124193205_add_two_factor_columns_to_users.rb @@ -1,4 +1,4 @@ -# rubocop:disable Migration/AddColumnWithDefaultToLargeTable +# rubocop:disable Migration/UpdateLargeTable  class AddTwoFactorColumnsToUsers < ActiveRecord::Migration    include Gitlab::Database::MigrationHelpers diff --git a/db/migrate/20170301125302_add_printing_merge_request_link_enabled_to_project.rb b/db/migrate/20170301125302_add_printing_merge_request_link_enabled_to_project.rb index 7ad01a04815..6d43f346d4f 100644 --- a/db/migrate/20170301125302_add_printing_merge_request_link_enabled_to_project.rb +++ b/db/migrate/20170301125302_add_printing_merge_request_link_enabled_to_project.rb @@ -1,7 +1,7 @@  # See http://doc.gitlab.com/ce/development/migration_style_guide.html  # for more information on how to write migrations for GitLab. -# rubocop:disable Migration/AddColumnWithDefaultToLargeTable +# rubocop:disable Migration/UpdateLargeTable  class AddPrintingMergeRequestLinkEnabledToProject < ActiveRecord::Migration    include Gitlab::Database::MigrationHelpers    disable_ddl_transaction! diff --git a/db/migrate/20170305180853_add_auto_cancel_pending_pipelines_to_project.rb b/db/migrate/20170305180853_add_auto_cancel_pending_pipelines_to_project.rb index f335e77fb5e..3c5cd95726a 100644 --- a/db/migrate/20170305180853_add_auto_cancel_pending_pipelines_to_project.rb +++ b/db/migrate/20170305180853_add_auto_cancel_pending_pipelines_to_project.rb @@ -1,4 +1,4 @@ -# rubocop:disable Migration/AddColumnWithDefaultToLargeTable +# rubocop:disable Migration/UpdateLargeTable  class AddAutoCancelPendingPipelinesToProject < ActiveRecord::Migration    include Gitlab::Database::MigrationHelpers diff --git a/db/migrate/20170315174634_revert_add_notified_of_own_activity_to_users.rb b/db/migrate/20170315174634_revert_add_notified_of_own_activity_to_users.rb index 6c9fe19ca34..807dfcb385d 100644 --- a/db/migrate/20170315174634_revert_add_notified_of_own_activity_to_users.rb +++ b/db/migrate/20170315174634_revert_add_notified_of_own_activity_to_users.rb @@ -1,4 +1,4 @@ -# rubocop:disable Migration/AddColumnWithDefaultToLargeTable +# rubocop:disable Migration/UpdateLargeTable  class RevertAddNotifiedOfOwnActivityToUsers < ActiveRecord::Migration    include Gitlab::Database::MigrationHelpers    disable_ddl_transaction! diff --git a/db/migrate/20170320173259_migrate_assignees.rb b/db/migrate/20170320173259_migrate_assignees.rb index 7b61e811317..255b5e9c4db 100644 --- a/db/migrate/20170320173259_migrate_assignees.rb +++ b/db/migrate/20170320173259_migrate_assignees.rb @@ -1,3 +1,4 @@ +# rubocop:disable Migration/UpdateLargeTable  # rubocop:disable Migration/UpdateColumnInBatches  class MigrateAssignees < ActiveRecord::Migration    include Gitlab::Database::MigrationHelpers diff --git a/db/migrate/20170918072948_create_job_artifacts.rb b/db/migrate/20170918072948_create_job_artifacts.rb new file mode 100644 index 00000000000..95f2c6c8ce8 --- /dev/null +++ b/db/migrate/20170918072948_create_job_artifacts.rb @@ -0,0 +1,23 @@ +class CreateJobArtifacts < ActiveRecord::Migration +  include Gitlab::Database::MigrationHelpers + +  DOWNTIME = false + +  def change +    create_table :ci_job_artifacts do |t| +      t.belongs_to :project, null: false, index: true, foreign_key: { on_delete: :cascade } +      t.integer :job_id, null: false +      t.integer :file_type, null: false +      t.integer :size, limit: 8 + +      t.datetime_with_timezone :created_at, null: false +      t.datetime_with_timezone :updated_at, null: false +      t.datetime_with_timezone :expire_at + +      t.string :file + +      t.foreign_key :ci_builds, column: :job_id, on_delete: :cascade +      t.index [:job_id, :file_type], unique: true +    end +  end +end diff --git a/db/migrate/20170919211300_remove_temporary_ci_builds_index.rb b/db/migrate/20170919211300_remove_temporary_ci_builds_index.rb index b2009b282e9..8423bf13fd9 100644 --- a/db/migrate/20170919211300_remove_temporary_ci_builds_index.rb +++ b/db/migrate/20170919211300_remove_temporary_ci_builds_index.rb @@ -12,6 +12,7 @@ class RemoveTemporaryCiBuildsIndex < ActiveRecord::Migration    def up      return unless index_exists?(:ci_builds, :id, name: 'index_for_ci_builds_retried_migration') +      remove_concurrent_index(:ci_builds, :id, name: "index_for_ci_builds_retried_migration")    end diff --git a/db/migrate/20171006220837_add_global_rate_limits_to_application_settings.rb b/db/migrate/20171006220837_add_global_rate_limits_to_application_settings.rb new file mode 100644 index 00000000000..55e822752af --- /dev/null +++ b/db/migrate/20171006220837_add_global_rate_limits_to_application_settings.rb @@ -0,0 +1,38 @@ +# See http://doc.gitlab.com/ce/development/migration_style_guide.html +# for more information on how to write migrations for GitLab. + +class AddGlobalRateLimitsToApplicationSettings < ActiveRecord::Migration +  include Gitlab::Database::MigrationHelpers + +  DOWNTIME = false + +  disable_ddl_transaction! + +  def up +    add_column_with_default :application_settings, :throttle_unauthenticated_enabled, :boolean, default: false, allow_null: false +    add_column_with_default :application_settings, :throttle_unauthenticated_requests_per_period, :integer, default: 3600, allow_null: false +    add_column_with_default :application_settings, :throttle_unauthenticated_period_in_seconds, :integer, default: 3600, allow_null: false + +    add_column_with_default :application_settings, :throttle_authenticated_api_enabled, :boolean, default: false, allow_null: false +    add_column_with_default :application_settings, :throttle_authenticated_api_requests_per_period, :integer, default: 7200, allow_null: false +    add_column_with_default :application_settings, :throttle_authenticated_api_period_in_seconds, :integer, default: 3600, allow_null: false + +    add_column_with_default :application_settings, :throttle_authenticated_web_enabled, :boolean, default: false, allow_null: false +    add_column_with_default :application_settings, :throttle_authenticated_web_requests_per_period, :integer, default: 7200, allow_null: false +    add_column_with_default :application_settings, :throttle_authenticated_web_period_in_seconds, :integer, default: 3600, allow_null: false +  end + +  def down +    remove_column :application_settings, :throttle_authenticated_web_period_in_seconds +    remove_column :application_settings, :throttle_authenticated_web_requests_per_period +    remove_column :application_settings, :throttle_authenticated_web_enabled + +    remove_column :application_settings, :throttle_authenticated_api_period_in_seconds +    remove_column :application_settings, :throttle_authenticated_api_requests_per_period +    remove_column :application_settings, :throttle_authenticated_api_enabled + +    remove_column :application_settings, :throttle_unauthenticated_period_in_seconds +    remove_column :application_settings, :throttle_unauthenticated_requests_per_period +    remove_column :application_settings, :throttle_unauthenticated_enabled +  end +end diff --git a/db/migrate/20171101130535_add_gitaly_timeout_properties_to_application_settings.rb b/db/migrate/20171101130535_add_gitaly_timeout_properties_to_application_settings.rb new file mode 100644 index 00000000000..de621e7111c --- /dev/null +++ b/db/migrate/20171101130535_add_gitaly_timeout_properties_to_application_settings.rb @@ -0,0 +1,31 @@ +# See http://doc.gitlab.com/ce/development/migration_style_guide.html +# for more information on how to write migrations for GitLab. + +class AddGitalyTimeoutPropertiesToApplicationSettings < ActiveRecord::Migration +  include Gitlab::Database::MigrationHelpers + +  DOWNTIME = false + +  disable_ddl_transaction! + +  def up +    add_column_with_default :application_settings, +                            :gitaly_timeout_default, +                            :integer, +                            default: 55 +    add_column_with_default :application_settings, +                            :gitaly_timeout_medium, +                            :integer, +                            default: 30 +    add_column_with_default :application_settings, +                            :gitaly_timeout_fast, +                            :integer, +                            default: 10 +  end + +  def down +    remove_column :application_settings, :gitaly_timeout_default +    remove_column :application_settings, :gitaly_timeout_medium +    remove_column :application_settings, :gitaly_timeout_fast +  end +end diff --git a/db/migrate/20171103000000_set_uploads_path_size_for_mysql.rb b/db/migrate/20171103000000_set_uploads_path_size_for_mysql.rb new file mode 100644 index 00000000000..1fbe505f804 --- /dev/null +++ b/db/migrate/20171103000000_set_uploads_path_size_for_mysql.rb @@ -0,0 +1,25 @@ +# See http://doc.gitlab.com/ce/development/migration_style_guide.html +# for more information on how to write migrations for GitLab. + +class SetUploadsPathSizeForMysql < ActiveRecord::Migration +  include Gitlab::Database::MigrationHelpers + +  # Set this constant to true if this migration requires downtime. +  DOWNTIME = false + +  def up +    # We need at least 297 at the moment. For more detail on that number, see: +    # https://gitlab.com/gitlab-org/gitlab-ce/issues/40168#what-is-the-expected-correct-behavior +    # +    # Rails + PostgreSQL `string` is equivalent to a `text` field, but +    # Rails + MySQL `string` is `varchar(255)` by default. Also, note that we +    # have an upper limit because with a unique index, MySQL has a max key +    # length of 3072 bytes which seems to correspond to `varchar(1024)`. +    change_column :uploads, :path, :string, limit: 511 +  end + +  def down +    # It was unspecified, which is varchar(255) by default in Rails for MySQL. +    change_column :uploads, :path, :string +  end +end diff --git a/db/migrate/20171106132212_issues_confidential_not_null.rb b/db/migrate/20171106132212_issues_confidential_not_null.rb new file mode 100644 index 00000000000..c959d2dd938 --- /dev/null +++ b/db/migrate/20171106132212_issues_confidential_not_null.rb @@ -0,0 +1,23 @@ +# See http://doc.gitlab.com/ce/development/migration_style_guide.html +# for more information on how to write migrations for GitLab. + +class IssuesConfidentialNotNull < ActiveRecord::Migration +  include Gitlab::Database::MigrationHelpers + +  # Set this constant to true if this migration requires downtime. +  DOWNTIME = false + +  class Issue < ActiveRecord::Base +    self.table_name = 'issues' +  end + +  def up +    Issue.where('confidential IS NULL').update_all(confidential: false) + +    change_column_null :issues, :confidential, false +  end + +  def down +    # There's no way / point to revert this. +  end +end diff --git a/db/migrate/20171106133143_rename_application_settings_password_authentication_enabled_to_password_authentication_enabled_for_web.rb b/db/migrate/20171106133143_rename_application_settings_password_authentication_enabled_to_password_authentication_enabled_for_web.rb new file mode 100644 index 00000000000..6d369e93361 --- /dev/null +++ b/db/migrate/20171106133143_rename_application_settings_password_authentication_enabled_to_password_authentication_enabled_for_web.rb @@ -0,0 +1,15 @@ +class RenameApplicationSettingsPasswordAuthenticationEnabledToPasswordAuthenticationEnabledForWeb < ActiveRecord::Migration +  include Gitlab::Database::MigrationHelpers + +  DOWNTIME = false + +  disable_ddl_transaction! + +  def up +    rename_column_concurrently :application_settings, :password_authentication_enabled, :password_authentication_enabled_for_web +  end + +  def down +    cleanup_concurrent_column_rename :application_settings, :password_authentication_enabled_for_web, :password_authentication_enabled +  end +end diff --git a/db/migrate/20171106133911_add_password_authentication_enabled_for_git_to_application_settings.rb b/db/migrate/20171106133911_add_password_authentication_enabled_for_git_to_application_settings.rb new file mode 100644 index 00000000000..b8aa600864e --- /dev/null +++ b/db/migrate/20171106133911_add_password_authentication_enabled_for_git_to_application_settings.rb @@ -0,0 +1,9 @@ +class AddPasswordAuthenticationEnabledForGitToApplicationSettings < ActiveRecord::Migration +  include Gitlab::Database::MigrationHelpers + +  DOWNTIME = false + +  def change +    add_column :application_settings, :password_authentication_enabled_for_git, :boolean, default: true, null: false +  end +end diff --git a/db/migrate/20171106135924_issues_milestone_id_foreign_key.rb b/db/migrate/20171106135924_issues_milestone_id_foreign_key.rb new file mode 100644 index 00000000000..e6a780d0964 --- /dev/null +++ b/db/migrate/20171106135924_issues_milestone_id_foreign_key.rb @@ -0,0 +1,38 @@ +# See http://doc.gitlab.com/ce/development/migration_style_guide.html +# for more information on how to write migrations for GitLab. + +class IssuesMilestoneIdForeignKey < ActiveRecord::Migration +  include Gitlab::Database::MigrationHelpers + +  # Set this constant to true if this migration requires downtime. +  DOWNTIME = false + +  disable_ddl_transaction! + +  class Issue < ActiveRecord::Base +    include EachBatch + +    self.table_name = 'issues' + +    def self.with_orphaned_milestones +      where('NOT EXISTS (SELECT true FROM milestones WHERE milestones.id = issues.milestone_id)') +    end +  end + +  def up +    Issue.with_orphaned_milestones.each_batch(of: 100) do |batch| +      batch.update_all(milestone_id: nil) +    end + +    add_concurrent_foreign_key( +      :issues, +      :milestones, +      column: :milestone_id, +      on_delete: :nullify +    ) +  end + +  def down +    remove_foreign_key_without_error(:issues, column: :milestone_id) +  end +end diff --git a/db/migrate/20171106150657_issues_updated_by_id_foreign_key.rb b/db/migrate/20171106150657_issues_updated_by_id_foreign_key.rb new file mode 100644 index 00000000000..3b8844d7d9f --- /dev/null +++ b/db/migrate/20171106150657_issues_updated_by_id_foreign_key.rb @@ -0,0 +1,45 @@ +# See http://doc.gitlab.com/ce/development/migration_style_guide.html +# for more information on how to write migrations for GitLab. + +class IssuesUpdatedByIdForeignKey < ActiveRecord::Migration +  include Gitlab::Database::MigrationHelpers + +  # Set this constant to true if this migration requires downtime. +  DOWNTIME = false + +  disable_ddl_transaction! + +  class Issue < ActiveRecord::Base +    include EachBatch + +    self.table_name = 'issues' + +    def self.with_orphaned_updaters +      where('NOT EXISTS (SELECT true FROM users WHERE users.id = issues.updated_by_id)') +        .where('updated_by_id IS NOT NULL') +    end +  end + +  def up +    Issue.with_orphaned_updaters.each_batch(of: 100) do |batch| +      batch.update_all(updated_by_id: nil) +    end + +    # This index is only used for foreign keys, and those in turn will always +    # specify a value. As such we can add a WHERE condition to make the index +    # smaller. +    add_concurrent_index(:issues, :updated_by_id, where: 'updated_by_id IS NOT NULL') + +    add_concurrent_foreign_key( +      :issues, +      :users, +      column: :updated_by_id, +      on_delete: :nullify +    ) +  end + +  def down +    remove_foreign_key_without_error(:issues, column: :updated_by_id) +    remove_concurrent_index(:issues, :updated_by_id) +  end +end diff --git a/db/migrate/20171106151218_issues_moved_to_id_foreign_key.rb b/db/migrate/20171106151218_issues_moved_to_id_foreign_key.rb new file mode 100644 index 00000000000..8d2ceb8cc18 --- /dev/null +++ b/db/migrate/20171106151218_issues_moved_to_id_foreign_key.rb @@ -0,0 +1,44 @@ +# See http://doc.gitlab.com/ce/development/migration_style_guide.html +# for more information on how to write migrations for GitLab. + +class IssuesMovedToIdForeignKey < ActiveRecord::Migration +  include Gitlab::Database::MigrationHelpers + +  # Set this constant to true if this migration requires downtime. +  DOWNTIME = false + +  disable_ddl_transaction! + +  class Issue < ActiveRecord::Base +    include EachBatch + +    self.table_name = 'issues' + +    def self.with_orphaned_moved_to_issues +      where('NOT EXISTS (SELECT true FROM issues WHERE issues.id = issues.moved_to_id)') +        .where('moved_to_id IS NOT NULL') +    end +  end + +  def up +    Issue.with_orphaned_moved_to_issues.each_batch(of: 100) do |batch| +      batch.update_all(moved_to_id: nil) +    end + +    add_concurrent_foreign_key( +      :issues, +      :issues, +      column: :moved_to_id, +      on_delete: :nullify +    ) + +    # We're using a partial index here so we only index the data we actually +    # care about. +    add_concurrent_index(:issues, :moved_to_id, where: 'moved_to_id IS NOT NULL') +  end + +  def down +    remove_foreign_key_without_error(:issues, column: :moved_to_id) +    remove_concurrent_index(:issues, :moved_to_id) +  end +end diff --git a/db/migrate/20171106154015_remove_issues_branch_name.rb b/db/migrate/20171106154015_remove_issues_branch_name.rb new file mode 100644 index 00000000000..3d08225c96d --- /dev/null +++ b/db/migrate/20171106154015_remove_issues_branch_name.rb @@ -0,0 +1,13 @@ +# See http://doc.gitlab.com/ce/development/migration_style_guide.html +# for more information on how to write migrations for GitLab. + +class RemoveIssuesBranchName < ActiveRecord::Migration +  include Gitlab::Database::MigrationHelpers + +  # Set this constant to true if this migration requires downtime. +  DOWNTIME = false + +  def change +    remove_column :issues, :branch_name, :string +  end +end diff --git a/db/migrate/20171106155656_turn_issues_due_date_index_to_partial_index.rb b/db/migrate/20171106155656_turn_issues_due_date_index_to_partial_index.rb new file mode 100644 index 00000000000..e4bed778695 --- /dev/null +++ b/db/migrate/20171106155656_turn_issues_due_date_index_to_partial_index.rb @@ -0,0 +1,37 @@ +# See http://doc.gitlab.com/ce/development/migration_style_guide.html +# for more information on how to write migrations for GitLab. + +class TurnIssuesDueDateIndexToPartialIndex < ActiveRecord::Migration +  include Gitlab::Database::MigrationHelpers + +  # Set this constant to true if this migration requires downtime. +  DOWNTIME = false + +  NEW_INDEX_NAME = 'idx_issues_on_project_id_and_due_date_and_id_and_state_partial' +  OLD_INDEX_NAME = 'index_issues_on_project_id_and_due_date_and_id_and_state' + +  disable_ddl_transaction! + +  def up +    add_concurrent_index( +      :issues, +      [:project_id, :due_date, :id, :state], +      where: 'due_date IS NOT NULL', +      name: NEW_INDEX_NAME +    ) + +    # We set the column name to nil as otherwise Rails will ignore the custom +    # index name and remove the wrong index. +    remove_concurrent_index(:issues, nil, name: OLD_INDEX_NAME) +  end + +  def down +    add_concurrent_index( +      :issues, +      [:project_id, :due_date, :id, :state], +      name: OLD_INDEX_NAME +    ) + +    remove_concurrent_index(:issues, nil, name: NEW_INDEX_NAME) +  end +end diff --git a/db/migrate/20171106171453_add_timezone_to_issues_closed_at.rb b/db/migrate/20171106171453_add_timezone_to_issues_closed_at.rb new file mode 100644 index 00000000000..ad540b1e509 --- /dev/null +++ b/db/migrate/20171106171453_add_timezone_to_issues_closed_at.rb @@ -0,0 +1,19 @@ +# See http://doc.gitlab.com/ce/development/migration_style_guide.html +# for more information on how to write migrations for GitLab. + +class AddTimezoneToIssuesClosedAt < ActiveRecord::Migration +  include Gitlab::Database::MigrationHelpers + +  # Set this constant to true if this migration requires downtime. +  DOWNTIME = false + +  disable_ddl_transaction! + +  def up +    change_column_type_concurrently(:issues, :closed_at, :datetime_with_timezone) +  end + +  def down +    cleanup_concurrent_column_type_change(:issues, :closed_at) +  end +end diff --git a/db/migrate/20171114150259_merge_requests_author_id_foreign_key.rb b/db/migrate/20171114150259_merge_requests_author_id_foreign_key.rb new file mode 100644 index 00000000000..021eaa04a0c --- /dev/null +++ b/db/migrate/20171114150259_merge_requests_author_id_foreign_key.rb @@ -0,0 +1,43 @@ +# See http://doc.gitlab.com/ce/development/migration_style_guide.html +# for more information on how to write migrations for GitLab. + +class MergeRequestsAuthorIdForeignKey < ActiveRecord::Migration +  include Gitlab::Database::MigrationHelpers + +  # Set this constant to true if this migration requires downtime. +  DOWNTIME = false + +  disable_ddl_transaction! + +  class MergeRequest < ActiveRecord::Base +    include EachBatch + +    self.table_name = 'merge_requests' + +    def self.with_orphaned_authors +      where('NOT EXISTS (SELECT true FROM users WHERE merge_requests.author_id = users.id)') +        .where('author_id IS NOT NULL') +    end +  end + +  def up +    # Replacing the ghost user ID logic would be too complex, hence we don't +    # redefine the User model here. +    ghost_id = User.select(:id).ghost.id + +    MergeRequest.with_orphaned_authors.each_batch(of: 100) do |batch| +      batch.update_all(author_id: ghost_id) +    end + +    add_concurrent_foreign_key( +      :merge_requests, +      :users, +      column: :author_id, +      on_delete: :nullify +    ) +  end + +  def down +    remove_foreign_key(:merge_requests, column: :author_id) +  end +end diff --git a/db/migrate/20171114160005_merge_requests_assignee_id_foreign_key.rb b/db/migrate/20171114160005_merge_requests_assignee_id_foreign_key.rb new file mode 100644 index 00000000000..1a242f01051 --- /dev/null +++ b/db/migrate/20171114160005_merge_requests_assignee_id_foreign_key.rb @@ -0,0 +1,39 @@ +# See http://doc.gitlab.com/ce/development/migration_style_guide.html +# for more information on how to write migrations for GitLab. + +class MergeRequestsAssigneeIdForeignKey < ActiveRecord::Migration +  include Gitlab::Database::MigrationHelpers + +  # Set this constant to true if this migration requires downtime. +  DOWNTIME = false + +  disable_ddl_transaction! + +  class MergeRequest < ActiveRecord::Base +    include EachBatch + +    self.table_name = 'merge_requests' + +    def self.with_orphaned_assignees +      where('NOT EXISTS (SELECT true FROM users WHERE merge_requests.assignee_id = users.id)') +        .where('assignee_id IS NOT NULL') +    end +  end + +  def up +    MergeRequest.with_orphaned_assignees.each_batch(of: 100) do |batch| +      batch.update_all(assignee_id: nil) +    end + +    add_concurrent_foreign_key( +      :merge_requests, +      :users, +      column: :assignee_id, +      on_delete: :nullify +    ) +  end + +  def down +    remove_foreign_key(:merge_requests, column: :assignee_id) +  end +end diff --git a/db/migrate/20171114160904_merge_requests_updated_by_id_foreign_key.rb b/db/migrate/20171114160904_merge_requests_updated_by_id_foreign_key.rb new file mode 100644 index 00000000000..eb3872e38da --- /dev/null +++ b/db/migrate/20171114160904_merge_requests_updated_by_id_foreign_key.rb @@ -0,0 +1,46 @@ +# See http://doc.gitlab.com/ce/development/migration_style_guide.html +# for more information on how to write migrations for GitLab. + +class MergeRequestsUpdatedByIdForeignKey < ActiveRecord::Migration +  include Gitlab::Database::MigrationHelpers + +  # Set this constant to true if this migration requires downtime. +  DOWNTIME = false + +  disable_ddl_transaction! + +  class MergeRequest < ActiveRecord::Base +    include EachBatch + +    self.table_name = 'merge_requests' + +    def self.with_orphaned_updaters +      where('NOT EXISTS (SELECT true FROM users WHERE merge_requests.updated_by_id = users.id)') +        .where('updated_by_id IS NOT NULL') +    end +  end + +  def up +    MergeRequest.with_orphaned_updaters.each_batch(of: 100) do |batch| +      batch.update_all(updated_by_id: nil) +    end + +    add_concurrent_index( +      :merge_requests, +      :updated_by_id, +      where: 'updated_by_id IS NOT NULL' +    ) + +    add_concurrent_foreign_key( +      :merge_requests, +      :users, +      column: :updated_by_id, +      on_delete: :nullify +    ) +  end + +  def down +    remove_foreign_key_without_error(:merge_requests, column: :updated_by_id) +    remove_concurrent_index(:merge_requests, :updated_by_id) +  end +end diff --git a/db/migrate/20171114161720_merge_requests_merge_user_id_foreign_key.rb b/db/migrate/20171114161720_merge_requests_merge_user_id_foreign_key.rb new file mode 100644 index 00000000000..925b3e537d7 --- /dev/null +++ b/db/migrate/20171114161720_merge_requests_merge_user_id_foreign_key.rb @@ -0,0 +1,46 @@ +# See http://doc.gitlab.com/ce/development/migration_style_guide.html +# for more information on how to write migrations for GitLab. + +class MergeRequestsMergeUserIdForeignKey < ActiveRecord::Migration +  include Gitlab::Database::MigrationHelpers + +  # Set this constant to true if this migration requires downtime. +  DOWNTIME = false + +  disable_ddl_transaction! + +  class MergeRequest < ActiveRecord::Base +    include EachBatch + +    self.table_name = 'merge_requests' + +    def self.with_orphaned_mergers +      where('NOT EXISTS (SELECT true FROM users WHERE merge_requests.merge_user_id = users.id)') +        .where('merge_user_id IS NOT NULL') +    end +  end + +  def up +    MergeRequest.with_orphaned_mergers.each_batch(of: 100) do |batch| +      batch.update_all(merge_user_id: nil) +    end + +    add_concurrent_index( +      :merge_requests, +      :merge_user_id, +      where: 'merge_user_id IS NOT NULL' +    ) + +    add_concurrent_foreign_key( +      :merge_requests, +      :users, +      column: :merge_user_id, +      on_delete: :nullify +    ) +  end + +  def down +    remove_foreign_key_without_error(:merge_requests, column: :merge_user_id) +    remove_concurrent_index(:merge_requests, :merge_user_id) +  end +end diff --git a/db/migrate/20171114161914_merge_requests_source_project_id_foreign_key.rb b/db/migrate/20171114161914_merge_requests_source_project_id_foreign_key.rb new file mode 100644 index 00000000000..99740f64fe6 --- /dev/null +++ b/db/migrate/20171114161914_merge_requests_source_project_id_foreign_key.rb @@ -0,0 +1,45 @@ +# See http://doc.gitlab.com/ce/development/migration_style_guide.html +# for more information on how to write migrations for GitLab. + +class MergeRequestsSourceProjectIdForeignKey < ActiveRecord::Migration +  include Gitlab::Database::MigrationHelpers + +  # Set this constant to true if this migration requires downtime. +  DOWNTIME = false + +  disable_ddl_transaction! + +  class MergeRequest < ActiveRecord::Base +    include EachBatch + +    self.table_name = 'merge_requests' + +    def self.with_orphaned_source_projects +      where('NOT EXISTS (SELECT true FROM projects WHERE merge_requests.source_project_id = projects.id)') +        .where('source_project_id IS NOT NULL') +    end +  end + +  def up +    # We need to allow NULL values so we can nullify the column when the source +    # project is removed. We _don't_ want to remove the merge request, instead +    # the application will keep them but close them. +    change_column_null(:merge_requests, :source_project_id, true) + +    MergeRequest.with_orphaned_source_projects.each_batch(of: 100) do |batch| +      batch.update_all(source_project_id: nil) +    end + +    add_concurrent_foreign_key( +      :merge_requests, +      :projects, +      column: :source_project_id, +      on_delete: :nullify +    ) +  end + +  def down +    remove_foreign_key_without_error(:merge_requests, column: :source_project_id) +    change_column_null(:merge_requests, :source_project_id, false) +  end +end diff --git a/db/migrate/20171114162227_merge_requests_milestone_id_foreign_key.rb b/db/migrate/20171114162227_merge_requests_milestone_id_foreign_key.rb new file mode 100644 index 00000000000..c005cf7d173 --- /dev/null +++ b/db/migrate/20171114162227_merge_requests_milestone_id_foreign_key.rb @@ -0,0 +1,39 @@ +# See http://doc.gitlab.com/ce/development/migration_style_guide.html +# for more information on how to write migrations for GitLab. + +class MergeRequestsMilestoneIdForeignKey < ActiveRecord::Migration +  include Gitlab::Database::MigrationHelpers + +  # Set this constant to true if this migration requires downtime. +  DOWNTIME = false + +  disable_ddl_transaction! + +  class MergeRequest < ActiveRecord::Base +    include EachBatch + +    self.table_name = 'merge_requests' + +    def self.with_orphaned_milestones +      where('NOT EXISTS (SELECT true FROM milestones WHERE merge_requests.milestone_id = milestones.id)') +        .where('milestone_id IS NOT NULL') +    end +  end + +  def up +    MergeRequest.with_orphaned_milestones.each_batch(of: 100) do |batch| +      batch.update_all(milestone_id: nil) +    end + +    add_concurrent_foreign_key( +      :merge_requests, +      :milestones, +      column: :milestone_id, +      on_delete: :nullify +    ) +  end + +  def down +    remove_foreign_key_without_error(:merge_requests, column: :milestone_id) +  end +end diff --git a/db/migrate/20171115164540_populate_merge_requests_latest_merge_request_diff_id_take_two.rb b/db/migrate/20171115164540_populate_merge_requests_latest_merge_request_diff_id_take_two.rb new file mode 100644 index 00000000000..27b6b4ebddc --- /dev/null +++ b/db/migrate/20171115164540_populate_merge_requests_latest_merge_request_diff_id_take_two.rb @@ -0,0 +1,30 @@ +# This is identical to the stolen background migration, which already has specs. +class PopulateMergeRequestsLatestMergeRequestDiffIdTakeTwo < ActiveRecord::Migration +  include Gitlab::Database::MigrationHelpers + +  DOWNTIME = false +  BATCH_SIZE = 1_000 + +  class MergeRequest < ActiveRecord::Base +    self.table_name = 'merge_requests' + +    include ::EachBatch +  end + +  disable_ddl_transaction! + +  def up +    Gitlab::BackgroundMigration.steal('PopulateMergeRequestsLatestMergeRequestDiffId') + +    update = ' +      latest_merge_request_diff_id = ( +        SELECT MAX(id) +        FROM merge_request_diffs +        WHERE merge_requests.id = merge_request_diffs.merge_request_id +      )'.squish + +    MergeRequest.where(latest_merge_request_diff_id: nil).each_batch(of: BATCH_SIZE) do |relation| +      relation.update_all(update) +    end +  end +end diff --git a/db/migrate/20171116135628_add_environment_scope_to_clusters.rb b/db/migrate/20171116135628_add_environment_scope_to_clusters.rb new file mode 100644 index 00000000000..cce757095dd --- /dev/null +++ b/db/migrate/20171116135628_add_environment_scope_to_clusters.rb @@ -0,0 +1,15 @@ +class AddEnvironmentScopeToClusters < ActiveRecord::Migration +  include Gitlab::Database::MigrationHelpers + +  DOWNTIME = false + +  disable_ddl_transaction! + +  def up +    add_column_with_default(:clusters, :environment_scope, :string, default: '*') +  end + +  def down +    remove_column(:clusters, :environment_scope) +  end +end diff --git a/db/migrate/20171121135738_clean_up_from_merge_request_diffs_and_commits.rb b/db/migrate/20171121135738_clean_up_from_merge_request_diffs_and_commits.rb new file mode 100644 index 00000000000..30cf08b29fc --- /dev/null +++ b/db/migrate/20171121135738_clean_up_from_merge_request_diffs_and_commits.rb @@ -0,0 +1,36 @@ +class CleanUpFromMergeRequestDiffsAndCommits < ActiveRecord::Migration +  include Gitlab::Database::MigrationHelpers + +  DOWNTIME = false + +  class MergeRequestDiff < ActiveRecord::Base +    self.table_name = 'merge_request_diffs' + +    include ::EachBatch +  end + +  disable_ddl_transaction! + +  def up +    Gitlab::BackgroundMigration.steal('DeserializeMergeRequestDiffsAndCommits') + +    # The literal '--- []\n' value is created by the import process and treated +    # as null by the application, so we can ignore those - even if we were +    # migrating, it wouldn't create any rows. +    literal_prefix = Gitlab::Database.postgresql? ? 'E' : '' +    non_empty = " +      (st_commits IS NOT NULL AND st_commits != #{literal_prefix}'--- []\n') +      OR +      (st_diffs IS NOT NULL AND st_diffs != #{literal_prefix}'--- []\n') +    ".squish + +    MergeRequestDiff.where(non_empty).each_batch(of: 500) do |relation, index| +      range = relation.pluck('MIN(id)', 'MAX(id)').first + +      Gitlab::BackgroundMigration::DeserializeMergeRequestDiffsAndCommits.new.perform(*range) +    end +  end + +  def down +  end +end diff --git a/db/migrate/20171121144800_ci_pipelines_index_on_project_id_ref_status_id.rb b/db/migrate/20171121144800_ci_pipelines_index_on_project_id_ref_status_id.rb new file mode 100644 index 00000000000..5a8ae6e4b57 --- /dev/null +++ b/db/migrate/20171121144800_ci_pipelines_index_on_project_id_ref_status_id.rb @@ -0,0 +1,35 @@ +# See http://doc.gitlab.com/ce/development/migration_style_guide.html +# for more information on how to write migrations for GitLab. + +class CiPipelinesIndexOnProjectIdRefStatusId < ActiveRecord::Migration +  include Gitlab::Database::MigrationHelpers + +  # Set this constant to true if this migration requires downtime. +  DOWNTIME = false + +  disable_ddl_transaction! + +  TABLE = :ci_pipelines +  OLD_COLUMNS = %i[project_id ref status].freeze +  NEW_COLUMNS = %i[project_id ref status id].freeze + +  def up +    unless index_exists?(TABLE, NEW_COLUMNS) +      add_concurrent_index(TABLE, NEW_COLUMNS) +    end + +    if index_exists?(TABLE, OLD_COLUMNS) +      remove_concurrent_index(TABLE, OLD_COLUMNS) +    end +  end + +  def down +    unless index_exists?(TABLE, OLD_COLUMNS) +      add_concurrent_index(TABLE, OLD_COLUMNS) +    end + +    if index_exists?(TABLE, NEW_COLUMNS) +      remove_concurrent_index(TABLE, NEW_COLUMNS) +    end +  end +end diff --git a/db/migrate/20171122131600_add_new_project_guidelines_to_appearances.rb b/db/migrate/20171122131600_add_new_project_guidelines_to_appearances.rb new file mode 100644 index 00000000000..f141c442d97 --- /dev/null +++ b/db/migrate/20171122131600_add_new_project_guidelines_to_appearances.rb @@ -0,0 +1,12 @@ +class AddNewProjectGuidelinesToAppearances < ActiveRecord::Migration +  include Gitlab::Database::MigrationHelpers + +  DOWNTIME = false + +  def change +    change_table :appearances do |t| +      t.text :new_project_guidelines +      t.text :new_project_guidelines_html +    end +  end +end diff --git a/db/migrate/20171123094802_add_circuitbreaker_check_interval_to_application_settings.rb b/db/migrate/20171123094802_add_circuitbreaker_check_interval_to_application_settings.rb new file mode 100644 index 00000000000..213d46018fc --- /dev/null +++ b/db/migrate/20171123094802_add_circuitbreaker_check_interval_to_application_settings.rb @@ -0,0 +1,20 @@ +class AddCircuitbreakerCheckIntervalToApplicationSettings < ActiveRecord::Migration +  include Gitlab::Database::MigrationHelpers + +  # Set this constant to true if this migration requires downtime. +  DOWNTIME = false + +  disable_ddl_transaction! + +  def up +    add_column_with_default :application_settings, +                            :circuitbreaker_check_interval, +                            :integer, +                            default: 1 +  end + +  def down +    remove_column :application_settings, +                  :circuitbreaker_check_interval +  end +end diff --git a/db/migrate/20171124125042_add_default_values_to_merge_request_states.rb b/db/migrate/20171124125042_add_default_values_to_merge_request_states.rb new file mode 100644 index 00000000000..d08863c3b78 --- /dev/null +++ b/db/migrate/20171124125042_add_default_values_to_merge_request_states.rb @@ -0,0 +1,19 @@ +# See http://doc.gitlab.com/ce/development/migration_style_guide.html +# for more information on how to write migrations for GitLab. + +class AddDefaultValuesToMergeRequestStates < ActiveRecord::Migration +  include Gitlab::Database::MigrationHelpers + +  # Set this constant to true if this migration requires downtime. +  DOWNTIME = false + +  def up +    change_column_default :merge_requests, :state, :opened +    change_column_default :merge_requests, :merge_status, :unchecked +  end + +  def down +    change_column_default :merge_requests, :state, nil +    change_column_default :merge_requests, :merge_status, nil +  end +end diff --git a/db/migrate/20171124125748_populate_missing_merge_request_statuses.rb b/db/migrate/20171124125748_populate_missing_merge_request_statuses.rb new file mode 100644 index 00000000000..72fbab59f4c --- /dev/null +++ b/db/migrate/20171124125748_populate_missing_merge_request_statuses.rb @@ -0,0 +1,50 @@ +# See http://doc.gitlab.com/ce/development/migration_style_guide.html +# for more information on how to write migrations for GitLab. + +class PopulateMissingMergeRequestStatuses < ActiveRecord::Migration +  include Gitlab::Database::MigrationHelpers + +  # Set this constant to true if this migration requires downtime. +  DOWNTIME = false + +  disable_ddl_transaction! + +  class MergeRequest < ActiveRecord::Base +    include EachBatch + +    self.table_name = 'merge_requests' +  end + +  def up +    say 'Populating missing merge_requests.state values' + +    # GitLab.com has no rows where "state" is NULL, and technically this should +    # never happen. However it doesn't hurt to be 100% certain. +    MergeRequest.where(state: nil).each_batch do |batch| +      batch.update_all(state: 'opened') +    end + +    say 'Populating missing merge_requests.merge_status values. ' \ +      'This will take a few minutes...' + +    # GitLab.com has 66 880 rows where "merge_status" is NULL, dating back all +    # the way to 2011. +    MergeRequest.where(merge_status: nil).each_batch(of: 10_000) do |batch| +      batch.update_all(merge_status: 'unchecked') + +      # We want to give PostgreSQL some time to vacuum any dead tuples. In +      # production we see it takes roughly 1 minute for a vacuuming run to clear +      # out 10-20k dead tuples, so we'll wait for 90 seconds between every +      # batch. +      sleep(90) if sleep? +    end +  end + +  def down +    # Reverting this makes no sense. +  end + +  def sleep? +    Rails.env.staging? || Rails.env.production? +  end +end diff --git a/db/migrate/20171124132536_make_merge_request_statuses_not_null.rb b/db/migrate/20171124132536_make_merge_request_statuses_not_null.rb new file mode 100644 index 00000000000..4bb09126036 --- /dev/null +++ b/db/migrate/20171124132536_make_merge_request_statuses_not_null.rb @@ -0,0 +1,14 @@ +# See http://doc.gitlab.com/ce/development/migration_style_guide.html +# for more information on how to write migrations for GitLab. + +class MakeMergeRequestStatusesNotNull < ActiveRecord::Migration +  include Gitlab::Database::MigrationHelpers + +  # Set this constant to true if this migration requires downtime. +  DOWNTIME = false + +  def change +    change_column_null :merge_requests, :state, false +    change_column_null :merge_requests, :merge_status, false +  end +end diff --git a/db/migrate/limits_to_mysql.rb b/db/migrate/limits_to_mysql.rb index 5cd9f3198e3..8f8d8f27410 100644 --- a/db/migrate/limits_to_mysql.rb +++ b/db/migrate/limits_to_mysql.rb @@ -3,8 +3,19 @@ class LimitsToMysql < ActiveRecord::Migration    def up      return unless ActiveRecord::Base.configurations[Rails.env]['adapter'] =~ /^mysql/ -    change_column :merge_request_diffs, :st_commits, :text, limit: 2147483647 -    change_column :merge_request_diffs, :st_diffs, :text, limit: 2147483647 +    # These columns were removed in 10.3, but this is called from two places: +    # 1. A migration run after they were added, but before they were removed. +    # 2. A rake task which can be run at any time. +    # +    # Because of item 2, we need these checks. +    if column_exists?(:merge_request_diffs, :st_commits) +      change_column :merge_request_diffs, :st_commits, :text, limit: 2147483647 +    end + +    if column_exists?(:merge_request_diffs, :st_diffs) +      change_column :merge_request_diffs, :st_diffs, :text, limit: 2147483647 +    end +      change_column :snippets, :content, :text, limit: 2147483647      change_column :notes, :st_diff, :text, limit: 2147483647    end | 
