ridgepole 0.6.5.beta11 → 0.6.5.beta12

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 CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA1:
3
- metadata.gz: 9d9f5c2109909e6a196908e0a0990e62a5b00030
4
- data.tar.gz: 30a539a691cf72848afa5ba2ef81c9ce8a7dc2ce
3
+ metadata.gz: fe78b203c5736b9c91293c2e678889afe4b1e927
4
+ data.tar.gz: d4bf1df43c6676eb5817b38cc377d02d826dab65
5
5
  SHA512:
6
- metadata.gz: a404a78077b95bd8feeac8e3cabc25910440784f9b9c1db0fa144332a9352a47465b86e0f24df5f08ecc9003e405db9e73b282cb4abd085a8fc595f22763d9c6
7
- data.tar.gz: 597e212b753edf77db08483b1b827951dd893c5b129b75a7fd509ac317c3b49241f3797324774de04283faac3b2527ae1640c838e70e9899430b6062c45bbb71
6
+ metadata.gz: 29d7d68475863ef2e2575eef3fb2162c38f84659c8f56c5b5c5f36d339f185a7c686ca7feb31ef5c9fd2192cbf87d23318630aaf36a468333daf2a873804f5d0
7
+ data.tar.gz: a8173e2d906dfef78b698abe9723aa0dad1ec67af06918095074934d599dcd7a170e7a7763a5240de74eee8aa802cd63eac45fc1dd4022c37b990c1f2d3b3e49
@@ -168,7 +168,7 @@ class Ridgepole::Diff
168
168
  modified_indices = []
169
169
 
170
170
  from_indices.each do |name, attrs|
171
- if attrs[:column_name].delete(column_name)
171
+ if attrs[:column_name].is_a?(Array) && attrs[:column_name].delete(column_name)
172
172
  modified_indices << name
173
173
  end
174
174
  end
@@ -181,7 +181,7 @@ class Ridgepole::Diff
181
181
  end
182
182
 
183
183
  from_indices.reject! do |name, attrs|
184
- attrs[:column_name].empty?
184
+ attrs[:column_name].is_a?(Array) && attrs[:column_name].empty?
185
185
  end
186
186
  end
187
187
  end
@@ -303,6 +303,10 @@ class Ridgepole::Diff
303
303
  end
304
304
 
305
305
  def columns_all_include?(expected_columns, actual_columns, table_options)
306
+ unless expected_columns.is_a?(Array)
307
+ return true
308
+ end
309
+
306
310
  if table_options[:id] != false
307
311
  actual_columns = actual_columns + [(table_options[:primary_key] || 'id').to_s]
308
312
  end
@@ -1,3 +1,3 @@
1
1
  module Ridgepole
2
- VERSION = '0.6.5.beta11'
2
+ VERSION = '0.6.5.beta12'
3
3
  end
@@ -0,0 +1,57 @@
1
+ describe 'Ridgepole::Client#diff -> migrate', condition: [:activerecord_5] do
2
+ subject { client }
3
+
4
+ before do
5
+ subject.diff(actual_dsl).migrate
6
+ end
7
+
8
+ context 'when drop column from table containing an expression index' do
9
+ let(:actual_dsl) { <<-EOS }
10
+ create_table "users", force: :cascade do |t|
11
+ t.string "name", null: false
12
+ t.datetime "created_at", null: false
13
+ t.index "lower((name)::text)", name: "index_users_on_lower_name", using: :btree
14
+ end
15
+ EOS
16
+
17
+ let(:expected_dsl) { <<-EOS }
18
+ create_table "users", force: :cascade do |t|
19
+ t.string "name", null: false
20
+ t.index "lower((name)::text)", name: "index_users_on_lower_name", using: :btree
21
+ end
22
+ EOS
23
+
24
+ specify do
25
+ delta = subject.diff(expected_dsl)
26
+ expect(delta).to be_differ
27
+ expect(delta.script).to match_fuzzy('remove_column("users", "created_at")')
28
+ expect(subject.dump).to match_fuzzy(actual_dsl)
29
+ delta.migrate
30
+ expect(subject.dump).to match_fuzzy(expected_dsl)
31
+ end
32
+ end
33
+
34
+ context 'when drop expression index' do
35
+ let(:actual_dsl) { <<-EOS }
36
+ create_table "users", force: :cascade do |t|
37
+ t.string "name", null: false
38
+ t.index "lower((name)::text)", name: "index_users_on_lower_name", using: :btree
39
+ end
40
+ EOS
41
+
42
+ let(:expected_dsl) { <<-EOS }
43
+ create_table "users", force: :cascade do |t|
44
+ t.string "name", null: false
45
+ end
46
+ EOS
47
+
48
+ specify do
49
+ delta = subject.diff(expected_dsl)
50
+ expect(delta).to be_differ
51
+ expect(delta.script).to match_fuzzy('remove_index("users", {:name=>"index_users_on_lower_name"})')
52
+ expect(subject.dump).to match_fuzzy(actual_dsl)
53
+ delta.migrate
54
+ expect(subject.dump).to match_fuzzy(expected_dsl)
55
+ end
56
+ end
57
+ end
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: ridgepole
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.6.5.beta11
4
+ version: 0.6.5.beta12
5
5
  platform: ruby
6
6
  authors:
7
7
  - Genki Sugawara
@@ -327,6 +327,7 @@ files:
327
327
  - spec/postgresql/migrate/migrate_create_table_with_default_proc_spec.rb
328
328
  - spec/postgresql/migrate/migrate_drop_column_spec.rb
329
329
  - spec/postgresql/migrate/migrate_drop_column_with_index_spec.rb
330
+ - spec/postgresql/migrate/migrate_drop_expression_index_spec.rb
330
331
  - spec/postgresql/migrate/migrate_drop_index_spec.rb
331
332
  - spec/postgresql/migrate/migrate_drop_table_spec.rb
332
333
  - spec/postgresql/migrate/migrate_ext_cols_spec.rb
@@ -457,6 +458,7 @@ test_files:
457
458
  - spec/postgresql/migrate/migrate_create_table_with_default_proc_spec.rb
458
459
  - spec/postgresql/migrate/migrate_drop_column_spec.rb
459
460
  - spec/postgresql/migrate/migrate_drop_column_with_index_spec.rb
461
+ - spec/postgresql/migrate/migrate_drop_expression_index_spec.rb
460
462
  - spec/postgresql/migrate/migrate_drop_index_spec.rb
461
463
  - spec/postgresql/migrate/migrate_drop_table_spec.rb
462
464
  - spec/postgresql/migrate/migrate_ext_cols_spec.rb