aboutsummaryrefslogtreecommitdiffstats
path: root/railties/test/generators/model_generator_test.rb
diff options
context:
space:
mode:
authorPrathamesh Sonpatki <csonpatki@gmail.com>2019-04-16 11:42:18 +0530
committerPrathamesh Sonpatki <csonpatki@gmail.com>2019-04-19 20:08:29 +0530
commit8b4d344815655027d9f7584c0a59271dce8f1d5a (patch)
treecf98e4e0c22a1584fb574d10ef18cae56374eb36 /railties/test/generators/model_generator_test.rb
parent10da0a27512e108a5cde3eeba774b01c15f6c43a (diff)
downloadrails-8b4d344815655027d9f7584c0a59271dce8f1d5a.tar.gz
rails-8b4d344815655027d9f7584c0a59271dce8f1d5a.tar.bz2
rails-8b4d344815655027d9f7584c0a59271dce8f1d5a.zip
Add `null: false` constraint by default for `belongs_to` associations
- Also deprecate passing {required} to the model generator. - Also made sure the global config `belongs_to_required_by_default` is applied correctly to the model generator for `null: false` option.
Diffstat (limited to 'railties/test/generators/model_generator_test.rb')
-rw-r--r--railties/test/generators/model_generator_test.rb50
1 files changed, 46 insertions, 4 deletions
diff --git a/railties/test/generators/model_generator_test.rb b/railties/test/generators/model_generator_test.rb
index f860e328f2..df765432bc 100644
--- a/railties/test/generators/model_generator_test.rb
+++ b/railties/test/generators/model_generator_test.rb
@@ -10,6 +10,14 @@ class ModelGeneratorTest < Rails::Generators::TestCase
def setup
super
Rails::Generators::ModelHelpers.skip_warn = false
+ @old_belongs_to_required_by_default = Rails.application.config.active_record.belongs_to_required_by_default
+
+ Rails.application.config.active_record.belongs_to_required_by_default = true
+ end
+
+
+ def teardown
+ Rails.application.config.active_record.belongs_to_required_by_default = @old_belongs_to_required_by_default
end
def test_help_shows_invoked_generators_options
@@ -415,7 +423,7 @@ class ModelGeneratorTest < Rails::Generators::TestCase
end
def test_required_polymorphic_belongs_to_generates_correct_model
- run_generator ["account", "supplier:references{required,polymorphic}"]
+ run_generator ["account", "supplier:references{polymorphic}"]
expected_file = <<~FILE
class Account < ApplicationRecord
@@ -426,7 +434,7 @@ class ModelGeneratorTest < Rails::Generators::TestCase
end
def test_required_and_polymorphic_are_order_independent
- run_generator ["account", "supplier:references{polymorphic.required}"]
+ run_generator ["account", "supplier:references{polymorphic}"]
expected_file = <<~FILE
class Account < ApplicationRecord
@@ -436,8 +444,10 @@ class ModelGeneratorTest < Rails::Generators::TestCase
assert_file "app/models/account.rb", expected_file
end
- def test_required_adds_null_false_to_column
- run_generator ["account", "supplier:references{required}"]
+ def test_passing_required_to_model_generator_is_deprecated
+ assert_deprecated do
+ run_generator ["account", "supplier:references{required}"]
+ end
assert_migration "db/migrate/create_accounts.rb" do |m|
assert_method :change, m do |up|
@@ -446,6 +456,38 @@ class ModelGeneratorTest < Rails::Generators::TestCase
end
end
+ def test_null_false_is_added_for_references_by_default
+ run_generator ["account", "user:references"]
+
+ assert_migration "db/migrate/create_accounts.rb" do |m|
+ assert_method :change, m do |up|
+ assert_match(/t\.references :user,.*\snull: false/, up)
+ end
+ end
+ end
+
+ def test_null_false_is_added_for_belongs_to_by_default
+ run_generator ["account", "user:belongs_to"]
+
+ assert_migration "db/migrate/create_accounts.rb" do |m|
+ assert_method :change, m do |up|
+ assert_match(/t\.belongs_to :user,.*\snull: false/, up)
+ end
+ end
+ end
+
+ def test_null_false_is_not_added_when_belongs_to_required_by_default_global_config_is_false
+ Rails.application.config.active_record.belongs_to_required_by_default = false
+
+ run_generator ["account", "user:belongs_to"]
+
+ assert_migration "db/migrate/create_accounts.rb" do |m|
+ assert_method :change, m do |up|
+ assert_match(/t\.belongs_to :user/, up)
+ end
+ end
+ end
+
def test_foreign_key_is_not_added_for_non_references
run_generator ["account", "supplier:string"]