1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55
|
require 'contest'
require 'tilt'
begin
require 'rdiscount'
class RDiscountTemplateTest < Test::Unit::TestCase
test "registered for '.md' files" do
assert Tilt.mappings['md'].include?(Tilt::RDiscountTemplate)
end
test "registered for '.mkd' files" do
assert Tilt.mappings['mkd'].include?(Tilt::RDiscountTemplate)
end
test "registered for '.markdown' files" do
assert Tilt.mappings['markdown'].include?(Tilt::RDiscountTemplate)
end
test "registered above BlueCloth" do
%w[md mkd markdown].each do |ext|
mappings = Tilt.mappings[ext]
blue_idx = mappings.index(Tilt::BlueClothTemplate)
rdis_idx = mappings.index(Tilt::RDiscountTemplate)
assert rdis_idx < blue_idx,
"#{rdis_idx} should be lower than #{blue_idx}"
end
end
test "preparing and evaluating templates on #render" do
template = Tilt::RDiscountTemplate.new { |t| "# Hello World!" }
assert_equal "<h1>Hello World!</h1>\n", template.render
end
test "can be rendered more than once" do
template = Tilt::RDiscountTemplate.new { |t| "# Hello World!" }
3.times { assert_equal "<h1>Hello World!</h1>\n", template.render }
end
test "smartypants when :smart is set" do
template = Tilt::RDiscountTemplate.new(:smart => true) { |t|
"OKAY -- 'Smarty Pants'" }
assert_equal "<p>OKAY — ‘Smarty Pants’</p>\n",
template.render
end
test "stripping HTML when :filter_html is set" do
template = Tilt::RDiscountTemplate.new(:filter_html => true) { |t|
"HELLO <blink>WORLD</blink>" }
assert_equal "<p>HELLO <blink>WORLD</blink></p>\n", template.render
end
end
rescue LoadError => boom
warn "Tilt::RDiscountTemplate (disabled)"
end
|