data_migrate 8.1.0 → 8.1.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/Changelog.md +4 -0
- data/lib/data_migrate/database_tasks.rb +1 -34
- data/lib/data_migrate/version.rb +1 -1
- data/tasks/databases.rake +85 -35
- metadata +1 -1
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 7f6afd16bfaf1425e8e8fa9b7916df46f6b2d826fb572c2adeade0db17ec9e03
|
4
|
+
data.tar.gz: 80cc32ea79bfb83913ea24c647d8fd1a12fb2956756d33ad9f31eef3ebeca2db
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 57a9d5e94a753924506ad0a79896b859e53073f348c222972988510a942dc958e61b3b1e6859b51f31f3374f2d550b82710e7b579509894c33e1e045bd9a0ecc
|
7
|
+
data.tar.gz: 6ab5ceea16179d7f3e42b6ce9aa0028cd214c907139e3938e503ed21e35ad00c16a5a409dfe6b9032d06f689ce37ea36e14543238d9a76147f2b0dd5b5421700
|
data/Changelog.md
CHANGED
@@ -47,40 +47,6 @@ module DataMigrate
|
|
47
47
|
Kernel.abort message
|
48
48
|
end
|
49
49
|
end
|
50
|
-
|
51
|
-
def pending_migrations
|
52
|
-
sort_migrations(
|
53
|
-
pending_schema_migrations,
|
54
|
-
pending_data_migrations
|
55
|
-
)
|
56
|
-
end
|
57
|
-
|
58
|
-
def sort_migrations set_1, set_2=nil
|
59
|
-
migrations = set_1 + (set_2 || [])
|
60
|
-
migrations.sort{|a,b| sort_string(a) <=> sort_string(b)}
|
61
|
-
end
|
62
|
-
|
63
|
-
def sort_string migration
|
64
|
-
"#{migration[:version]}_#{migration[:kind] == :data ? 1 : 0}"
|
65
|
-
end
|
66
|
-
|
67
|
-
def data_migrations_path
|
68
|
-
::DataMigrate.config.data_migrations_path
|
69
|
-
end
|
70
|
-
|
71
|
-
def run_migration(migration, direction)
|
72
|
-
if migration[:kind] == :data
|
73
|
-
::ActiveRecord::Migration.write("== %s %s" % ['Data', "=" * 71])
|
74
|
-
::DataMigrate::DataMigrator.run(direction, data_migrations_path, migration[:version])
|
75
|
-
else
|
76
|
-
::ActiveRecord::Migration.write("== %s %s" % ['Schema', "=" * 69])
|
77
|
-
::DataMigrate::SchemaMigration.run(
|
78
|
-
direction,
|
79
|
-
::Continuation::SchemaMigration.migrations_paths,
|
80
|
-
migration[:version]
|
81
|
-
)
|
82
|
-
end
|
83
|
-
end
|
84
50
|
end
|
85
51
|
|
86
52
|
# This overrides ActiveRecord::Tasks::DatabaseTasks
|
@@ -155,5 +121,6 @@ module DataMigrate
|
|
155
121
|
|
156
122
|
sort == "asc" ? sort_migrations(migrations) : sort_migrations(migrations).reverse
|
157
123
|
end
|
124
|
+
|
158
125
|
end
|
159
126
|
end
|
data/lib/data_migrate/version.rb
CHANGED
data/tasks/databases.rake
CHANGED
@@ -4,29 +4,29 @@ namespace :db do
|
|
4
4
|
namespace :migrate do
|
5
5
|
desc "Migrate the database data and schema (options: VERSION=x, VERBOSE=false)."
|
6
6
|
task :with_data => :environment do
|
7
|
-
|
7
|
+
assure_data_schema_table
|
8
8
|
|
9
9
|
ActiveRecord::Migration.verbose = ENV["VERBOSE"] ? ENV["VERBOSE"] == "true" : true
|
10
10
|
target_version = ENV["VERSION"] ? ENV["VERSION"].to_i : nil
|
11
11
|
migrations = []
|
12
12
|
|
13
13
|
if target_version.nil?
|
14
|
-
migrations =
|
14
|
+
migrations = pending_migrations.map{ |m| m.merge(:direction =>:up) }
|
15
15
|
else
|
16
16
|
current_schema_version = ActiveRecord::Migrator.current_version
|
17
17
|
schema_migrations = if target_version > current_schema_version
|
18
|
-
|
18
|
+
pending_schema_migrations.keep_if{ |m| m[:version] <= target_version }.map{ |m| m.merge(:direction =>:up) }
|
19
19
|
elsif target_version < current_schema_version
|
20
|
-
|
20
|
+
past_migrations.keep_if{ |m| m[:version] > target_version }.map{ |m| m.merge(:direction =>:down) }
|
21
21
|
else # ==
|
22
22
|
[]
|
23
23
|
end
|
24
24
|
|
25
|
-
current_data_version =
|
25
|
+
current_data_version = ActiveRecord::Migrator.current_version
|
26
26
|
data_migrations = if target_version > current_data_version
|
27
|
-
|
27
|
+
pending_data_migrations.keep_if{ |m| m[:version] <= target_version }.map{ |m| m.merge(:direction =>:up) }
|
28
28
|
elsif target_version < current_data_version
|
29
|
-
|
29
|
+
past_migrations.keep_if{ |m| m[:version] > target_version }.map{ |m| m.merge(:direction =>:down) }
|
30
30
|
else # ==
|
31
31
|
[]
|
32
32
|
end
|
@@ -35,9 +35,9 @@ namespace :db do
|
|
35
35
|
elsif data_migrations.empty?
|
36
36
|
schema_migrations
|
37
37
|
elsif target_version > current_data_version && target_version > current_schema_version
|
38
|
-
|
38
|
+
sort_migrations data_migrations, schema_migrations
|
39
39
|
elsif target_version < current_data_version && target_version < current_schema_version
|
40
|
-
|
40
|
+
sort_migrations(data_migrations, schema_migrations).reverse
|
41
41
|
elsif target_version > current_data_version && target_version < current_schema_version
|
42
42
|
schema_migrations + data_migrations
|
43
43
|
elsif target_version < current_data_version && target_version > current_schema_version
|
@@ -46,7 +46,7 @@ namespace :db do
|
|
46
46
|
end
|
47
47
|
|
48
48
|
migrations.each do |migration|
|
49
|
-
|
49
|
+
run_migration(migration, migration[:direction])
|
50
50
|
end
|
51
51
|
|
52
52
|
Rake::Task["db:_dump"].invoke
|
@@ -56,7 +56,7 @@ namespace :db do
|
|
56
56
|
namespace :redo do
|
57
57
|
desc 'Rollbacks the database one migration and re migrate up (options: STEP=x, VERSION=x).'
|
58
58
|
task :with_data => :environment do
|
59
|
-
|
59
|
+
assure_data_schema_table
|
60
60
|
if ENV["VERSION"]
|
61
61
|
Rake::Task["db:migrate:down:with_data"].invoke
|
62
62
|
Rake::Task["db:migrate:up:with_data"].invoke
|
@@ -72,16 +72,16 @@ namespace :db do
|
|
72
72
|
task :with_data => :environment do
|
73
73
|
version = ENV["VERSION"] ? ENV["VERSION"].to_i : nil
|
74
74
|
raise "VERSION is required" unless version
|
75
|
-
|
75
|
+
assure_data_schema_table
|
76
76
|
run_both = ENV["BOTH"] == "true"
|
77
|
-
migrations =
|
77
|
+
migrations = pending_migrations.keep_if{|m| m[:version] == version}
|
78
78
|
|
79
79
|
unless run_both || migrations.size < 2
|
80
80
|
migrations = migrations.slice(0,1)
|
81
81
|
end
|
82
82
|
|
83
83
|
migrations.each do |migration|
|
84
|
-
|
84
|
+
run_migration(migration, :up)
|
85
85
|
end
|
86
86
|
|
87
87
|
Rake::Task["db:_dump"].invoke
|
@@ -94,16 +94,16 @@ namespace :db do
|
|
94
94
|
task :with_data => :environment do
|
95
95
|
version = ENV["VERSION"] ? ENV["VERSION"].to_i : nil
|
96
96
|
raise "VERSION is required" unless version
|
97
|
-
|
97
|
+
assure_data_schema_table
|
98
98
|
run_both = ENV["BOTH"] == "true"
|
99
|
-
migrations =
|
99
|
+
migrations = past_migrations.keep_if{|m| m[:version] == version}
|
100
100
|
|
101
101
|
unless run_both || migrations.size < 2
|
102
102
|
migrations = migrations.slice(0,1)
|
103
103
|
end
|
104
104
|
|
105
105
|
migrations.each do |migration|
|
106
|
-
|
106
|
+
run_migration(migration, :down)
|
107
107
|
end
|
108
108
|
|
109
109
|
Rake::Task["db:_dump"].invoke
|
@@ -123,9 +123,9 @@ namespace :db do
|
|
123
123
|
desc 'Rolls the schema back to the previous version (specify steps w/ STEP=n).'
|
124
124
|
task :with_data => :environment do
|
125
125
|
step = ENV['STEP'] ? ENV['STEP'].to_i : 1
|
126
|
-
|
127
|
-
|
128
|
-
|
126
|
+
assure_data_schema_table
|
127
|
+
past_migrations[0..(step - 1)].each do | past_migration |
|
128
|
+
run_migration(past_migration, :down)
|
129
129
|
end
|
130
130
|
|
131
131
|
Rake::Task["db:_dump"].invoke
|
@@ -136,7 +136,7 @@ namespace :db do
|
|
136
136
|
namespace :forward do
|
137
137
|
desc 'Pushes the schema to the next version (specify steps w/ STEP=n).'
|
138
138
|
task :with_data => :environment do
|
139
|
-
|
139
|
+
assure_data_schema_table
|
140
140
|
step = ENV['STEP'] ? ENV['STEP'].to_i : 1
|
141
141
|
DataMigrate::DatabaseTasks.forward(step)
|
142
142
|
Rake::Task["db:_dump"].invoke
|
@@ -147,7 +147,7 @@ namespace :db do
|
|
147
147
|
namespace :version do
|
148
148
|
desc "Retrieves the current schema version numbers for data and schema migrations"
|
149
149
|
task :with_data => :environment do
|
150
|
-
|
150
|
+
assure_data_schema_table
|
151
151
|
puts "Current Schema version: #{ActiveRecord::Migrator.current_version}"
|
152
152
|
puts "Current Data version: #{DataMigrate::DataMigrator.current_version}"
|
153
153
|
end
|
@@ -157,7 +157,7 @@ namespace :db do
|
|
157
157
|
desc "Raises an error if there are pending migrations or data migrations"
|
158
158
|
task with_data: :environment do
|
159
159
|
message = %{Run `rake db:migrate:with_data` to update your database then try again.}
|
160
|
-
DataMigrate::Tasks::DataMigrateTasks.abort_if_pending_migrations(
|
160
|
+
DataMigrate::Tasks::DataMigrateTasks.abort_if_pending_migrations(pending_migrations, message)
|
161
161
|
end
|
162
162
|
end
|
163
163
|
|
@@ -200,7 +200,7 @@ namespace :data do
|
|
200
200
|
namespace :migrate do
|
201
201
|
desc 'Rollbacks the database one migration and re migrate up (options: STEP=x, VERSION=x).'
|
202
202
|
task :redo => :environment do
|
203
|
-
|
203
|
+
assure_data_schema_table
|
204
204
|
if ENV["VERSION"]
|
205
205
|
Rake::Task["data:migrate:down"].invoke
|
206
206
|
Rake::Task["data:migrate:up"].invoke
|
@@ -212,10 +212,10 @@ namespace :data do
|
|
212
212
|
|
213
213
|
desc 'Runs the "up" for a given migration VERSION.'
|
214
214
|
task :up => :environment do
|
215
|
-
|
215
|
+
assure_data_schema_table
|
216
216
|
version = ENV["VERSION"] ? ENV["VERSION"].to_i : nil
|
217
217
|
raise "VERSION is required" unless version
|
218
|
-
DataMigrate::DataMigrator.run(:up,
|
218
|
+
DataMigrate::DataMigrator.run(:up, data_migrations_path, version)
|
219
219
|
Rake::Task["data:dump"].invoke
|
220
220
|
end
|
221
221
|
|
@@ -223,8 +223,8 @@ namespace :data do
|
|
223
223
|
task :down => :environment do
|
224
224
|
version = ENV["VERSION"] ? ENV["VERSION"].to_i : nil
|
225
225
|
raise "VERSION is required" unless version
|
226
|
-
|
227
|
-
DataMigrate::DataMigrator.run(:down,
|
226
|
+
assure_data_schema_table
|
227
|
+
DataMigrate::DataMigrator.run(:down, data_migrations_path, version)
|
228
228
|
Rake::Task["data:dump"].invoke
|
229
229
|
end
|
230
230
|
|
@@ -236,35 +236,35 @@ namespace :data do
|
|
236
236
|
|
237
237
|
desc 'Rolls the schema back to the previous version (specify steps w/ STEP=n).'
|
238
238
|
task :rollback => :environment do
|
239
|
-
|
239
|
+
assure_data_schema_table
|
240
240
|
step = ENV['STEP'] ? ENV['STEP'].to_i : 1
|
241
|
-
DataMigrate::DataMigrator.rollback(
|
241
|
+
DataMigrate::DataMigrator.rollback(data_migrations_path, step)
|
242
242
|
Rake::Task["data:dump"].invoke
|
243
243
|
end
|
244
244
|
|
245
245
|
desc 'Pushes the schema to the next version (specify steps w/ STEP=n).'
|
246
246
|
task :forward => :environment do
|
247
|
-
|
247
|
+
assure_data_schema_table
|
248
248
|
step = ENV['STEP'] ? ENV['STEP'].to_i : 1
|
249
249
|
# TODO: No worky for .forward
|
250
250
|
# DataMigrate::DataMigrator.forward('db/data/', step)
|
251
|
-
migrations =
|
251
|
+
migrations = pending_data_migrations.reverse.pop(step).reverse
|
252
252
|
migrations.each do | pending_migration |
|
253
|
-
DataMigrate::DataMigrator.run(:up,
|
253
|
+
DataMigrate::DataMigrator.run(:up, data_migrations_path, pending_migration[:version])
|
254
254
|
end
|
255
255
|
Rake::Task["data:dump"].invoke
|
256
256
|
end
|
257
257
|
|
258
258
|
desc "Retrieves the current schema version number for data migrations"
|
259
259
|
task :version => :environment do
|
260
|
-
|
260
|
+
assure_data_schema_table
|
261
261
|
puts "Current data version: #{DataMigrate::DataMigrator.current_version}"
|
262
262
|
end
|
263
263
|
|
264
264
|
desc "Raises an error if there are pending data migrations"
|
265
265
|
task abort_if_pending_migrations: :environment do
|
266
266
|
message = %{Run `rake data:migrate` to update your database then try again.}
|
267
|
-
DataMigrate::Tasks::DataMigrateTasks.abort_if_pending_migrations(
|
267
|
+
DataMigrate::Tasks::DataMigrateTasks.abort_if_pending_migrations(pending_data_migrations, message)
|
268
268
|
end
|
269
269
|
|
270
270
|
desc "Create a db/data_schema.rb file that stores the current data version"
|
@@ -287,3 +287,53 @@ namespace :data do
|
|
287
287
|
end
|
288
288
|
end
|
289
289
|
end
|
290
|
+
|
291
|
+
def pending_migrations
|
292
|
+
DataMigrate::DatabaseTasks.sort_migrations(
|
293
|
+
DataMigrate::DatabaseTasks.pending_schema_migrations,
|
294
|
+
DataMigrate::DatabaseTasks.pending_data_migrations
|
295
|
+
)
|
296
|
+
end
|
297
|
+
|
298
|
+
def pending_data_migrations
|
299
|
+
DataMigrate::DatabaseTasks.pending_data_migrations
|
300
|
+
end
|
301
|
+
|
302
|
+
def pending_schema_migrations
|
303
|
+
DataMigrate::DatabaseTasks.pending_schema_migrations
|
304
|
+
end
|
305
|
+
|
306
|
+
def sort_migrations set_1, set_2=nil
|
307
|
+
migrations = set_1 + (set_2 || [])
|
308
|
+
migrations.sort{|a,b| sort_string(a) <=> sort_string(b)}
|
309
|
+
end
|
310
|
+
|
311
|
+
def sort_string migration
|
312
|
+
"#{migration[:version]}_#{migration[:kind] == :data ? 1 : 0}"
|
313
|
+
end
|
314
|
+
|
315
|
+
def past_migrations(sort=nil)
|
316
|
+
DataMigrate::DatabaseTasks.past_migrations(sort)
|
317
|
+
end
|
318
|
+
|
319
|
+
def assure_data_schema_table
|
320
|
+
DataMigrate::DataMigrator.assure_data_schema_table
|
321
|
+
end
|
322
|
+
|
323
|
+
def data_migrations_path
|
324
|
+
DataMigrate.config.data_migrations_path
|
325
|
+
end
|
326
|
+
|
327
|
+
def run_migration(migration, direction)
|
328
|
+
if migration[:kind] == :data
|
329
|
+
ActiveRecord::Migration.write("== %s %s" % ['Data', "=" * 71])
|
330
|
+
DataMigrate::DataMigrator.run(direction, data_migrations_path, migration[:version])
|
331
|
+
else
|
332
|
+
ActiveRecord::Migration.write("== %s %s" % ['Schema', "=" * 69])
|
333
|
+
DataMigrate::SchemaMigration.run(
|
334
|
+
direction,
|
335
|
+
DataMigrate::SchemaMigration.migrations_paths,
|
336
|
+
migration[:version]
|
337
|
+
)
|
338
|
+
end
|
339
|
+
end
|