aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJosé Valim <jose.valim@gmail.com>2010-10-10 13:17:01 +0200
committerJosé Valim <jose.valim@gmail.com>2010-10-10 13:17:04 +0200
commitffa32714bd339ae32355a6827750e1af81454a1b (patch)
tree9663ebb516cb396861f719d1892e7f901007b7a3
parentcba395dab9812d86d48cc0574061cd6dcd18009b (diff)
downloadrails-ffa32714bd339ae32355a6827750e1af81454a1b.tar.gz
rails-ffa32714bd339ae32355a6827750e1af81454a1b.tar.bz2
rails-ffa32714bd339ae32355a6827750e1af81454a1b.zip
Add some unit tests to Template#refresh.
-rw-r--r--actionpack/test/template/template_test.rb32
1 files changed, 28 insertions, 4 deletions
diff --git a/actionpack/test/template/template_test.rb b/actionpack/test/template/template_test.rb
index eb2d4aab36..34679962b2 100644
--- a/actionpack/test/template/template_test.rb
+++ b/actionpack/test/template/template_test.rb
@@ -1,9 +1,16 @@
require "abstract_unit"
+require "logger"
class TestERBTemplate < ActiveSupport::TestCase
ERBHandler = ActionView::Template::Handlers::ERB.new
class Context
+ class LookupContext
+ def disable_cache
+ yield
+ end
+ end
+
def initialize
@output_buffer = "original"
@_virtual_path = nil
@@ -22,8 +29,11 @@ class TestERBTemplate < ActiveSupport::TestCase
)
end
+ def lookup_context
+ @lookup_context ||= LookupContext.new
+ end
+
def logger
- require "logger"
Logger.new(STDERR)
end
@@ -37,11 +47,11 @@ class TestERBTemplate < ActiveSupport::TestCase
end
def render(locals = {})
- @template.render(@obj, locals)
+ @template.render(@context, locals)
end
def setup
- @obj = Context.new
+ @context = Context.new
end
def test_basic_template
@@ -70,7 +80,7 @@ class TestERBTemplate < ActiveSupport::TestCase
def test_restores_buffer
@template = new_template
assert_equal "Hello", render
- assert_equal "original", @obj.my_buffer
+ assert_equal "original", @context.my_buffer
end
def test_virtual_path
@@ -80,6 +90,20 @@ class TestERBTemplate < ActiveSupport::TestCase
assert_equal "hellopartialhello", render
end
+ def test_refresh
+ @template = new_template("Hello", :virtual_path => "test/foo")
+ @template.locals = [:key]
+ @context.lookup_context.expects(:find_template).with("foo", "test", false, [:key]).returns("template")
+ assert_equal "template", @template.refresh(@context)
+ end
+
+ def test_refresh_raises_an_error_without_virtual_path
+ @template = new_template("Hello", :virtual_path => nil)
+ assert_raise RuntimeError, /OMG/ do
+ @template.refresh(@context)
+ end
+ end
+
if "ruby".encoding_aware?
def test_resulting_string_is_utf8
@template = new_template