mirror of
https://github.com/haml/haml.git
synced 2022-11-09 12:33:31 -05:00

git-svn-id: svn://hamptoncatlin.com/haml/branches/1.5dev@206 7063305b-7217-0410-af8c-cdc13e5119b9
94 lines
3.1 KiB
Ruby
94 lines
3.1 KiB
Ruby
#!/usr/bin/env ruby
|
|
|
|
require 'test/unit'
|
|
require File.dirname(__FILE__) + '/../../lib/haml'
|
|
require 'haml/engine'
|
|
|
|
class EngineTest < Test::Unit::TestCase
|
|
|
|
def render(text, options = {})
|
|
Haml::Engine.new(text, options).to_html
|
|
end
|
|
|
|
def test_empty_render_should_remain_empty
|
|
assert_equal('', render(''))
|
|
end
|
|
|
|
# This is ugly because Hashes are unordered; we don't always know the order
|
|
# in which attributes will be returned.
|
|
# There is probably a better way to do this.
|
|
def test_attributes_should_render_correctly
|
|
assert_equal("<div class='atlantis' style='ugly'>\n</div>", render(".atlantis{:style => 'ugly'}").chomp)
|
|
rescue
|
|
assert_equal("<div style='ugly' class='atlantis'>\n</div>", render(".atlantis{:style => 'ugly'}").chomp)
|
|
end
|
|
|
|
def test_ruby_code_should_work_inside_attributes
|
|
author = 'hcatlin'
|
|
assert_equal("<p class='3'>foo</p>", render("%p{:class => 1+2} foo").chomp)
|
|
end
|
|
|
|
def test_nil_should_render_empty_tag
|
|
assert_equal("<div class='no_attributes'>\n</div>",
|
|
render(".no_attributes{:nil => nil}").chomp)
|
|
end
|
|
|
|
def test_strings_should_get_stripped_inside_tags
|
|
assert_equal("<div class='stripped'>This should have no spaces in front of it</div>",
|
|
render(".stripped This should have no spaces in front of it").chomp)
|
|
end
|
|
|
|
def test_one_liner_should_be_one_line
|
|
assert_equal("<p>Hello</p>", render('%p Hello').chomp)
|
|
end
|
|
|
|
def test_long_liner_should_not_print_on_one_line
|
|
assert_equal("<div>\n #{'x' * 51}\n</div>", render("%div #{'x' * 51}").chomp)
|
|
end
|
|
|
|
def test_multi_render
|
|
engine = Haml::Engine.new("%strong Hi there!")
|
|
assert_equal("<strong>Hi there!</strong>\n", engine.to_html)
|
|
assert_equal("<strong>Hi there!</strong>\n", engine.to_html)
|
|
assert_equal("<strong>Hi there!</strong>\n", engine.to_html)
|
|
end
|
|
|
|
# Options tests
|
|
|
|
def test_stop_eval
|
|
assert_equal("", render("= 'Hello'", :suppress_eval => true))
|
|
end
|
|
|
|
def test_attr_wrapper
|
|
assert_equal("<p strange=*attrs*>\n</p>\n", render("%p{ :strange => 'attrs'}", :attr_wrapper => '*'))
|
|
assert_equal("<p escaped='quo\"te'>\n</p>\n", render("%p{ :escaped => 'quo\"te'}", :attr_wrapper => '"'))
|
|
assert_equal("<p escaped=\"q'uo"te\">\n</p>\n", render("%p{ :escaped => 'q\\'uo\"te'}", :attr_wrapper => '"'))
|
|
assert_equal("<?xml version=\"1.0\" encoding=\"utf-8\" ?>\n", render("!!! XML", :attr_wrapper => '"'))
|
|
end
|
|
|
|
def test_locals
|
|
assert_equal("<p>Paragraph!</p>\n", render("%p= text", :locals => { :text => "Paragraph!" }))
|
|
end
|
|
|
|
def test_precompiled
|
|
precompiled = <<-END
|
|
def _haml_render
|
|
_hamlout = @haml_stack[-1]
|
|
_erbout = _hamlout.buffer
|
|
|
|
_hamlout.open_tag("p", 0, nil, true, "", nil, nil, false)
|
|
@haml_lineno = 1
|
|
haml_temp = "Haml Rocks Socks"
|
|
haml_temp = _hamlout.push_script(haml_temp, 1, false)
|
|
_hamlout.close_tag("p", 0)
|
|
end
|
|
END
|
|
|
|
assert_equal("<p>Haml Rocks Socks</p>\n", render("%h1 I shall not be rendered", :precompiled => precompiled))
|
|
end
|
|
|
|
def test_comps
|
|
assert_equal(-1, "foo" <=> nil)
|
|
assert_equal(1, nil <=> "foo")
|
|
end
|
|
end
|