diff options
author | Henrik Nygren <nygrenh@gmail.com> | 2015-05-14 09:42:55 +0300 |
---|---|---|
committer | Henrik Nygren <nygrenh@gmail.com> | 2015-05-14 10:46:44 +0300 |
commit | bef9484cf867ab261891d3431782e60c4e17f87f (patch) | |
tree | 20d2436600193a9fcd756b564aeb0153c8425ecb /actionview/test | |
parent | 987a45307f8ca0b8b6cbab3763180cbe4eee18b7 (diff) | |
download | rails-bef9484cf867ab261891d3431782e60c4e17f87f.tar.gz rails-bef9484cf867ab261891d3431782e60c4e17f87f.tar.bz2 rails-bef9484cf867ab261891d3431782e60c4e17f87f.zip |
Do not put partial name to local_assigns when rendering without an object
When one rendered a partial template without specifying an object
or a collection (e.g. <%= render partial: 'partial_name' %>), Rails
would make an object called :partial_name available in local_assigns.
I don't think this was the intended behavior, since no local variable
called 'partial_name' gets defined in the view.
Diffstat (limited to 'actionview/test')
-rw-r--r-- | actionview/test/fixtures/test/_partial_name_in_local_assigns.erb | 1 | ||||
-rw-r--r-- | actionview/test/template/render_test.rb | 8 |
2 files changed, 9 insertions, 0 deletions
diff --git a/actionview/test/fixtures/test/_partial_name_in_local_assigns.erb b/actionview/test/fixtures/test/_partial_name_in_local_assigns.erb new file mode 100644 index 0000000000..28ee9f41c5 --- /dev/null +++ b/actionview/test/fixtures/test/_partial_name_in_local_assigns.erb @@ -0,0 +1 @@ +<%= local_assigns.has_key?(:partial_name_in_local_assigns) %>
\ No newline at end of file diff --git a/actionview/test/template/render_test.rb b/actionview/test/template/render_test.rb index 22665b6844..27bbb9b6c1 100644 --- a/actionview/test/template/render_test.rb +++ b/actionview/test/template/render_test.rb @@ -277,6 +277,14 @@ module RenderTestCases assert_nil @view.render(:partial => "test/customer", :collection => nil) end + def test_render_partial_without_object_does_not_put_partial_name_to_local_assigns + assert_equal 'false', @view.render(partial: 'test/partial_name_in_local_assigns') + end + + def test_render_partial_with_nil_object_puts_partial_name_to_local_assigns + assert_equal 'true', @view.render(partial: 'test/partial_name_in_local_assigns', object: nil) + end + def test_render_partial_with_nil_values_in_collection assert_equal "Hello: davidHello: Anonymous", @view.render(:partial => "test/customer", :collection => [ Customer.new("david"), nil ]) end |