Hey everyone, I've been out of the loop for a minute regarding engines, but I'm looking to update Substruct to Engines 2.3/Rails 2.3 if possible. My last investigation stopped when running into the migrations issue. I'm wondering if there is a recommended way to handle engine migrations / legacy migrations (001_my_migration.rb) with 2.3. The official site mentions some "things being in the works" but I didn't really see anything past that. Any advice or a link to a blog post would be cool. Thanks much.
on 2010-02-09 22:43
on 2010-02-09 22:47
I've been handling them by including a generator in my plugin, which generates a migration (or possibly multiple migrations). You'd have to generate and run the migration in each app using the plugin, which is a bit clunky, but seems to be okay as a workaround. Nat
on 2010-02-09 22:54
Having just taken the plunge and updated my old 2.0.2 site to 2.3.5 with all the trimmings, I can offer a few thoughts. The latest engines plugin does handle legacy migrations, but you need to do some tweaking. First off, you need to set Rails to use numeric migrations, or you'll have lots of headaches. Alternately, I suppose you can manually timestamp your old migrations, but I haven't tried that one yet... You can set Rails to use numeric migrations by setting: config.active_record.timestamped_migrations = false Once that's done, you need (possibly) to run: rake db:migrate:upgrade_plugin_migration This will make sure you have the proper DB tables, and put an entry into that table for every old plugin migrations you have, in the format "<#>-<plugin-name>" At this point, you should be in good shape. Your db state matches your code state, with one entry in schema_migrations for every plugin migration and every main app migration. The final trick is to use: rake db:migrate:all Use this to upgrade your DB instead of the old ./script/generate plugin_migration bit. The engines plugin will run all existing plugins, find all new migrations, and apply them correctly. Hope that helps! -Rob
on 2010-02-11 16:55
only thing I know of is http://www.ruby-forum.com/topic/196976#new I think I got migrations to work all right. It's been awhile. -r
on 2010-08-27 03:26
Rob Morris wrote: > Having just taken the plunge and updated my old 2.0.2 site to 2.3.5 with > all the trimmings, I can offer a few thoughts. > > The latest engines plugin does handle legacy migrations, but you need to > do some tweaking. > > First off, you need to set Rails to use numeric migrations, or you'll > have lots of headaches. Alternately, I suppose you can manually > timestamp your old migrations, but I haven't tried that one yet... You > can set Rails to use numeric migrations by setting: > config.active_record.timestamped_migrations = false > > Once that's done, you need (possibly) to run: rake > db:migrate:upgrade_plugin_migration > > This will make sure you have the proper DB tables, and put an entry into > that table for every old plugin migrations you have, in the format > "<#>-<plugin-name>" > > At this point, you should be in good shape. Your db state matches your > code state, with one entry in schema_migrations for every plugin > migration and every main app migration. > > The final trick is to use: rake db:migrate:all > > Use this to upgrade your DB instead of the old ./script/generate > plugin_migration bit. The engines plugin will run all existing plugins, > find all new migrations, and apply them correctly. > > Hope that helps! > > -Rob That does help and I think I'll go with that. I've found you can run rake db:migrate:plugin NAME=pluginname and it runs fine. The only issue I can't seem to solve is how to back out migrations applied in this way. Have you any guidance there? Doesn't look like there's any sort of rake db:migrate:plugin:down ...wondering if there should be?
Please log in before posting. Registration is free and takes only a minute.
Existing account
(Switch to SSL-encrypted connection)
NEW: Do you have a Google/GoogleMail or Yahoo account? No registration required!
Log in with Google account | Log in with Yahoo account
Log in with Google account | Log in with Yahoo account
No account? Register here.