aboutsummaryrefslogtreecommitdiffstats
path: root/railties
diff options
context:
space:
mode:
authorSammy Larbi <sam@codeodor.com>2012-12-26 13:02:28 -0600
committerSammy Larbi <sam@codeodor.com>2013-03-01 06:13:30 -0600
commit20e041579f5fe9df51bdc40048cc1ef78915e116 (patch)
treedadb0c23877b488daef2e5896c4193213a5b91a0 /railties
parentbb9f8312e7fe31566b898f87be149b13daf4dc57 (diff)
downloadrails-20e041579f5fe9df51bdc40048cc1ef78915e116.tar.gz
rails-20e041579f5fe9df51bdc40048cc1ef78915e116.tar.bz2
rails-20e041579f5fe9df51bdc40048cc1ef78915e116.zip
Support creating a table migration generator
Sometimes you want to create a table without an associated model and test, which is also not a join table. With this commit, you can now do that. Example: rails g migration create_posts title:string or rails g migration CreatePosts title:string This commit also moves the template the model generator uses for the migration to the migration templates folder, as it seems a more sensible place for it now that it is shared code.
Diffstat (limited to 'railties')
-rw-r--r--railties/test/generators/migration_generator_test.rb17
1 files changed, 14 insertions, 3 deletions
diff --git a/railties/test/generators/migration_generator_test.rb b/railties/test/generators/migration_generator_test.rb
index 62d9d1f06a..d876597944 100644
--- a/railties/test/generators/migration_generator_test.rb
+++ b/railties/test/generators/migration_generator_test.rb
@@ -172,8 +172,19 @@ class MigrationGeneratorTest < Rails::Generators::TestCase
end
end
- def test_should_create_empty_migrations_if_name_not_start_with_add_or_remove
- migration = "create_books"
+ def test_create_table_migration
+ run_generator ["create_books", "title:string", "content:text"]
+ assert_migration "db/migrate/create_books.rb" do |content|
+ assert_method :change, content do |change|
+ assert_match(/create_table :books/, change)
+ assert_match(/ t\.string :title/, change)
+ assert_match(/ t\.text :content/, change)
+ end
+ end
+ end
+
+ def test_should_create_empty_migrations_if_name_not_start_with_add_or_remove_or_create
+ migration = "delete_books"
run_generator [migration, "title:string", "content:text"]
assert_migration "db/migrate/#{migration}.rb" do |content|
@@ -182,7 +193,7 @@ class MigrationGeneratorTest < Rails::Generators::TestCase
end
end
end
-
+
def test_properly_identifies_usage_file
assert generator_class.send(:usage_path)
end