aboutsummaryrefslogtreecommitdiffstats
path: root/spec/support/pg_catalog.rb
blob: ca02f25508de12b18f44eb92b3a5e60572ae9bc6 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
require_relative 'bare_sql'
module Support
  module PGCatalog
    include Support::BareSQL

    def get_columns(schema_name, table_name)
      execute("SELECT column_name, column_default FROM information_schema.columns WHERE table_name = '#{table_name}' AND table_schema = '#{schema_name}'").to_a
    end

    def get_foreign_keys(schema_oid, table_name)
      schema_oid = get_schema_oid(schema_oid) unless Integer === schema_oid
      return [] unless schema_oid
      execute(foreign_key_query(schema_oid, table_name))
        .to_a
    end

    def get_schema_oid(schema_name)
      execute("SELECT oid FROM pg_namespace WHERE nspname = '#{schema_name}'")
        .values
        .flatten
        .first
    end

    def get_sequences(schema_name, sequence_name)
      sequences = execute(sequence_query(schema_name, sequence_name))
      sequences.values.flatten.map do | sequence |
        execute "SELECT * from #{schema_name}.#{sequence}"
      end.flat_map(&:to_a)
    end

    def get_table_information(schema_name, table_name)
      execute("SELECT * FROM information_schema.tables WHERE table_name = '#{table_name}' AND table_schema = '#{schema_name}'")
        .to_a
        .map(&without_keys("table_catalog"))
    end


    private

    def foreign_key_query(schema_oid, table_name)
      <<-EOQ
        SELECT ct.conname AS constraint_name, pg_get_constraintdef(ct.oid) AS constraint_def
          FROM pg_constraint ct JOIN pg_class rn ON rn.oid = ct.conrelid
          WHERE connamespace = #{schema_oid} AND rn.relname = '#{table_name}' AND rn.relkind = 'r' AND ct.contype = 'f'
      EOQ
    end

    def sequence_query(schema_name, sequence_name)
      <<-EOQ
        SELECT sequence_name FROM information_schema.sequences
          WHERE sequence_schema = '#{schema_name}' AND sequence_name = '#{sequence_name}'
      EOQ
    end

    def without_keys(*keys)
      -> hashy do
        hashy.inject({}) do |h, (k,v)|
          keys.include?(k) ? h : h.merge(k => v)
        end
      end
    end
  end
end

RSpec.configure do | conf |
  conf.include Support::PGCatalog, type: :pg_catalog
end