Sha256: cfdd3748f53eff205cc1da6e48e853d4700209ae0ae63d283b5f71060345a941

Contents?: true

Size: 1.33 KB

Versions: 74

Compression:

Stored size: 1.33 KB

Contents

module PactBroker
  module Database

    # 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

74 entries across 74 versions & 1 rubygems

Version Path
pact_broker-2.61.0 tasks/database/table_dependency_calculator.rb
pact_broker-2.60.1 tasks/database/table_dependency_calculator.rb
pact_broker-2.60.0 tasks/database/table_dependency_calculator.rb
pact_broker-2.59.2 tasks/database/table_dependency_calculator.rb
pact_broker-2.59.1 tasks/database/table_dependency_calculator.rb
pact_broker-2.59.0 tasks/database/table_dependency_calculator.rb
pact_broker-2.58.3 tasks/database/table_dependency_calculator.rb
pact_broker-2.58.2 tasks/database/table_dependency_calculator.rb
pact_broker-2.58.0 tasks/database/table_dependency_calculator.rb
pact_broker-2.57.0 tasks/database/table_dependency_calculator.rb
pact_broker-2.56.1 tasks/database/table_dependency_calculator.rb
pact_broker-2.56.0 tasks/database/table_dependency_calculator.rb
pact_broker-2.55.0 tasks/database/table_dependency_calculator.rb
pact_broker-2.54.0 tasks/database/table_dependency_calculator.rb
pact_broker-2.53.0 tasks/database/table_dependency_calculator.rb
pact_broker-2.52.2 tasks/database/table_dependency_calculator.rb
pact_broker-2.52.1 tasks/database/table_dependency_calculator.rb
pact_broker-2.52.0 tasks/database/table_dependency_calculator.rb
pact_broker-2.51.0 tasks/database/table_dependency_calculator.rb
pact_broker-2.50.1 tasks/database/table_dependency_calculator.rb