Sha256: 096aee4c5130a34a2ccfe08ff3955a23ed62f074d7f4331b223e182e45585dcc

Contents?: true

Size: 1.05 KB

Versions: 45

Compression:

Stored size: 1.05 KB

Contents

require 'pact_broker/db/data_migrations/helpers'

module PactBroker
  module DB
    module DataMigrations
      class SetConsumerIdsForPactPublications
        def self.call connection
          if columns_exist?(connection)
            query = "UPDATE pact_publications
                    SET consumer_id = (SELECT pacticipant_id
                      FROM versions
                      WHERE id = pact_publications.consumer_version_id)
                    WHERE consumer_id is null"
            connection.run(query)
          end
        end

        def self.columns_exist?(connection)
          column_exists?(connection, :pact_publications, :consumer_id) &&
            column_exists?(connection, :pact_publications, :id) &&
            column_exists?(connection, :versions, :id) &&
            column_exists?(connection, :versions, :pacticipant_id)
        end

        def self.column_exists?(connection, table, column)
          connection.table_exists?(table) && connection.schema(table).find{|col| col.first == column }
        end
      end
    end
  end
end

Version data entries

45 entries across 45 versions & 1 rubygems

Version Path
pact_broker-2.79.1 lib/pact_broker/db/data_migrations/set_consumer_ids_for_pact_publications.rb
pact_broker-2.79.0 lib/pact_broker/db/data_migrations/set_consumer_ids_for_pact_publications.rb
pact_broker-2.78.1 lib/pact_broker/db/data_migrations/set_consumer_ids_for_pact_publications.rb
pact_broker-2.78.0 lib/pact_broker/db/data_migrations/set_consumer_ids_for_pact_publications.rb
pact_broker-2.77.0 lib/pact_broker/db/data_migrations/set_consumer_ids_for_pact_publications.rb
pact_broker-2.76.2 lib/pact_broker/db/data_migrations/set_consumer_ids_for_pact_publications.rb
pact_broker-2.76.1 lib/pact_broker/db/data_migrations/set_consumer_ids_for_pact_publications.rb
pact_broker-2.76.0 lib/pact_broker/db/data_migrations/set_consumer_ids_for_pact_publications.rb
pact_broker-2.75.0 lib/pact_broker/db/data_migrations/set_consumer_ids_for_pact_publications.rb
pact_broker-2.74.1 lib/pact_broker/db/data_migrations/set_consumer_ids_for_pact_publications.rb
pact_broker-2.74.0 lib/pact_broker/db/data_migrations/set_consumer_ids_for_pact_publications.rb
pact_broker-2.73.0 lib/pact_broker/db/data_migrations/set_consumer_ids_for_pact_publications.rb
pact_broker-2.72.0 lib/pact_broker/db/data_migrations/set_consumer_ids_for_pact_publications.rb
pact_broker-2.71.0 lib/pact_broker/db/data_migrations/set_consumer_ids_for_pact_publications.rb
pact_broker-2.70.0 lib/pact_broker/db/data_migrations/set_consumer_ids_for_pact_publications.rb
pact_broker-2.69.0 lib/pact_broker/db/data_migrations/set_consumer_ids_for_pact_publications.rb
pact_broker-2.68.1 lib/pact_broker/db/data_migrations/set_consumer_ids_for_pact_publications.rb
pact_broker-2.68.0 lib/pact_broker/db/data_migrations/set_consumer_ids_for_pact_publications.rb
pact_broker-2.67.0 lib/pact_broker/db/data_migrations/set_consumer_ids_for_pact_publications.rb
pact_broker-2.66.0 lib/pact_broker/db/data_migrations/set_consumer_ids_for_pact_publications.rb