Sha256: 151ecd8e9611e9afe27d3496463898d3cbe7dbd2525b7e6bed0aa906e1e62acc

Contents?: true

Size: 1.32 KB

Versions: 69

Compression:

Stored size: 1.32 KB

Contents

module PactBroker
  module DB

    # Returns a list of the tables in the database in the order in which
    # they can be truncated or dropped
    class TableDependencyCalculator

      def self.call connection
        new(connection).call
      end

      def initialize connection
        @connection = connection
      end

      def call
        ordered_table_names = []
        dependencies = @connection
          .tables
          .collect{|it| @connection.foreign_key_list(it)
          .collect{|fk| {from: it, to: fk[:table]} } }
          .flatten
          .uniq
        table_names = @connection.tables - [:schema_migrations, :schema_info]
        check(table_names, dependencies, ordered_table_names)
        ordered_table_names
      end

      def deps_on table_name, deps
        deps.select{ | d| d[:to] == table_name }.collect{ |d| d[:from] }
      end

      def check table_names, deps, ordered_table_names
        return if table_names.size == 0
        remaining_dependencies = deps_on(table_names.first, deps) - ordered_table_names
        if remaining_dependencies.size == 0
          ordered_table_names << table_names.first
          check(table_names[1..-1], deps, ordered_table_names)
        else
          check((remaining_dependencies + table_names).uniq, deps, ordered_table_names)
        end
      end
    end
  end
end

Version data entries

69 entries across 69 versions & 1 rubygems

Version Path
pact_broker-2.113.0 lib/pact_broker/db/table_dependency_calculator.rb
pact_broker-2.112.0 lib/pact_broker/db/table_dependency_calculator.rb
pact_broker-2.111.0 lib/pact_broker/db/table_dependency_calculator.rb
pact_broker-2.109.1 lib/pact_broker/db/table_dependency_calculator.rb
pact_broker-2.109.0 lib/pact_broker/db/table_dependency_calculator.rb
pact_broker-2.108.0 lib/pact_broker/db/table_dependency_calculator.rb
pact_broker-2.107.1 lib/pact_broker/db/table_dependency_calculator.rb
pact_broker-2.107.0 lib/pact_broker/db/table_dependency_calculator.rb
pact_broker-2.107.0.beta.1 lib/pact_broker/db/table_dependency_calculator.rb
pact_broker-2.106.0 lib/pact_broker/db/table_dependency_calculator.rb
pact_broker-2.105.0 lib/pact_broker/db/table_dependency_calculator.rb
pact_broker-2.104.0 lib/pact_broker/db/table_dependency_calculator.rb
pact_broker-2.103.0 lib/pact_broker/db/table_dependency_calculator.rb
pact_broker-2.102.2 lib/pact_broker/db/table_dependency_calculator.rb
pact_broker-2.102.1 lib/pact_broker/db/table_dependency_calculator.rb
pact_broker-2.102.0 lib/pact_broker/db/table_dependency_calculator.rb
pact_broker-2.101.0 lib/pact_broker/db/table_dependency_calculator.rb
pact_broker-2.100.0 lib/pact_broker/db/table_dependency_calculator.rb
pact_broker-2.99.0 lib/pact_broker/db/table_dependency_calculator.rb
pact_broker-2.98.0 lib/pact_broker/db/table_dependency_calculator.rb