diff options
author | Alexey Vakhov <vakhov@gmail.com> | 2012-04-11 12:45:28 +0600 |
---|---|---|
committer | Alexey Vakhov <vakhov@gmail.com> | 2012-05-04 23:31:09 +0400 |
commit | 0d19a081ee12b46791d8709e5c0898429e2ef91f (patch) | |
tree | 26ab14ac12a5516c8663bec767d5f6a93ce95ea2 /actionpack | |
parent | 4bd05a7bdc5003c9ebb090dcb0dc4949e4fb8ad3 (diff) | |
download | rails-0d19a081ee12b46791d8709e5c0898429e2ef91f.tar.gz rails-0d19a081ee12b46791d8709e5c0898429e2ef91f.tar.bz2 rails-0d19a081ee12b46791d8709e5c0898429e2ef91f.zip |
Improve assert_template layout checking
Diffstat (limited to 'actionpack')
-rw-r--r-- | actionpack/lib/action_controller/test_case.rb | 18 | ||||
-rw-r--r-- | actionpack/test/controller/action_pack_assertions_test.rb | 15 |
2 files changed, 30 insertions, 3 deletions
diff --git a/actionpack/lib/action_controller/test_case.rb b/actionpack/lib/action_controller/test_case.rb index f664da4ffe..ad02375f12 100644 --- a/actionpack/lib/action_controller/test_case.rb +++ b/actionpack/lib/action_controller/test_case.rb @@ -22,6 +22,9 @@ module ActionController path = payload[:layout] if path @layouts[path] += 1 + if path =~ /^layouts\/(.*)/ + @layouts[$1] += 1 + end end end @@ -61,6 +64,15 @@ module ActionController # # assert that the exact template "admin/posts/new" was rendered # assert_template %r{\Aadmin/posts/new\Z} # + # # assert that the layout 'admin' was rendered + # assert_template :layout => 'admin' + # assert_template :layout => 'layouts/admin' + # assert_template :layout => :admin + # + # # assert that no layout was rendered + # assert_template :layout => nil + # assert_template :layout => false + # # # assert that the "_customer" partial was rendered twice # assert_template :partial => '_customer', :count => 2 # @@ -98,11 +110,11 @@ module ActionController expected_layout, @layouts.keys) case expected_layout - when String - assert_includes @layouts.keys, expected_layout, msg + when String, Symbol + assert_includes @layouts.keys, expected_layout.to_s, msg when Regexp assert(@layouts.keys.any? {|l| l =~ expected_layout }, msg) - when nil + when nil, false assert(@layouts.empty?, msg) end end diff --git a/actionpack/test/controller/action_pack_assertions_test.rb b/actionpack/test/controller/action_pack_assertions_test.rb index bc6630a02d..9b0d4d0f4c 100644 --- a/actionpack/test/controller/action_pack_assertions_test.rb +++ b/actionpack/test/controller/action_pack_assertions_test.rb @@ -500,6 +500,21 @@ class AssertTemplateTest < ActionController::TestCase assert_template :layout => nil end + def test_passed_with_no_layout_false + get :hello_world + assert_template :layout => false + end + + def test_passes_with_correct_layout_without_layouts_prefix + get :render_with_layout + assert_template :layout => "standard" + end + + def test_passes_with_correct_layout_symbol + get :render_with_layout + assert_template :layout => :standard + end + def test_assert_template_reset_between_requests get :hello_world assert_template 'test/hello_world' |