diff options
author | Rafael Mendonça França <rafaelmfranca@gmail.com> | 2013-02-28 13:32:36 -0800 |
---|---|---|
committer | Rafael Mendonça França <rafaelmfranca@gmail.com> | 2013-02-28 13:32:36 -0800 |
commit | 12cbc57aad153ecd140f917059e11b8d726094b4 (patch) | |
tree | 23098c166dc06a46cec7d6ae2a072cbd56d87ba0 | |
parent | c4f2f5b9d7902c280fb341560cf23c52c99e4e55 (diff) | |
parent | e2a4b7a506e36839771284942829cbbe8d40b377 (diff) | |
download | rails-12cbc57aad153ecd140f917059e11b8d726094b4.tar.gz rails-12cbc57aad153ecd140f917059e11b8d726094b4.tar.bz2 rails-12cbc57aad153ecd140f917059e11b8d726094b4.zip |
Merge pull request #9493 from kennyj/fix_wrong_exception
Wrong exception is occured when raising no translatable exception
Closes #8617
3 files changed, 13 insertions, 0 deletions
diff --git a/activerecord/CHANGELOG.md b/activerecord/CHANGELOG.md index a5d74418c4..63eda83b5e 100644 --- a/activerecord/CHANGELOG.md +++ b/activerecord/CHANGELOG.md @@ -1,5 +1,10 @@ ## Rails 4.0.0 (unreleased) ## +* Fix a problem wrong exception is occured + when raising no translatable exception in PostgreSQL. + + *kennyj* + * Support PostgreSQL specific column types when using `change_table`. Fixes #9480. diff --git a/activerecord/lib/active_record/connection_adapters/postgresql_adapter.rb b/activerecord/lib/active_record/connection_adapters/postgresql_adapter.rb index b39eb058ae..c91e1b3fb9 100644 --- a/activerecord/lib/active_record/connection_adapters/postgresql_adapter.rb +++ b/activerecord/lib/active_record/connection_adapters/postgresql_adapter.rb @@ -675,6 +675,8 @@ module ActiveRecord UNIQUE_VIOLATION = "23505" def translate_exception(exception, message) + return exception unless exception.respond_to?(:result) + case exception.result.try(:error_field, PGresult::PG_DIAG_SQLSTATE) when UNIQUE_VIOLATION RecordNotUnique.new(message, exception) diff --git a/activerecord/test/cases/adapters/postgresql/postgresql_adapter_test.rb b/activerecord/test/cases/adapters/postgresql/postgresql_adapter_test.rb index 872204c644..05e0f0e192 100644 --- a/activerecord/test/cases/adapters/postgresql/postgresql_adapter_test.rb +++ b/activerecord/test/cases/adapters/postgresql/postgresql_adapter_test.rb @@ -250,6 +250,12 @@ module ActiveRecord assert_equal "DISTINCT posts.title, posts.updater_id AS alias_0", @connection.distinct("posts.title", ["posts.updater_id desc nulls last"]) end + def test_raise_error_when_cannot_translate_exception + assert_raise TypeError do + @connection.send(:log, nil) { @connection.execute(nil) } + end + end + private def insert(ctx, data) binds = data.map { |name, value| |