vendor/plugins/haml/test/haml/template_test.rb in radiant-0.6.7 vs vendor/plugins/haml/test/haml/template_test.rb in radiant-0.6.8
- old
+ new
@@ -1,27 +1,33 @@
#!/usr/bin/env ruby
-require File.dirname(__FILE__) + '/test_helper'
+require File.dirname(__FILE__) + '/../test_helper'
require 'haml/template'
require File.dirname(__FILE__) + '/mocks/article'
-module TestFilter
+module Haml::Filters::Test
include Haml::Filters::Base
def render(text)
"TESTING HAHAHAHA!"
end
end
+module Haml::Helpers
+ def test_partial(name, locals = {})
+ Haml::Engine.new(File.read(File.join(TemplateTest::TEMPLATE_PATH, "_#{name}.haml"))).render(self, locals)
+ end
+end
+
class TemplateTest < Test::Unit::TestCase
- @@templates = %w{ very_basic standard helpers
+ TEMPLATE_PATH = File.join(File.dirname(__FILE__), "templates")
+ TEMPLATES = %w{ very_basic standard helpers
whitespace_handling original_engine list helpful
silent_script tag_parsing just_stuff partials
- filters }
+ filters nuke_outer_whitespace nuke_inner_whitespace }
def setup
- Haml::Template.options = { :filters => { 'test'=>TestFilter } }
- @base = ActionView::Base.new(File.dirname(__FILE__) + "/templates/", {'article' => Article.new, 'foo' => 'value one'})
+ @base = ActionView::Base.new(TEMPLATE_PATH, 'article' => Article.new, 'foo' => 'value one')
@base.send(:evaluate_assigns)
# This is used by form_for.
# It's usually provided by ActionController::Base.
def @base.protect_against_forgery?; false; end
@@ -37,55 +43,45 @@
@result
end
def assert_renders_correctly(name, &render_method)
render_method ||= proc { |name| @base.render(name) }
- test = Proc.new do |rendered|
- load_result(name).split("\n").zip(rendered.split("\n")).each_with_index do |pair, line|
- message = "template: #{name}\nline: #{line}"
- assert_equal(pair.first, pair.last, message)
- end
+
+ load_result(name).split("\n").zip(render_method[name].split("\n")).each_with_index do |pair, line|
+ message = "template: #{name}\nline: #{line}"
+ assert_equal(pair.first, pair.last, message)
end
- begin
- test.call(render_method[name])
- rescue ActionView::TemplateError => e
- if e.message =~ /Can't run [\w:]+ filter; required (one of|file) ((?:'\w+'(?: or )?)+)(, but none were found| not found)/
- puts "\nCouldn't require #{$2}; skipping a test."
- else
- raise e
- end
+ rescue ActionView::TemplateError => e
+ if e.message =~ /Can't run [\w:]+ filter; required (one of|file) ((?:'\w+'(?: or )?)+)(, but none were found| not found)/
+ puts "\nCouldn't require #{$2}; skipping a test."
+ else
+ raise e
end
end
def test_empty_render_should_remain_empty
assert_equal('', render(''))
end
- def test_templates_should_render_correctly
- @@templates.each do |template|
+ TEMPLATES.each do |template|
+ define_method "test_template_should_render_correctly [template: #{template}] " do
assert_renders_correctly template
end
end
def test_templates_should_render_correctly_with_render_proc
- @@templates.each do |template|
- assert_renders_correctly(template) do |name|
- engine = Haml::Engine.new(File.read(File.dirname(__FILE__) + "/templates/#{name}.haml"), :filters => { 'test'=>TestFilter })
- engine.render_proc(@base).call
- end
+ assert_renders_correctly("standard") do |name|
+ engine = Haml::Engine.new(File.read(File.dirname(__FILE__) + "/templates/#{name}.haml"))
+ engine.render_proc(@base).call
end
end
-
+
def test_templates_should_render_correctly_with_def_method
- @@templates.each do |template|
- assert_renders_correctly(template) do |name|
- method = "render_haml_" + name.gsub(/[^a-zA-Z0-9]/, '_')
-
- engine = Haml::Engine.new(File.read(File.dirname(__FILE__) + "/templates/#{name}.haml"), :filters => { 'test'=>TestFilter })
- engine.def_method(@base, method)
- @base.send(method)
- end
+ assert_renders_correctly("standard") do |name|
+ engine = Haml::Engine.new(File.read(File.dirname(__FILE__) + "/templates/#{name}.haml"))
+ engine.def_method(@base, "render_standard")
+ @base.render_standard
end
end
def test_action_view_templates_render_correctly
@base.instance_variable_set("@content_for_layout", 'Lorem ipsum dolor sit amet')
@@ -111,22 +107,9 @@
assert_equal("<p class='hcatlin'>foo</p>", render("%p{:class => @author} foo").chomp)
end
def test_template_renders_should_eval
assert_equal("2\n", render("= 1+1"))
- end
-
- def test_rhtml_still_renders
- # Make sure it renders normally
- res = @base.render("../rhtml/standard")
- assert !(res.nil? || res.empty?)
-
- # Register Haml stuff in @base...
- @base.render("standard")
-
- # Does it still render?
- res = @base.render("../rhtml/standard")
- assert !(res.nil? || res.empty?)
end
def test_haml_options
Haml::Template.options = { :suppress_eval => true }
assert_equal({ :suppress_eval => true }, Haml::Template.options)