diff options
| author | Dylan Griffith <dyl.griffith@gmail.com> | 2018-04-24 15:07:34 +1000 | 
|---|---|---|
| committer | Dylan Griffith <dyl.griffith@gmail.com> | 2018-04-24 15:07:34 +1000 | 
| commit | 1b9c1ac3adb3d65e51f38e37c4705d46c5618f88 (patch) | |
| tree | b724afd0596dd658f7ef7baddf9411ff3e599f7d /db | |
| parent | 392c411bdc16386ef42c86afaf8c4d8e4cddb955 (diff) | |
| parent | 2e00c1a72afc4b7388bb46bd6d58608e2ae61899 (diff) | |
| download | gitlab-ce-1b9c1ac3adb3d65e51f38e37c4705d46c5618f88.tar.gz | |
Merge branch 'master' into 10244-add-project-ci-cd-settings
Diffstat (limited to 'db')
7 files changed, 154 insertions, 4 deletions
| diff --git a/db/fixtures/development/17_cycle_analytics.rb b/db/fixtures/development/17_cycle_analytics.rb index d7be6f5950f..7b9a4bad449 100644 --- a/db/fixtures/development/17_cycle_analytics.rb +++ b/db/fixtures/development/17_cycle_analytics.rb @@ -1,5 +1,5 @@  require './spec/support/sidekiq' -require './spec/support/test_env' +require './spec/support/helpers/test_env'  class Gitlab::Seeder::CycleAnalytics    def initialize(project, perf: false) diff --git a/db/migrate/20180330121048_add_issue_due_to_notification_settings.rb b/db/migrate/20180330121048_add_issue_due_to_notification_settings.rb new file mode 100644 index 00000000000..c64a481fcf0 --- /dev/null +++ b/db/migrate/20180330121048_add_issue_due_to_notification_settings.rb @@ -0,0 +1,9 @@ +class AddIssueDueToNotificationSettings < ActiveRecord::Migration +  include Gitlab::Database::MigrationHelpers + +  DOWNTIME = false + +  def change +    add_column :notification_settings, :issue_due, :boolean +  end +end diff --git a/db/migrate/20180413022611_create_missing_namespace_for_internal_users.rb b/db/migrate/20180413022611_create_missing_namespace_for_internal_users.rb new file mode 100644 index 00000000000..8fc558be733 --- /dev/null +++ b/db/migrate/20180413022611_create_missing_namespace_for_internal_users.rb @@ -0,0 +1,66 @@ +class CreateMissingNamespaceForInternalUsers < ActiveRecord::Migration +  DOWNTIME = false + +  def up +    connection.exec_query(users_query.to_sql).rows.each do |id, username| +      create_namespace(id, username) +      # When testing locally I've noticed that these internal users are missing +      # the notification email, for more details visit the below link: +      # https://gitlab.com/gitlab-org/gitlab-ce/merge_requests/18357#note_68327560 +      set_notification_email(id) +    end +  end + +  def down +    # no-op +  end + +  private + +  def users +    @users ||= Arel::Table.new(:users) +  end + +  def namespaces +    @namespaces ||= Arel::Table.new(:namespaces) +  end + +  def users_query +    condition = users[:ghost].eq(true) + +    if column_exists?(:users, :support_bot) +      condition = condition.or(users[:support_bot].eq(true)) +    end + +    users.join(namespaces, Arel::Nodes::OuterJoin) +      .on(namespaces[:type].eq(nil).and(namespaces[:owner_id].eq(users[:id]))) +      .where(namespaces[:owner_id].eq(nil)) +      .where(condition) +      .project(users[:id], users[:username]) +  end + +  def create_namespace(user_id, username) +    path = Uniquify.new.string(username) do |str| +      query = "SELECT id FROM namespaces WHERE parent_id IS NULL AND path='#{str}' LIMIT 1" +      connection.exec_query(query).present? +    end + +    insert_query = "INSERT INTO namespaces(owner_id, path, name) VALUES(#{user_id}, '#{path}', '#{path}')" +    namespace_id = connection.insert_sql(insert_query) + +    create_route(namespace_id) +  end + +  def create_route(namespace_id) +    return unless namespace_id + +    row = connection.exec_query("SELECT id, path FROM namespaces WHERE id=#{namespace_id}").first +    id, path = row.values_at('id', 'path') + +    execute("INSERT INTO routes(source_id, source_type, path, name) VALUES(#{id}, 'Namespace', '#{path}', '#{path}')") +  end + +  def set_notification_email(user_id) +    execute "UPDATE users SET notification_email = email WHERE notification_email IS NULL AND id = #{user_id}" +  end +end diff --git a/db/migrate/20180416155103_add_further_scope_columns_to_internal_id_table.rb b/db/migrate/20180416155103_add_further_scope_columns_to_internal_id_table.rb new file mode 100644 index 00000000000..37e2d19e022 --- /dev/null +++ b/db/migrate/20180416155103_add_further_scope_columns_to_internal_id_table.rb @@ -0,0 +1,15 @@ +class AddFurtherScopeColumnsToInternalIdTable < ActiveRecord::Migration +  include Gitlab::Database::MigrationHelpers + +  DOWNTIME = false + +  def up +    change_column_null :internal_ids, :project_id, true +    add_column :internal_ids, :namespace_id, :integer, null: true +  end + +  def down +    change_column_null :internal_ids, :project_id, false +    remove_column :internal_ids, :namespace_id +  end +end diff --git a/db/migrate/20180417090132_add_index_constraints_to_internal_id_table.rb b/db/migrate/20180417090132_add_index_constraints_to_internal_id_table.rb new file mode 100644 index 00000000000..582b89a3948 --- /dev/null +++ b/db/migrate/20180417090132_add_index_constraints_to_internal_id_table.rb @@ -0,0 +1,40 @@ +class AddIndexConstraintsToInternalIdTable < ActiveRecord::Migration +  include Gitlab::Database::MigrationHelpers + +  DOWNTIME = false + +  disable_ddl_transaction! + +  def up +    add_concurrent_index :internal_ids, [:usage, :namespace_id], unique: true, where: 'namespace_id IS NOT NULL' + +    replace_index(:internal_ids, [:usage, :project_id], name: 'index_internal_ids_on_usage_and_project_id') do +      add_concurrent_index :internal_ids, [:usage, :project_id], unique: true, where: 'project_id IS NOT NULL' +    end + +    add_concurrent_foreign_key :internal_ids, :namespaces, column: :namespace_id, on_delete: :cascade +  end + +  def down +    remove_concurrent_index :internal_ids, [:usage, :namespace_id] + +    replace_index(:internal_ids, [:usage, :project_id], name: 'index_internal_ids_on_usage_and_project_id') do +      add_concurrent_index :internal_ids, [:usage, :project_id], unique: true +    end + +    remove_foreign_key :internal_ids, column: :namespace_id +  end + +  private +  def replace_index(table, columns, name:) +    temporary_name = "#{name}_old" + +    if index_exists?(table, columns, name: name) +      rename_index table, name, temporary_name +    end + +    yield + +    remove_concurrent_index_by_name table, temporary_name +  end +end diff --git a/db/migrate/20180418053107_add_index_to_ci_job_artifacts_file_store.rb b/db/migrate/20180418053107_add_index_to_ci_job_artifacts_file_store.rb new file mode 100644 index 00000000000..1084ca14a34 --- /dev/null +++ b/db/migrate/20180418053107_add_index_to_ci_job_artifacts_file_store.rb @@ -0,0 +1,15 @@ +class AddIndexToCiJobArtifactsFileStore < ActiveRecord::Migration +  include Gitlab::Database::MigrationHelpers + +  DOWNTIME = false + +  disable_ddl_transaction! + +  def up +    add_concurrent_index :ci_job_artifacts, :file_store +  end + +  def down +    remove_index :ci_job_artifacts, :file_store if index_exists?(:ci_job_artifacts, :file_store) +  end +end diff --git a/db/schema.rb b/db/schema.rb index d741f0113d8..dc4607d0876 100644 --- a/db/schema.rb +++ b/db/schema.rb @@ -11,7 +11,7 @@  #  # It's strongly recommended that you check this file into your version control system. -ActiveRecord::Schema.define(version: 20180409170809) do +ActiveRecord::Schema.define(version: 20180418053107) do    # These are extensions that must be enabled in order to support this database    enable_extension "plpgsql" @@ -367,6 +367,7 @@ ActiveRecord::Schema.define(version: 20180409170809) do    end    add_index "ci_job_artifacts", ["expire_at", "job_id"], name: "index_ci_job_artifacts_on_expire_at_and_job_id", using: :btree +  add_index "ci_job_artifacts", ["file_store"], name: "index_ci_job_artifacts_on_file_store", using: :btree    add_index "ci_job_artifacts", ["job_id", "file_type"], name: "index_ci_job_artifacts_on_job_id_and_file_type", unique: true, using: :btree    add_index "ci_job_artifacts", ["project_id"], name: "index_ci_job_artifacts_on_project_id", using: :btree @@ -895,12 +896,14 @@ ActiveRecord::Schema.define(version: 20180409170809) do    add_index "identities", ["user_id"], name: "index_identities_on_user_id", using: :btree    create_table "internal_ids", id: :bigserial, force: :cascade do |t| -    t.integer "project_id", null: false +    t.integer "project_id"      t.integer "usage", null: false      t.integer "last_value", null: false +    t.integer "namespace_id"    end -  add_index "internal_ids", ["usage", "project_id"], name: "index_internal_ids_on_usage_and_project_id", unique: true, using: :btree +  add_index "internal_ids", ["usage", "namespace_id"], name: "index_internal_ids_on_usage_and_namespace_id", unique: true, where: "(namespace_id IS NOT NULL)", using: :btree +  add_index "internal_ids", ["usage", "project_id"], name: "index_internal_ids_on_usage_and_project_id", unique: true, where: "(project_id IS NOT NULL)", using: :btree    create_table "issue_assignees", id: false, force: :cascade do |t|      t.integer "user_id", null: false @@ -1325,6 +1328,7 @@ ActiveRecord::Schema.define(version: 20180409170809) do      t.boolean "failed_pipeline"      t.boolean "success_pipeline"      t.boolean "push_to_merge_request" +    t.boolean "issue_due"    end    add_index "notification_settings", ["source_id", "source_type"], name: "index_notification_settings_on_source_id_and_source_type", using: :btree @@ -2118,6 +2122,7 @@ ActiveRecord::Schema.define(version: 20180409170809) do    add_foreign_key "gpg_signatures", "gpg_keys", on_delete: :nullify    add_foreign_key "gpg_signatures", "projects", on_delete: :cascade    add_foreign_key "group_custom_attributes", "namespaces", column: "group_id", on_delete: :cascade +  add_foreign_key "internal_ids", "namespaces", name: "fk_162941d509", on_delete: :cascade    add_foreign_key "internal_ids", "projects", on_delete: :cascade    add_foreign_key "issue_assignees", "issues", name: "fk_b7d881734a", on_delete: :cascade    add_foreign_key "issue_assignees", "users", name: "fk_5e0c8d9154", on_delete: :cascade | 
