aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMichael Schuerig <michael@schuerig.de>2009-04-05 01:42:21 +0200
committerMichael Koziarski <michael@koziarski.com>2009-06-26 16:52:55 +1200
commit00a5fd3d18ac908af688c5944922cf69c56e850b (patch)
treeab0acf2af0a1404701fe04386e10e1f12084b630
parent53a3eaa8603cf6e7a3c007f327fe5d3bb68de1ee (diff)
downloadrails-00a5fd3d18ac908af688c5944922cf69c56e850b.tar.gz
rails-00a5fd3d18ac908af688c5944922cf69c56e850b.tar.bz2
rails-00a5fd3d18ac908af688c5944922cf69c56e850b.zip
Translate foreign key violations to ActiveRecord::InvalidForeignKey exceptions.
Signed-off-by: Michael Koziarski <michael@koziarski.com>
-rwxr-xr-xactiverecord/lib/active_record/base.rb4
-rw-r--r--activerecord/lib/active_record/connection_adapters/mysql_adapter.rb2
-rw-r--r--activerecord/lib/active_record/connection_adapters/postgresql_adapter.rb2
-rw-r--r--activerecord/test/cases/adapter_test.rb8
4 files changed, 16 insertions, 0 deletions
diff --git a/activerecord/lib/active_record/base.rb b/activerecord/lib/active_record/base.rb
index defe1b56b6..027ab8af9e 100755
--- a/activerecord/lib/active_record/base.rb
+++ b/activerecord/lib/active_record/base.rb
@@ -71,6 +71,10 @@ module ActiveRecord #:nodoc:
class RecordNotUnique < StatementInvalid
end
+ # Raised when a record cannot be inserted or updated because it references a non-existent record.
+ class InvalidForeignKey < StatementInvalid
+ end
+
# Raised when number of bind variables in statement given to <tt>:condition</tt> key (for example, when using +find+ method)
# does not match number of expected variables.
#
diff --git a/activerecord/lib/active_record/connection_adapters/mysql_adapter.rb b/activerecord/lib/active_record/connection_adapters/mysql_adapter.rb
index 59bf01e774..ae065e6bc1 100644
--- a/activerecord/lib/active_record/connection_adapters/mysql_adapter.rb
+++ b/activerecord/lib/active_record/connection_adapters/mysql_adapter.rb
@@ -569,6 +569,8 @@ module ActiveRecord
case exception.errno
when 1062
RecordNotUnique.new(message)
+ when 1452
+ InvalidForeignKey.new(message)
else
super
end
diff --git a/activerecord/lib/active_record/connection_adapters/postgresql_adapter.rb b/activerecord/lib/active_record/connection_adapters/postgresql_adapter.rb
index e990052e09..24482aa19a 100644
--- a/activerecord/lib/active_record/connection_adapters/postgresql_adapter.rb
+++ b/activerecord/lib/active_record/connection_adapters/postgresql_adapter.rb
@@ -945,6 +945,8 @@ module ActiveRecord
case exception.message
when /duplicate key value violates unique constraint/
RecordNotUnique.new(message)
+ when /violates foreign key constraint/
+ InvalidForeignKey.new(message)
else
super
end
diff --git a/activerecord/test/cases/adapter_test.rb b/activerecord/test/cases/adapter_test.rb
index 8688fbee49..80530194ff 100644
--- a/activerecord/test/cases/adapter_test.rb
+++ b/activerecord/test/cases/adapter_test.rb
@@ -137,4 +137,12 @@ class AdapterTest < ActiveRecord::TestCase
@connection.execute "INSERT INTO subscribers(nick) VALUES('me')"
end
end
+
+ def test_foreign_key_violations_are_translated_to_specific_exception
+ unless @connection.adapter_name == 'SQLite'
+ assert_raises(ActiveRecord::InvalidForeignKey) do
+ @connection.execute "INSERT INTO fk_test_has_fk (fk_id) VALUES (0)"
+ end
+ end
+ end
end