diff options
| author | Micaël Bergeron <mbergeron@gitlab.com> | 2018-02-26 14:14:00 -0500 | 
|---|---|---|
| committer | Micaël Bergeron <mbergeron@gitlab.com> | 2018-03-01 10:38:37 -0500 | 
| commit | 40a3b467f25df62fab4b92a3700846f06ef7534c (patch) | |
| tree | 36a810dda2811035af976a89eb4756ff12245f48 | |
| parent | e43d7d2b4d4ccae4e7c7c89b68b6dc3ae8f34bb7 (diff) | |
| download | gitlab-ce-40a3b467f25df62fab4b92a3700846f06ef7534c.tar.gz | |
add the Ci::Build `*_store` column
| -rw-r--r-- | app/models/ci/build.rb | 4 | ||||
| -rw-r--r-- | db/migrate/20180222152310_port_object_storage_to_ce.rb | 42 | ||||
| -rw-r--r-- | db/schema.rb | 2 | 
3 files changed, 27 insertions, 21 deletions
| diff --git a/app/models/ci/build.rb b/app/models/ci/build.rb index 53a0d787988..715ab55a100 100644 --- a/app/models/ci/build.rb +++ b/app/models/ci/build.rb @@ -3,6 +3,7 @@ module Ci      prepend ArtifactMigratable      include TokenAuthenticatable      include AfterCommitQueue +    include ObjectStorage::BackgroundMove      include Presentable      include Importable @@ -41,10 +42,13 @@ module Ci      scope :unstarted, ->() { where(runner_id: nil) }      scope :ignore_failures, ->() { where(allow_failure: false) } +      scope :with_artifacts, ->() do        where('(artifacts_file IS NOT NULL AND artifacts_file <> ?) OR EXISTS (?)',          '', Ci::JobArtifact.select(1).where('ci_builds.id = ci_job_artifacts.job_id'))      end +    scope :with_artifacts_stored_locally, -> { with_artifacts.where(artifacts_file_store: [nil, LegacyArtifactUploader::Store::LOCAL]) } +      scope :with_artifacts_not_expired, ->() { with_artifacts.where('artifacts_expire_at IS NULL OR artifacts_expire_at > ?', Time.now) }      scope :with_expired_artifacts, ->() { with_artifacts.where('artifacts_expire_at < ?', Time.now) }      scope :with_artifacts_stored_locally, ->() { with_artifacts.where(artifacts_file_store: [nil, LegacyArtifactUploader::Store::LOCAL]) } diff --git a/db/migrate/20180222152310_port_object_storage_to_ce.rb b/db/migrate/20180222152310_port_object_storage_to_ce.rb index aa1e15072b8..f2e2e53ed8c 100644 --- a/db/migrate/20180222152310_port_object_storage_to_ce.rb +++ b/db/migrate/20180222152310_port_object_storage_to_ce.rb @@ -7,31 +7,31 @@ class PortObjectStorageToCe < ActiveRecord::Migration    # Set this constant to true if this migration requires downtime.    DOWNTIME = false -  def up -    unless column_exists?(:ci_job_artifacts, :file_store) -      add_column(:ci_job_artifacts, :file_store, :integer) -    end - -    unless column_exists?(:lfs_objects, :file_store) -      add_column(:lfs_objects, :file_store, :integer) -    end +  def add_column_idempotent(table, column, *defs) +    return if column_exists?(table, column) -    unless column_exists?(:uploads, :store) -      add_column(:uploads, :store, :integer) -    end +    add_column(table, column, *defs)    end -  def down -    if column_exists?(:ci_job_artifacts, :file_store) -      remove_column(:ci_job_artifacts, :file_store) -    end +  def remove_column_idempotent(table, column) +    return unless column_exists?(table, column) + +    remove_column(table, column) +  end -    if column_exists?(:lfs_objects, :file_store) -      remove_column(:lfs_objects, :file_store) -    end +  def up +    add_column_idempotent(:ci_job_artifacts, :file_store, :integer) +    add_column_idempotent(:ci_builds, :artifacts_file_store, :integer) +    add_column_idempotent(:ci_builds, :artifacts_metadata_store, :integer) +    add_column_idempotent(:lfs_objects, :file_store, :integer) +    add_column_idempotent(:uploads, :store, :integer) +  end -    if column_exists?(:uploads, :store) -      remove_column(:uploads, :store) -    end +  def down +    remove_column_idempotent(:ci_job_artifacts, :file_store) +    remove_column_idempotent(:ci_builds, :artifacts_file_store) +    remove_column_idempotent(:ci_builds, :artifacts_metadata_store) +    remove_column_idempotent(:lfs_objects, :file_store) +    remove_column_idempotent(:uploads, :store)    end  end diff --git a/db/schema.rb b/db/schema.rb index 74dbb11c89b..3af701d0ed9 100644 --- a/db/schema.rb +++ b/db/schema.rb @@ -294,6 +294,8 @@ ActiveRecord::Schema.define(version: 20180222152310) do      t.integer "artifacts_metadata_store", default: 1, null: false      t.boolean "protected"      t.integer "failure_reason" +    t.integer "artifacts_file_store" +    t.integer "artifacts_metadata_store"    end    add_index "ci_builds", ["artifacts_expire_at"], name: "index_ci_builds_on_artifacts_expire_at", where: "(artifacts_file <> ''::text)", using: :btree | 
