Sha256: 1c43e946fe4adcdcf842be1e684c47750e72c5ca65bf7e87a45968e040dece64

Contents?: true

Size: 1.45 KB

Versions: 39

Compression:

Stored size: 1.45 KB

Contents

require "sequel"
require "pact_broker/repositories/helpers"

module PactBroker
  module Verifications
    class Sequence < Sequel::Model(:verification_sequence_number)
      dataset_module do
        # The easiest way to implement a cross database compatible sequence.
        # Sad, I know.
        def next_val
          if PactBroker::Repositories::Helpers.postgres?
            db.execute("SELECT nextval('verification_number_sequence') as val") { |v| v.first["val"].to_i }
          else
            db.transaction do
              for_update.first
              select_all.update(value: Sequel[:value]+1)
              row = first
              if row
                row.value
              else
                # The first row should have been created in the migration, so this code
                # should only ever be executed in a test context.
                # There would be a risk of a race condition creating two rows if this
                # code executed in prod, as I don't think you can lock an empty table
                # to prevent another record being inserted.
                max_verification_number = PactBroker::Domain::Verification.max(:number)
                value = max_verification_number ? max_verification_number + 100 : 1
                insert(value: value)
                value
              end
            end
          end
        end
      end
    end
  end
end

# Table: verification_sequence_number
# Columns:
#  value | integer | NOT NULL

Version data entries

39 entries across 39 versions & 1 rubygems

Version Path
pact_broker-2.107.1 lib/pact_broker/verifications/sequence.rb
pact_broker-2.107.0 lib/pact_broker/verifications/sequence.rb
pact_broker-2.107.0.beta.1 lib/pact_broker/verifications/sequence.rb
pact_broker-2.106.0 lib/pact_broker/verifications/sequence.rb
pact_broker-2.105.0 lib/pact_broker/verifications/sequence.rb
pact_broker-2.104.0 lib/pact_broker/verifications/sequence.rb
pact_broker-2.103.0 lib/pact_broker/verifications/sequence.rb
pact_broker-2.102.2 lib/pact_broker/verifications/sequence.rb
pact_broker-2.102.1 lib/pact_broker/verifications/sequence.rb
pact_broker-2.102.0 lib/pact_broker/verifications/sequence.rb
pact_broker-2.101.0 lib/pact_broker/verifications/sequence.rb
pact_broker-2.100.0 lib/pact_broker/verifications/sequence.rb
pact_broker-2.99.0 lib/pact_broker/verifications/sequence.rb
pact_broker-2.98.0 lib/pact_broker/verifications/sequence.rb
pact_broker-2.97.0 lib/pact_broker/verifications/sequence.rb
pact_broker-2.96.0 lib/pact_broker/verifications/sequence.rb
pact_broker-2.95.1 lib/pact_broker/verifications/sequence.rb
pact_broker-2.95.0 lib/pact_broker/verifications/sequence.rb
pact_broker-2.94.0 lib/pact_broker/verifications/sequence.rb
pact_broker-2.93.4 lib/pact_broker/verifications/sequence.rb