database_consistency 2.1.1 → 2.1.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/lib/database_consistency/checkers/association_checkers/association_checker.rb +3 -3
- data/lib/database_consistency/checkers/association_checkers/foreign_key_checker.rb +1 -1
- data/lib/database_consistency/checkers/association_checkers/foreign_key_type_checker.rb +46 -35
- data/lib/database_consistency/checkers/association_checkers/missing_dependent_destroy_checker.rb +1 -8
- data/lib/database_consistency/helper.rb +10 -1
- data/lib/database_consistency/version.rb +1 -1
- metadata +4 -6
checksums.yaml
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
---
|
|
2
2
|
SHA256:
|
|
3
|
-
metadata.gz:
|
|
4
|
-
data.tar.gz:
|
|
3
|
+
metadata.gz: 67c90295e24b6b49a4e010a612729f86951d2dda7daba5ac06b091e6b435e040
|
|
4
|
+
data.tar.gz: f1958934302e46a7b21d600a9418bbf58bef2921a5b4d5c2dd5fcccc5a4acda8
|
|
5
5
|
SHA512:
|
|
6
|
-
metadata.gz:
|
|
7
|
-
data.tar.gz:
|
|
6
|
+
metadata.gz: 3bb2a7b1dc68923711cad75c25c2e27a0208ac625a911f61b6e9a6459b5c71640800329f920f14373c4202f100f36b2bf05f2a683772bace47ebc5dd3b3b4ea4
|
|
7
|
+
data.tar.gz: e6a7b06b4bd9d7b3ff002e24c8a320b952c208e864f07ec4f0c255de23b032f14610bf893cc737d3ca2713f1357ee0e0307d91d4a611c48b693e330b1145891e
|
|
@@ -24,9 +24,9 @@ module DatabaseConsistency
|
|
|
24
24
|
@table_or_model_name ||= model.name.to_s
|
|
25
25
|
end
|
|
26
26
|
|
|
27
|
-
def
|
|
28
|
-
model.connection.foreign_keys(model.table_name).
|
|
29
|
-
(Helper.extract_columns(association.foreign_key
|
|
27
|
+
def foreign_key # rubocop:disable Metrics/AbcSize
|
|
28
|
+
model.connection.foreign_keys(model.table_name).find do |foreign_key|
|
|
29
|
+
(Helper.extract_columns(association.foreign_key) - Array.wrap(foreign_key.column)).empty? &&
|
|
30
30
|
foreign_key.to_table == association.klass.table_name
|
|
31
31
|
end
|
|
32
32
|
end
|
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
module DatabaseConsistency
|
|
4
4
|
module Checkers
|
|
5
5
|
# This class checks if association's foreign key type covers associated model's primary key (same or bigger)
|
|
6
|
-
class ForeignKeyTypeChecker < AssociationChecker
|
|
6
|
+
class ForeignKeyTypeChecker < AssociationChecker # rubocop:disable Metrics/ClassLength
|
|
7
7
|
Report = ReportBuilder.define(
|
|
8
8
|
DatabaseConsistency::Report,
|
|
9
9
|
:pk_name,
|
|
@@ -36,10 +36,11 @@ module DatabaseConsistency
|
|
|
36
36
|
# | ------------- | ------ |
|
|
37
37
|
# | covers | ok |
|
|
38
38
|
# | doesn't cover | fail |
|
|
39
|
-
def check # rubocop:disable Metrics/MethodLength
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
39
|
+
def check # rubocop:disable Metrics/MethodLength
|
|
40
|
+
associated_columns_converted_types = associated_columns.map { |column| converted_type(column) }
|
|
41
|
+
primary_columns_converted_types = primary_columns.map { |primary_column| converted_type(primary_column) }
|
|
42
|
+
|
|
43
|
+
if covers?(associated_columns_converted_types, primary_columns_converted_types)
|
|
43
44
|
report_template(:ok)
|
|
44
45
|
else
|
|
45
46
|
report_template(:fail, error_slug: :inconsistent_types)
|
|
@@ -53,17 +54,17 @@ module DatabaseConsistency
|
|
|
53
54
|
)
|
|
54
55
|
end
|
|
55
56
|
|
|
56
|
-
def report_template(status, error_slug: nil) # rubocop:disable Metrics/MethodLength
|
|
57
|
+
def report_template(status, error_slug: nil) # rubocop:disable Metrics/MethodLength, Metrics/AbcSize
|
|
57
58
|
Report.new(
|
|
58
59
|
status: status,
|
|
59
60
|
error_slug: error_slug,
|
|
60
61
|
error_message: nil,
|
|
61
62
|
table_to_change: table_to_change,
|
|
62
|
-
type_to_set: converted_type(primary_column).convert,
|
|
63
|
-
fk_type: converted_type(
|
|
64
|
-
fk_name:
|
|
65
|
-
pk_type: converted_type(primary_column).type,
|
|
66
|
-
pk_name:
|
|
63
|
+
type_to_set: primary_columns.map { |primary_column| converted_type(primary_column).convert },
|
|
64
|
+
fk_type: associated_columns.map { |column| converted_type(column).type }.join('+'),
|
|
65
|
+
fk_name: associated_keys.join('+'),
|
|
66
|
+
pk_type: primary_columns.map { |primary_column| converted_type(primary_column).type }.join('+'),
|
|
67
|
+
pk_name: primary_keys.join('+'),
|
|
67
68
|
**report_attributes
|
|
68
69
|
)
|
|
69
70
|
end
|
|
@@ -76,36 +77,40 @@ module DatabaseConsistency
|
|
|
76
77
|
end
|
|
77
78
|
end
|
|
78
79
|
|
|
79
|
-
# @return [String]
|
|
80
|
-
def
|
|
81
|
-
@
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
80
|
+
# @return [Array<String>]
|
|
81
|
+
def primary_keys
|
|
82
|
+
@primary_keys ||= if belongs_to_association?
|
|
83
|
+
Helper.extract_columns(association.association_primary_key)
|
|
84
|
+
else
|
|
85
|
+
Helper.extract_columns(association.active_record_primary_key)
|
|
86
|
+
end
|
|
86
87
|
end
|
|
87
88
|
|
|
88
|
-
# @return [String]
|
|
89
|
-
def
|
|
90
|
-
@
|
|
89
|
+
# @return [Array<String>]
|
|
90
|
+
def associated_keys
|
|
91
|
+
@associated_keys ||= Helper.extract_columns(association.foreign_key)
|
|
91
92
|
end
|
|
92
93
|
|
|
93
|
-
# @return [ActiveRecord::ConnectionAdapters::Column]
|
|
94
|
-
def
|
|
95
|
-
@
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
94
|
+
# @return [Array<ActiveRecord::ConnectionAdapters::Column>]
|
|
95
|
+
def primary_columns
|
|
96
|
+
@primary_columns ||= primary_keys.map do |primary_key|
|
|
97
|
+
if belongs_to_association?
|
|
98
|
+
column(association.klass, primary_key)
|
|
99
|
+
else
|
|
100
|
+
column(association.active_record, primary_key)
|
|
101
|
+
end
|
|
102
|
+
end
|
|
100
103
|
end
|
|
101
104
|
|
|
102
|
-
# @return [ActiveRecord::ConnectionAdapters::Column]
|
|
103
|
-
def
|
|
104
|
-
@
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
105
|
+
# @return [Array<ActiveRecord::ConnectionAdapters::Column>]
|
|
106
|
+
def associated_columns
|
|
107
|
+
@associated_columns ||= associated_keys.map do |associated_key|
|
|
108
|
+
if belongs_to_association?
|
|
109
|
+
column(association.active_record, associated_key)
|
|
110
|
+
else
|
|
111
|
+
column(association.klass, associated_key)
|
|
112
|
+
end
|
|
113
|
+
end
|
|
109
114
|
end
|
|
110
115
|
|
|
111
116
|
# @return [DatabaseConsistency::Databases::Factory]
|
|
@@ -135,6 +140,12 @@ module DatabaseConsistency
|
|
|
135
140
|
column.sql_type
|
|
136
141
|
end
|
|
137
142
|
|
|
143
|
+
def covers?(associated_types, primary_types)
|
|
144
|
+
associated_types.zip(primary_types).all? do |associated_type, primary_type|
|
|
145
|
+
associated_type.cover?(primary_type)
|
|
146
|
+
end
|
|
147
|
+
end
|
|
148
|
+
|
|
138
149
|
# @param [ActiveRecord::ConnectionAdapters::Column]
|
|
139
150
|
#
|
|
140
151
|
# @return [DatabaseConsistency::Databases::Types::Base]
|
data/lib/database_consistency/checkers/association_checkers/missing_dependent_destroy_checker.rb
CHANGED
|
@@ -15,7 +15,7 @@ module DatabaseConsistency
|
|
|
15
15
|
private
|
|
16
16
|
|
|
17
17
|
def preconditions
|
|
18
|
-
association.belongs_to? &&
|
|
18
|
+
association.belongs_to? && foreign_key
|
|
19
19
|
end
|
|
20
20
|
|
|
21
21
|
def check
|
|
@@ -34,13 +34,6 @@ module DatabaseConsistency
|
|
|
34
34
|
end
|
|
35
35
|
end
|
|
36
36
|
|
|
37
|
-
def foreign_key
|
|
38
|
-
association.klass
|
|
39
|
-
.connection
|
|
40
|
-
.foreign_keys(model.table_name)
|
|
41
|
-
.find { |fk| fk.column == association.foreign_key.to_s }
|
|
42
|
-
end
|
|
43
|
-
|
|
44
37
|
def cascade?
|
|
45
38
|
%i[cascade nullify].include? foreign_key.options[:on_delete]
|
|
46
39
|
end
|
|
@@ -128,7 +128,16 @@ module DatabaseConsistency
|
|
|
128
128
|
end
|
|
129
129
|
|
|
130
130
|
def extract_columns(str)
|
|
131
|
-
str
|
|
131
|
+
case str
|
|
132
|
+
when Array
|
|
133
|
+
str.map(&:to_s)
|
|
134
|
+
when String
|
|
135
|
+
str.scan(/(\w+)/).flatten
|
|
136
|
+
when Symbol
|
|
137
|
+
[str.to_s]
|
|
138
|
+
else
|
|
139
|
+
raise "Unexpected type for columns: #{str.class} with value: #{str}"
|
|
140
|
+
end
|
|
132
141
|
end
|
|
133
142
|
|
|
134
143
|
def foreign_key_or_attribute(model, attribute)
|
metadata
CHANGED
|
@@ -1,14 +1,13 @@
|
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
|
2
2
|
name: database_consistency
|
|
3
3
|
version: !ruby/object:Gem::Version
|
|
4
|
-
version: 2.1.
|
|
4
|
+
version: 2.1.3
|
|
5
5
|
platform: ruby
|
|
6
6
|
authors:
|
|
7
7
|
- Evgeniy Demin
|
|
8
|
-
autorequire:
|
|
9
8
|
bindir: bin
|
|
10
9
|
cert_chain: []
|
|
11
|
-
date:
|
|
10
|
+
date: 1980-01-02 00:00:00.000000000 Z
|
|
12
11
|
dependencies:
|
|
13
12
|
- !ruby/object:Gem::Dependency
|
|
14
13
|
name: activerecord
|
|
@@ -136,7 +135,6 @@ dependencies:
|
|
|
136
135
|
- - ">"
|
|
137
136
|
- !ruby/object:Gem::Version
|
|
138
137
|
version: '1.3'
|
|
139
|
-
description:
|
|
140
138
|
email:
|
|
141
139
|
- lawliet.djez@gmail.com
|
|
142
140
|
executables:
|
|
@@ -275,9 +273,9 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
|
275
273
|
- !ruby/object:Gem::Version
|
|
276
274
|
version: '0'
|
|
277
275
|
requirements: []
|
|
278
|
-
rubygems_version: 3.
|
|
279
|
-
signing_key:
|
|
276
|
+
rubygems_version: 3.7.2
|
|
280
277
|
specification_version: 4
|
|
281
278
|
summary: Provide an easy way to check the consistency of the database constraints
|
|
282
279
|
with the application validations.
|
|
283
280
|
test_files: []
|
|
281
|
+
...
|