2011-05-11 03:44:02 -04:00
|
|
|
require File.expand_path('../helper', __FILE__)
|
2010-09-11 08:34:41 -04:00
|
|
|
|
2011-04-15 05:00:07 -04:00
|
|
|
MarkdownTest = proc do
|
2010-09-11 08:34:41 -04:00
|
|
|
def markdown_app(&block)
|
|
|
|
mock_app do
|
|
|
|
set :views, File.dirname(__FILE__) + '/views'
|
|
|
|
get '/', &block
|
|
|
|
end
|
|
|
|
get '/'
|
|
|
|
end
|
|
|
|
|
2011-04-15 05:00:07 -04:00
|
|
|
def setup
|
|
|
|
Tilt.prefer engine, 'markdown', 'mkd', 'md'
|
|
|
|
super
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'uses the correct engine' do
|
|
|
|
assert_equal engine, Tilt[:md]
|
|
|
|
assert_equal engine, Tilt[:mkd]
|
|
|
|
assert_equal engine, Tilt[:markdown]
|
|
|
|
end
|
|
|
|
|
2010-09-11 08:34:41 -04:00
|
|
|
it 'renders inline markdown strings' do
|
|
|
|
markdown_app { markdown '# Hiya' }
|
|
|
|
assert ok?
|
2011-04-15 05:00:07 -04:00
|
|
|
assert_like "<h1>Hiya</h1>\n", body
|
2010-09-11 08:34:41 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
it 'renders .markdown files in views path' do
|
|
|
|
markdown_app { markdown :hello }
|
|
|
|
assert ok?
|
2011-04-15 05:00:07 -04:00
|
|
|
assert_like "<h1>Hello From Markdown</h1>", body
|
2010-09-11 08:34:41 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
it "raises error if template not found" do
|
|
|
|
mock_app { get('/') { markdown :no_such_template } }
|
|
|
|
assert_raise(Errno::ENOENT) { get('/') }
|
|
|
|
end
|
2011-04-15 05:14:23 -04:00
|
|
|
|
|
|
|
it "renders with inline layouts" do
|
|
|
|
mock_app do
|
|
|
|
layout { 'THIS. IS. #{yield.upcase}!' }
|
|
|
|
get('/') { markdown 'Sparta', :layout_engine => :str }
|
|
|
|
end
|
|
|
|
get '/'
|
|
|
|
assert ok?
|
|
|
|
assert_like 'THIS. IS. <P>SPARTA</P>!', body
|
|
|
|
end
|
|
|
|
|
|
|
|
it "renders with file layouts" do
|
|
|
|
markdown_app { markdown 'Hello World', :layout => :layout2, :layout_engine => :erb }
|
|
|
|
assert ok?
|
|
|
|
assert_body "ERB Layout!\n<p>Hello World</p>"
|
|
|
|
end
|
|
|
|
|
|
|
|
it "can be used in a nested fashion for partials and whatnot" do
|
|
|
|
mock_app do
|
|
|
|
template(:inner) { "hi" }
|
|
|
|
template(:outer) { "<outer><%= markdown :inner %></outer>" }
|
|
|
|
get '/' do
|
|
|
|
erb :outer
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
get '/'
|
|
|
|
assert ok?
|
|
|
|
assert_like '<outer><p>hi</p></outer>', body
|
|
|
|
end
|
2010-09-11 08:34:41 -04:00
|
|
|
end
|
2011-01-25 03:27:15 -05:00
|
|
|
|
2011-04-15 05:00:07 -04:00
|
|
|
# Will generate RDiscountTest, KramdownTest, etc.
|
|
|
|
Tilt.mappings['md'].each do |t|
|
|
|
|
begin
|
|
|
|
t.new { "" }
|
|
|
|
klass = Class.new(Test::Unit::TestCase) { define_method(:engine) { t }}
|
|
|
|
klass.class_eval(&MarkdownTest)
|
|
|
|
Object.const_set t.name[/[^:]+(?=Template$)/] << "Test", klass
|
|
|
|
rescue LoadError
|
|
|
|
warn "#{$!}: skipping markdown tests with #{t}"
|
|
|
|
end
|
2010-09-11 08:34:41 -04:00
|
|
|
end
|