require File.expand_path(File.dirname(__FILE__) + '/helper') require File.expand_path(File.dirname(__FILE__) + '/fixtures/markup_app/app') describe "TagHelpers" do def app MarkupDemo end context 'for #tag method' do should("support tags with no content no attributes") do assert_has_tag(:br) { tag(:br) } end should("support tags with no content with attributes") do actual_html = tag(:br, :style => 'clear:both', :class => 'yellow') assert_has_tag(:br, :class => 'yellow', :style=>'clear:both') { actual_html } end should "support selected attribute by using 'selected' if true" do actual_html = tag(:option, :selected => true) assert_has_tag('option', :selected => 'selected') { actual_html } end should "support data attributes" do actual_html = tag(:a, :data => { :remote => true, :method => 'post'}) assert_has_tag(:a, 'data-remote' => 'true', 'data-method' => 'post') { actual_html } end should "support nested attributes" do actual_html = tag(:div, :data => {:dojo => {:type => 'dijit.form.TextBox', :props => 'readOnly: true'}}) assert_has_tag(:div, 'data-dojo-type' => 'dijit.form.TextBox', 'data-dojo-props' => 'readOnly: true') { actual_html } end should "support open tags" do actual_html = tag(:p, { :class => 'demo' }, true) assert_equal "
", actual_html
end
should "escape html" do
actual_html = tag(:br, :class => 'Example
", actual_html
end
end
context 'for #content_tag method' do
should "support tags with content as parameter" do
actual_html = content_tag(:p, "Demo", :class => 'large', :id => 'thing')
assert_has_tag('p.large#thing', :content => "Demo") { actual_html }
end
should "support tags with content as block" do
actual_html = content_tag(:p, :class => 'large', :id => 'star') { "Demo" }
assert_has_tag('p.large#star', :content => "Demo") { actual_html }
end
should "escape non-html-safe content" do
actual_html = content_tag(:p, :class => 'large', :id => 'star') { "<>" }
assert_has_tag('p.large#star') { actual_html }
assert_match('<>', actual_html)
end
should "not escape html-safe content" do
actual_html = content_tag(:p, :class => 'large', :id => 'star') { "<>" }
assert_has_tag('p.large#star', :content => "<>") { actual_html }
end
should "support tags with erb" do
visit '/erb/content_tag'
assert_have_selector :p, :content => "Test 1", :class => 'test', :id => 'test1'
assert_have_selector :p, :content => "Test 2"
assert_have_selector :p, :content => "Test 3"
assert_have_selector :p, :content => "Test 4"
end
should "support tags with haml" do
visit '/haml/content_tag'
assert_have_selector :p, :content => "Test 1", :class => 'test', :id => 'test1'
assert_have_selector :p, :content => "Test 2"
assert_have_selector :p, :content => "Test 3", :class => 'test', :id => 'test3'
assert_have_selector :p, :content => "Test 4"
end
should "support tags with slim" do
visit '/slim/content_tag'
assert_have_selector :p, :content => "Test 1", :class => 'test', :id => 'test1'
assert_have_selector :p, :content => "Test 2"
assert_have_selector :p, :content => "Test 3", :class => 'test', :id => 'test3'
assert_have_selector :p, :content => "Test 4"
end
end
context 'for #input_tag method' do
should "support field with type" do
assert_has_tag('input[type=text]') { input_tag(:text) }
end
should "support field with type and options" do
actual_html = input_tag(:text, :class => "first", :id => 'texter')
assert_has_tag('input.first#texter[type=text]') { actual_html }
end
should "support checked attribute by using 'checked' if true" do
actual_html = input_tag(:checkbox, :checked => true)
assert_has_tag('input[type=checkbox]', :checked => 'checked') { actual_html }
end
should "remove checked attribute if false" do
actual_html = input_tag(:checkbox, :checked => false)
assert_has_no_tag('input[type=checkbox][checked=false]') { actual_html }
end
should "support disabled attribute by using 'disabled' if true" do
actual_html = input_tag(:checkbox, :disabled => true)
assert_has_tag('input[type=checkbox]', :disabled => 'disabled') { actual_html }
end
end
end