From a1a62e4e43818dde4d4c1089ea2dcee67551d0fd Mon Sep 17 00:00:00 2001 From: Andrew Kane Date: Thu, 7 Nov 2024 05:10:08 -0800 Subject: [PATCH] Made add_foreign_key retriable with safe_by_default and Active Record < 7.1 --- lib/strong_migrations/safe_methods.rb | 4 ++-- test/safe_by_default_test.rb | 10 ++++------ 2 files changed, 6 insertions(+), 8 deletions(-) diff --git a/lib/strong_migrations/safe_methods.rb b/lib/strong_migrations/safe_methods.rb index 7f7ad5f2..9e20f3c6 100644 --- a/lib/strong_migrations/safe_methods.rb +++ b/lib/strong_migrations/safe_methods.rb @@ -47,9 +47,9 @@ def safe_add_reference(table, reference, *args, **options) def safe_add_foreign_key(from_table, to_table, *args, **options) @migration.reversible do |dir| dir.up do - # validate option is ignored for Active Record < 7.1 + # validate option is unintentionally ignored for Active Record < 7.1 # https://github.com/rails/rails/pull/45896 - if ar_version < 7.1 || !connection.foreign_key_exists?(from_table, to_table, **options.merge(validate: false)) + if !connection.foreign_key_exists?(from_table, to_table, **options.merge(validate: false)) @migration.add_foreign_key(from_table, to_table, *args, **options.merge(validate: false)) end disable_transaction diff --git a/test/safe_by_default_test.rb b/test/safe_by_default_test.rb index 729e4002..82d56cf6 100644 --- a/test/safe_by_default_test.rb +++ b/test/safe_by_default_test.rb @@ -146,16 +146,14 @@ def test_add_foreign_key_invalid user.update!(order_id: nil) + migrate AddForeignKey + if ActiveRecord::VERSION::STRING.to_f >= 7.1 - migrate AddForeignKey - else + # fail if trying to add the same foreign key in a future migration assert_raises(ActiveRecord::StatementInvalid) do migrate AddForeignKey end - end - - # fail if trying to add the same foreign key in a future migration - assert_raises(ActiveRecord::StatementInvalid) do + else migrate AddForeignKey end