diff options
6 files changed, 25 insertions, 1 deletions
| diff --git a/actionpack/CHANGELOG.md b/actionpack/CHANGELOG.md index 180d802dbe..3fc3e06160 100644 --- a/actionpack/CHANGELOG.md +++ b/actionpack/CHANGELOG.md @@ -1,5 +1,11 @@  ## Rails 4.0.0 (unreleased) ## +*   Fixed `ActionView::Helpers::CaptureHelper#content_for` regression when trying to use it in +    a boolean statement. +    Fixes #9360. + +    *Nikolay Shebanov* +  *   `format: true` does not override existing format constraints.      Fixes #9466. diff --git a/actionpack/lib/action_view/helpers/capture_helper.rb b/actionpack/lib/action_view/helpers/capture_helper.rb index 4ec860d69a..1bad82159a 100644 --- a/actionpack/lib/action_view/helpers/capture_helper.rb +++ b/actionpack/lib/action_view/helpers/capture_helper.rb @@ -156,7 +156,7 @@ module ActionView            end            nil          else -          @view_flow.get(name) +          @view_flow.get(name).presence          end        end diff --git a/actionpack/test/template/capture_helper_test.rb b/actionpack/test/template/capture_helper_test.rb index 234ac3252d..938f1c3e54 100644 --- a/actionpack/test/template/capture_helper_test.rb +++ b/actionpack/test/template/capture_helper_test.rb @@ -137,6 +137,10 @@ class CaptureHelperTest < ActionView::TestCase      assert_equal 'bar', content_for(:title)    end +  def test_content_for_returns_nil_when_content_missing +    assert_equal nil, content_for(:some_missing_key) +  end +    def test_content_for_question_mark      assert ! content_for?(:title)      content_for :title, 'title' diff --git a/activerecord/CHANGELOG.md b/activerecord/CHANGELOG.md index a5d74418c4..384ec03334 100644 --- a/activerecord/CHANGELOG.md +++ b/activerecord/CHANGELOG.md @@ -1,5 +1,11 @@  ## Rails 4.0.0 (unreleased) ## +*   Fix bug that raises the wrong exception when the exception handled by PostgreSQL adapter +    doesn't respond to `#result`. +    Fixes #8617. + +    *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| | 
