Efficiency: Sanitize Once

Envoke the HTML5lib Sanitizer just once (when the content is finally rendered),
rather than each time it passes through the chunk-handler.
This commit is contained in:
Jacques Distler 2008-05-15 01:22:13 -05:00
parent cd5c19e530
commit 5ca0760f7c
4 changed files with 100 additions and 112 deletions

View file

@ -25,19 +25,16 @@ module Engines
class Textile < AbstractEngine class Textile < AbstractEngine
def mask def mask
require 'sanitize'
require 'redcloth' require 'redcloth'
redcloth = RedCloth.new(@content, [:hard_breaks] + @content.options[:engine_opts]) redcloth = RedCloth.new(@content, [:hard_breaks] + @content.options[:engine_opts])
redcloth.filter_html = false redcloth.filter_html = false
redcloth.no_span_caps = false redcloth.no_span_caps = false
html = redcloth.to_html(:textile) html = redcloth.to_html(:textile)
sanitize_xhtml(html)
end end
end end
class Markdown < AbstractEngine class Markdown < AbstractEngine
def mask def mask
require 'sanitize'
require 'maruku' require 'maruku'
require 'maruku/ext/math' require 'maruku/ext/math'
@ -48,10 +45,8 @@ module Engines
:author => @content.options[:engine_opts][:author], :author => @content.options[:engine_opts][:author],
:title => @content.options[:engine_opts][:title]}) :title => @content.options[:engine_opts][:title]})
@content.options[:renderer].s5_theme = my_content.s5_theme @content.options[:renderer].s5_theme = my_content.s5_theme
sanitize_xhtml(my_content.to_s5)
else else
html = sanitize_rexml(Maruku.new(@content.delete("\r"), html = Maruku.new(@content.delete("\r"), {:math_enabled => false}).to_html
{:math_enabled => false}).to_html_tree)
html.gsub(/\A<div class="maruku_wrapper_div">\n?(.*?)\n?<\/div>\Z/m, '\1') html.gsub(/\A<div class="maruku_wrapper_div">\n?(.*?)\n?<\/div>\Z/m, '\1')
end end
@ -60,7 +55,6 @@ module Engines
class MarkdownMML < AbstractEngine class MarkdownMML < AbstractEngine
def mask def mask
require 'sanitize'
require 'maruku' require 'maruku'
require 'maruku/ext/math' require 'maruku/ext/math'
@ -72,35 +66,30 @@ module Engines
:author => @content.options[:engine_opts][:author], :author => @content.options[:engine_opts][:author],
:title => @content.options[:engine_opts][:title]}) :title => @content.options[:engine_opts][:title]})
@content.options[:renderer].s5_theme = my_content.s5_theme @content.options[:renderer].s5_theme = my_content.s5_theme
sanitize_xhtml(my_content.to_s5) my_content.to_s5
else else
html = sanitize_rexml(Maruku.new(@content.delete("\r"), html = Maruku.new(@content.delete("\r"),
{:math_enabled => true, {:math_enabled => true,
:math_numbered => ['\\[','\\begin{equation}']}).to_html_tree) :math_numbered => ['\\[','\\begin{equation}']}).to_html
html.gsub(/\A<div class="maruku_wrapper_div">\n?(.*?)\n?<\/div>\Z/m, '\1') html.gsub(/\A<div class="maruku_wrapper_div">\n?(.*?)\n?<\/div>\Z/m, '\1')
end end
end end
end end
class Mixed < AbstractEngine class Mixed < AbstractEngine
def mask def mask
require 'sanitize'
require 'redcloth' require 'redcloth'
redcloth = RedCloth.new(@content, @content.options[:engine_opts]) redcloth = RedCloth.new(@content, @content.options[:engine_opts])
redcloth.filter_html = false redcloth.filter_html = false
redcloth.no_span_caps = false redcloth.no_span_caps = false
html = redcloth.to_html html = redcloth.to_html
sanitize_xhtml(html)
end end
end end
class RDoc < AbstractEngine class RDoc < AbstractEngine
def mask def mask
require 'sanitize'
require_dependency 'rdocsupport' require_dependency 'rdocsupport'
html = RDocSupport::RDocFormatter.new(@content).to_html html = RDocSupport::RDocFormatter.new(@content).to_html
sanitize_xhtml(html)
end end
end end

View file

@ -4,8 +4,8 @@ require 'chunks/category'
require_dependency 'chunks/include' require_dependency 'chunks/include'
require_dependency 'chunks/wiki' require_dependency 'chunks/wiki'
require_dependency 'chunks/literal' require_dependency 'chunks/literal'
#require_dependency 'chunks/uri'
require 'chunks/nowiki' require 'chunks/nowiki'
require 'sanitize'
# Wiki content is just a string that can process itself with a chain of # Wiki content is just a string that can process itself with a chain of
# actions. The actions can modify wiki content so that certain parts of # actions. The actions can modify wiki content so that certain parts of
@ -192,7 +192,7 @@ class WikiContent < String
chunk.unmask_text chunk.unmask_text
end end
end end
self self.replace sanitize_xhtml(self)
end end
def page_name def page_name

View file

@ -80,7 +80,7 @@ class FileControllerTest < Test::Unit::TestCase
renderer = PageRenderer.new renderer = PageRenderer.new
@wiki.revise_page('wiki1', 'HomePage', '[[rails-e2e.gif:pic]]', @wiki.revise_page('wiki1', 'HomePage', '[[rails-e2e.gif:pic]]',
Time.now, 'AnonymousBrave', renderer) Time.now, 'AnonymousBrave', renderer)
assert_equal "<p><span class=\"newWikiWord\">rails-e2e.gif<a href=\"../file/rails-e2e.gif\">" + assert_equal "<p><span class='newWikiWord'>rails-e2e.gif<a href='../file/rails-e2e.gif'>" +
"?</a></span></p>", "?</a></span></p>",
renderer.display_content renderer.display_content

View file

@ -14,14 +14,14 @@ class PageRendererTest < Test::Unit::TestCase
@web.add_page('SecondPage', 'Yo, yo. Have you EverBeenHated', @web.add_page('SecondPage', 'Yo, yo. Have you EverBeenHated',
Time.now, 'DavidHeinemeierHansson', test_renderer) Time.now, 'DavidHeinemeierHansson', test_renderer)
assert_equal('<p>Yo, yo. Have you <span class="newWikiWord">Ever Been Hated' + assert_equal("<p>Yo, yo. Have you <span class='newWikiWord'>Ever Been Hated" +
'<a href="../show/EverBeenHated">?</a></span></p>', "<a href='../show/EverBeenHated'>?</a></span></p>",
rendered_content(@web.page("SecondPage"))) rendered_content(@web.page("SecondPage")))
@web.add_page('EverBeenHated', 'Yo, yo. Have you EverBeenHated', Time.now, @web.add_page('EverBeenHated', 'Yo, yo. Have you EverBeenHated', Time.now,
'DavidHeinemeierHansson', test_renderer) 'DavidHeinemeierHansson', test_renderer)
assert_equal('<p>Yo, yo. Have you <a class="existingWikiWord" ' + assert_equal("<p>Yo, yo. Have you <a class='existingWikiWord' " +
'href="../show/EverBeenHated">Ever Been Hated</a></p>', "href='../show/EverBeenHated'>Ever Been Hated</a></p>",
rendered_content(@web.page("SecondPage"))) rendered_content(@web.page("SecondPage")))
end end
@ -42,17 +42,17 @@ class PageRendererTest < Test::Unit::TestCase
end end
def test_content_with_wiki_links def test_content_with_wiki_links
assert_equal '<p><span class="newWikiWord">His Way<a href="../show/HisWay">?</a></span> ' + assert_equal "<p><span class='newWikiWord'>His Way<a href='../show/HisWay'>?</a></span> " +
'would be <a class="existingWikiWord" href="../show/MyWay">My Way</a> ' + "would be <a class='existingWikiWord' href='../show/MyWay'>My Way</a> " +
'<math class="maruku-mathml" display="inline" xmlns="http://www.w3.org/1998/Math/MathML">' + "<math class='maruku-mathml' display='inline' xmlns='http://www.w3.org/1998/Math/MathML'>" +
'<mi>sin</mi><mo stretchy="false">(</mo><mi>x</mi><mo stretchy="false">)</mo><semantics>' + "<mi>sin</mi><mo stretchy='false'>(</mo><mi>x</mi><mo stretchy='false'>)</mo><semantics>" +
'<annotation-xml encoding="SVG1.1"><svg></svg></annotation-xml></semantics></math> in kinda ' + "<annotation-xml encoding='SVG1.1'><svg/></annotation-xml></semantics></math> in kinda " +
'<a class="existingWikiWord" href="../show/ThatWay">That Way</a> in ' + "<a class='existingWikiWord' href='../show/ThatWay'>That Way</a> in " +
'<span class="newWikiWord">His Way<a href="../show/HisWay">?</a></span> ' + "<span class='newWikiWord'>His Way<a href='../show/HisWay'>?</a></span> " +
%{though <a class="existingWikiWord" href="../show/MyWay">My Way</a> OverThere \xE2\x80\x93 see } + %{though <a class='existingWikiWord' href='../show/MyWay'>My Way</a> OverThere \xE2\x80\x93 see } +
'<a class="existingWikiWord" href="../show/SmartEngine">Smart Engine</a> in that ' + "<a class='existingWikiWord' href='../show/SmartEngine'>Smart Engine</a> in that " +
'<span class="newWikiWord">Smart Engine GUI' + "<span class='newWikiWord'>Smart Engine GUI" +
'<a href="../show/SmartEngineGUI">?</a></span></p>', "<a href='../show/SmartEngineGUI'>?</a></span></p>",
test_renderer(@revision).display_content test_renderer(@revision).display_content
end end
@ -60,31 +60,31 @@ class PageRendererTest < Test::Unit::TestCase
set_web_property :markup, :markdownMML set_web_property :markup, :markdownMML
assert_markup_parsed_as( assert_markup_parsed_as(
%{<p>equation <math class="maruku-mathml" } + %{<p>equation <math class='maruku-mathml' } +
%{display="inline" xmlns="http://www.w3.org/1998/Math/MathML">} + %{display='inline' xmlns='http://www.w3.org/1998/Math/MathML'>} +
%{<mi>sin</mi><mo stretchy="false">(</mo><mi>x</mi><mo stretchy="false">)</mo></math></p>}, %{<mi>sin</mi><mo stretchy='false'>(</mo><mi>x</mi><mo stretchy='false'>)</mo></math></p>},
"equation $\\sin(x)$") "equation $\\sin(x)$")
assert_markup_parsed_as( assert_markup_parsed_as(
%{<h1 id="my_headline">My Headline</h1>\n\n<p>that <span class="newWikiWord">} + %{<h1 id='my_headline'>My Headline</h1>\n\n<p>that <span class='newWikiWord'>} +
%{Smart Engine GUI<a href="../show/SmartEngineGUI">?</a></span></p>}, %{Smart Engine GUI<a href='../show/SmartEngineGUI'>?</a></span></p>},
"My Headline\n===========\n\nthat SmartEngineGUI") "My Headline\n===========\n\nthat SmartEngineGUI")
assert_markup_parsed_as( assert_markup_parsed_as(
%{<h1 id="my_headline">My Headline</h1>\n\n<p>that <span class="newWikiWord">} + %{<h1 id='my_headline'>My Headline</h1>\n\n<p>that <span class='newWikiWord'>} +
%{Smart Engine GUI<a href="../show/SmartEngineGUI">?</a></span></p>}, %{Smart Engine GUI<a href='../show/SmartEngineGUI'>?</a></span></p>},
"#My Headline#\n\nthat SmartEngineGUI") "#My Headline#\n\nthat SmartEngineGUI")
assert_markup_parsed_as( assert_markup_parsed_as(
%{<p>SVG <animateColor title="MathML"><span class="newWikiWord">} + %{<p>SVG <animateColor title='MathML'><span class='newWikiWord'>} +
%{Math ML<a href="../show/MathML">?</a></span></animateColor></p>}, %{Math ML<a href='../show/MathML'>?</a></span></animateColor></p>},
"SVG <animateColor title='MathML'>MathML</animateColor>") "SVG <animateColor title='MathML'>MathML</animateColor>")
assert_markup_parsed_as( assert_markup_parsed_as(
%{<div class="maruku-equation"><math class="maruku-mathml" display="block" } + %{<div class='maruku-equation'><math class='maruku-mathml' display='block' } +
%{xmlns="http://www.w3.org/1998/Math/MathML"><mi>sin</mi><mo stretchy="false">} + %{xmlns='http://www.w3.org/1998/Math/MathML'><mi>sin</mi><mo stretchy='false'>} +
%{(</mo><mi>x</mi><mo stretchy="false">)</mo><semantics><annotation-xml encoding="SVG1.1">} + %{(</mo><mi>x</mi><mo stretchy='false'>)</mo><semantics><annotation-xml encoding='SVG1.1'>} +
%{<svg></svg></annotation-xml></semantics></math><div class="maruku-eq-tex"><code style="display: none;">} + %{<svg/></annotation-xml></semantics></math><div class='maruku-eq-tex'><code style='display: none;'>} +
%{\\sin(x) \\begin{svg}<svg></svg>\\end{svg}</code></div></div>}, %{\\sin(x) \\begin{svg}<svg></svg>\\end{svg}</code></div></div>},
"$$\\sin(x) \\begin{svg}<svg/>\\end{svg}$$") "$$\\sin(x) \\begin{svg}<svg/>\\end{svg}$$")
@ -103,29 +103,28 @@ class PageRendererTest < Test::Unit::TestCase
code_block) code_block)
assert_markup_parsed_as( assert_markup_parsed_as(
%{<p><math class="maruku-mathml" } + %{<p><math class='maruku-mathml' } +
%{display="inline" xmlns="http://www.w3.org/1998/Math/MathML">} + %{display='inline' xmlns='http://www.w3.org/1998/Math/MathML'>} +
%{<mi>sin</mi><mo stretchy="false">(</mo><mi>x</mi><mo stretchy="false">)</mo></math> ecuasi\303\263n</p>}, %{<mi>sin</mi><mo stretchy='false'>(</mo><mi>x</mi><mo stretchy='false'>)</mo></math> ecuasi\303\263n</p>},
"$\\sin(x)$ ecuasi\303\263n") "$\\sin(x)$ ecuasi\303\263n")
assert_markup_parsed_as( assert_markup_parsed_as(
%{<p>ecuasi\303\263n</p>\n<div class="maruku-equation"><math class="maruku-mathml" } + %{<p>ecuasi\303\263n</p>\n<div class='maruku-equation'><math class='maruku-mathml' } +
%{display="block" xmlns="http://www.w3.org/1998/Math/MathML"><mi>sin</mi>} + %{display='block' xmlns='http://www.w3.org/1998/Math/MathML'><mi>sin</mi>} +
%{<mo stretchy="false">(</mo><mi>x</mi><mo stretchy="false">)</mo></math>} + %{<mo stretchy='false'>(</mo><mi>x</mi><mo stretchy='false'>)</mo></math>} +
%{<div class="maruku-eq-tex"><code style="display: none;">\\sin(x)</code></div></div>}, %{<div class='maruku-eq-tex'><code style='display: none;'>\\sin(x)</code></div></div>},
"ecuasi\303\263n\n$$\\sin(x)$$") "ecuasi\303\263n\n$$\\sin(x)$$")
assert_markup_parsed_as( assert_markup_parsed_as(
%{<p>ecuasi\303\263n</p>\n\n<p><math class="maruku-mathml" } + %{<p>ecuasi\303\263n</p>\n\n<p><math class='maruku-mathml' } +
%{display="inline" xmlns="http://www.w3.org/1998/Math/MathML">} + %{display='inline' xmlns='http://www.w3.org/1998/Math/MathML'>} +
%{<mi>sin</mi><mo stretchy="false">(</mo><mi>x</mi><mo stretchy="false">)</mo></math></p>}, %{<mi>sin</mi><mo stretchy='false'>(</mo><mi>x</mi><mo stretchy='false'>)</mo></math></p>},
"ecuasi\303\263n \n\n$\\sin(x)$") "ecuasi\303\263n \n\n$\\sin(x)$")
#FIXME
assert_markup_parsed_as( assert_markup_parsed_as(
%{<p>ecuasi\303\263n <math class="maruku-mathml" } + %{<p>ecuasi\303\263n <math class='maruku-mathml' } +
%{display="inline" xmlns="http://www.w3.org/1998/Math/MathML">} + %{display='inline' xmlns='http://www.w3.org/1998/Math/MathML'>} +
%{<mi>sin</mi><mo stretchy="false">(</mo><mi>x</mi><mo stretchy="false">)</mo></math></p>}, %{<mi>sin</mi><mo stretchy='false'>(</mo><mi>x</mi><mo stretchy='false'>)</mo></math></p>},
"ecuasi\303\263n $\\sin(x)$") "ecuasi\303\263n $\\sin(x)$")
end end
@ -135,7 +134,7 @@ class PageRendererTest < Test::Unit::TestCase
set_web_property :markup, :markdown set_web_property :markup, :markdown
assert_markup_parsed_as( assert_markup_parsed_as(
'<p><a href="http://example/with/slash">text</a></p>', "<p><a href='http://example/with/slash'>text</a></p>",
'[text](http://example/with/slash)') '[text](http://example/with/slash)')
end end
@ -154,7 +153,7 @@ class PageRendererTest < Test::Unit::TestCase
set_web_property :markup, :markdown set_web_property :markup, :markdown
assert_markup_parsed_as( assert_markup_parsed_as(
"<h1 id=\"markdown_heading\">Markdown heading</h1>\n\n" + "<h1 id='markdown_heading'>Markdown heading</h1>\n\n" +
"<p>h2. Textile heading</p>\n\n" + "<p>h2. Textile heading</p>\n\n" +
"<p><em>some</em> <strong>text</strong> <em>with</em> -styles-</p>\n\n" + "<p><em>some</em> <strong>text</strong> <em>with</em> -styles-</p>\n\n" +
"<ul>\n<li>list 1</li>\n\n<li>list 2</li>\n</ul>", "<ul>\n<li>list 1</li>\n\n<li>list 2</li>\n</ul>",
@ -181,8 +180,8 @@ class PageRendererTest < Test::Unit::TestCase
@revision = Revision.new(:page => @page, :content => '+hello+ that SmartEngineGUI', @revision = Revision.new(:page => @page, :content => '+hello+ that SmartEngineGUI',
:author => Author.new('DavidHeinemeierHansson')) :author => Author.new('DavidHeinemeierHansson'))
assert_equal "<tt>hello</tt> that <span class=\"newWikiWord\">Smart Engine GUI" + assert_equal "<tt>hello</tt> that <span class='newWikiWord'>Smart Engine GUI" +
"<a href=\"../show/SmartEngineGUI\">?</a></span>\n\n", "<a href='../show/SmartEngineGUI'>?</a></span>\n\n",
test_renderer(@revision).display_content test_renderer(@revision).display_content
end end
@ -197,15 +196,15 @@ class PageRendererTest < Test::Unit::TestCase
def test_content_with_aliased_links def test_content_with_aliased_links
assert_markup_parsed_as( assert_markup_parsed_as(
'<p>Would a <a class="existingWikiWord" href="../show/SmartEngine">clever motor' + "<p>Would a <a class='existingWikiWord' href='../show/SmartEngine'>clever motor" +
'</a> go by any other name?</p>', '</a> go by any other name?</p>',
'Would a [[SmartEngine|clever motor]] go by any other name?') 'Would a [[SmartEngine|clever motor]] go by any other name?')
end end
def test_content_with_wikiword_in_em def test_content_with_wikiword_in_em
assert_markup_parsed_as( assert_markup_parsed_as(
'<p><em>should we go <a class="existingWikiWord" href="../show/ThatWay">' + "<p><em>should we go <a class='existingWikiWord' href='../show/ThatWay'>" +
'That Way</a> or <span class="newWikiWord">This Way<a href="../show/ThisWay">?</a>' + "That Way</a> or <span class='newWikiWord'>This Way<a href='../show/ThisWay'>?</a>" +
'</span></em></p>', '</span></em></p>',
'_should we go ThatWay or ThisWay _') '_should we go ThatWay or ThisWay _')
end end
@ -213,15 +212,15 @@ class PageRendererTest < Test::Unit::TestCase
# wikiwords are invalid as styles, must be in "name: value" form # wikiwords are invalid as styles, must be in "name: value" form
def test_content_with_wikiword_in_style_tag def test_content_with_wikiword_in_style_tag
assert_markup_parsed_as( assert_markup_parsed_as(
'<p>That is some <em style="">Stylish Emphasis</em></p>', "<p>That is some <em style=''>Stylish Emphasis</em></p>",
'That is some <em style="WikiWord">Stylish Emphasis</em>') "That is some <em style='WikiWord'>Stylish Emphasis</em>")
end end
# validates format of style.. # validates format of style..
def test_content_with_valid_style_in_style_tag def test_content_with_valid_style_in_style_tag
assert_markup_parsed_as( assert_markup_parsed_as(
'<p>That is some <em style="text-align: right;">Stylish Emphasis</em></p>', "<p>That is some <em style='text-align: right;'>Stylish Emphasis</em></p>",
'That is some <em style="text-align: right">Stylish Emphasis</em>') "That is some <em style='text-align: right'>Stylish Emphasis</em>")
end end
def test_content_with_escaped_wikiword def test_content_with_escaped_wikiword
@ -248,24 +247,24 @@ class PageRendererTest < Test::Unit::TestCase
def test_content_with_link_in_parentheses def test_content_with_link_in_parentheses
assert_markup_parsed_as( assert_markup_parsed_as(
'<p>(<a href="http://wiki.org/wiki.cgi?WhatIsWiki">What is a wiki?</a>)</p>', "<p>(<a href='http://wiki.org/wiki.cgi?WhatIsWiki'>What is a wiki?</a>)</p>",
'([What is a wiki?](http://wiki.org/wiki.cgi?WhatIsWiki))') '([What is a wiki?](http://wiki.org/wiki.cgi?WhatIsWiki))')
end end
def test_content_with_image_link def test_content_with_image_link
assert_markup_parsed_as( assert_markup_parsed_as(
'<p>This <img alt="" src="http://hobix.com/sample.jpg" /> is a Markdown image link.</p>', "<p>This <img alt='' src='http://hobix.com/sample.jpg'/> is a Markdown image link.</p>",
'This ![](http://hobix.com/sample.jpg) is a Markdown image link.') 'This ![](http://hobix.com/sample.jpg) is a Markdown image link.')
end end
def test_content_with_inlined_img_tag def test_content_with_inlined_img_tag
assert_markup_parsed_as( assert_markup_parsed_as(
'<p>This <img alt="" src="http://hobix.com/sample.jpg" /> is an inline image link.</p>', "<p>This <img alt='' src='http://hobix.com/sample.jpg'/> is an inline image link.</p>",
'This <img src="http://hobix.com/sample.jpg" alt="" /> is an inline image link.') 'This <img src="http://hobix.com/sample.jpg" alt="" /> is an inline image link.')
# currently, upper case HTML elements are not allowed # currently, upper case HTML elements are not allowed
assert_markup_parsed_as( assert_markup_parsed_as(
'<p>This &lt;IMG SRC="http://hobix.com/sample.jpg" alt=""&gt;&lt;/IMG&gt; is an inline image link.</p>', "<p>This &lt;IMG SRC=\"http://hobix.com/sample.jpg\" alt=\"\"/&gt; is an inline image link.</p>",
'This <IMG SRC="http://hobix.com/sample.jpg" alt="" /> is an inline image link.') 'This <IMG SRC="http://hobix.com/sample.jpg" alt="" /> is an inline image link.')
end end
@ -279,7 +278,7 @@ class PageRendererTest < Test::Unit::TestCase
def test_multiline_nowiki_tag def test_multiline_nowiki_tag
assert_markup_parsed_as( assert_markup_parsed_as(
"<p>Do not mark \n up [[this text]] \nand http://this.url.com but markup " + "<p>Do not mark \n up [[this text]] \nand http://this.url.com but markup " +
'<span class="newWikiWord">this<a href="../show/this">?</a></span></p>', "<span class='newWikiWord'>this<a href='../show/this'>?</a></span></p>",
"Do not <nowiki>mark \n up [[this text]] \n" + "Do not <nowiki>mark \n up [[this text]] \n" +
"and http://this.url.com </nowiki> but markup [[this]]") "and http://this.url.com </nowiki> but markup [[this]]")
end end
@ -293,45 +292,45 @@ class PageRendererTest < Test::Unit::TestCase
def test_content_with_bracketted_wiki_word def test_content_with_bracketted_wiki_word
set_web_property :brackets_only, true set_web_property :brackets_only, true
assert_markup_parsed_as( assert_markup_parsed_as(
'<p>This is a WikiWord and a tricky name <span class="newWikiWord">' + "<p>This is a WikiWord and a tricky name <span class='newWikiWord'>" +
'Sperberg-McQueen<a href="../show/Sperberg-McQueen">?</a></span>.</p>', "Sperberg-McQueen<a href='../show/Sperberg-McQueen'>?</a></span>.</p>",
'This is a WikiWord and a tricky name [[Sperberg-McQueen]].') 'This is a WikiWord and a tricky name [[Sperberg-McQueen]].')
end end
def test_content_for_export def test_content_for_export
assert_equal '<p><span class="newWikiWord">His Way</span> would be ' + assert_equal "<p><span class='newWikiWord'>His Way</span> would be " +
'<a class="existingWikiWord" href="MyWay.html">My Way</a> ' + "<a class='existingWikiWord' href='MyWay.html'>My Way</a> " +
'<math class="maruku-mathml" display="inline" xmlns="http://www.w3.org/1998/Math/MathML">' + "<math class='maruku-mathml' display='inline' xmlns='http://www.w3.org/1998/Math/MathML'>" +
'<mi>sin</mi><mo stretchy="false">(</mo><mi>x</mi><mo stretchy="false">)</mo><semantics>' + "<mi>sin</mi><mo stretchy='false'>(</mo><mi>x</mi><mo stretchy='false'>)</mo><semantics>" +
'<annotation-xml encoding="SVG1.1"><svg></svg></annotation-xml></semantics></math> in kinda ' + "<annotation-xml encoding='SVG1.1'><svg/></annotation-xml></semantics></math> in kinda " +
'<a class="existingWikiWord" href="ThatWay.html">That Way</a> in ' + "<a class='existingWikiWord' href='ThatWay.html'>That Way</a> in " +
'<span class="newWikiWord">His Way</span> though ' + "<span class='newWikiWord'>His Way</span> though " +
%{<a class="existingWikiWord" href="MyWay.html">My Way</a> OverThere \xE2\x80\x93 see } + %{<a class='existingWikiWord' href='MyWay.html'>My Way</a> OverThere \xE2\x80\x93 see } +
'<a class="existingWikiWord" href="SmartEngine.html">Smart Engine</a> in that ' + "<a class='existingWikiWord' href='SmartEngine.html'>Smart Engine</a> in that " +
'<span class="newWikiWord">Smart Engine GUI</span></p>', "<span class='newWikiWord'>Smart Engine GUI</span></p>",
test_renderer(@revision).display_content_for_export test_renderer(@revision).display_content_for_export
end end
def test_double_replacing def test_double_replacing
@revision.content = "VersionHistory\r\n\r\ncry VersionHistory" @revision.content = "VersionHistory\r\n\r\ncry VersionHistory"
assert_equal '<p><span class="newWikiWord">Version History' + assert_equal "<p><span class='newWikiWord'>Version History" +
"<a href=\"../show/VersionHistory\">?</a></span></p>\n\n<p>cry " + "<a href='../show/VersionHistory'>?</a></span></p>\n\n<p>cry " +
'<span class="newWikiWord">Version History<a href="../show/VersionHistory">?</a>' + "<span class='newWikiWord'>Version History<a href='../show/VersionHistory'>?</a>" +
'</span></p>', '</span></p>',
test_renderer(@revision).display_content test_renderer(@revision).display_content
@revision.content = "f\r\nVersionHistory\r\n\r\ncry VersionHistory" @revision.content = "f\r\nVersionHistory\r\n\r\ncry VersionHistory"
assert_equal "<p>f <span class=\"newWikiWord\">Version History" + assert_equal "<p>f <span class='newWikiWord'>Version History" +
"<a href=\"../show/VersionHistory\">?</a></span></p>\n\n<p>cry " + "<a href='../show/VersionHistory'>?</a></span></p>\n\n<p>cry " +
"<span class=\"newWikiWord\">Version History<a href=\"../show/VersionHistory\">?</a>" + "<span class='newWikiWord'>Version History<a href='../show/VersionHistory'>?</a>" +
"</span></p>", "</span></p>",
test_renderer(@revision).display_content test_renderer(@revision).display_content
end end
def test_difficult_wiki_words def test_difficult_wiki_words
@revision.content = "[[It's just awesome GUI!]]" @revision.content = "[[It's just awesome GUI!]]"
assert_equal "<p><span class=\"newWikiWord\">It's just awesome GUI!" + assert_equal "<p><span class='newWikiWord'>It's just awesome GUI!" +
"<a href=\"../show/It%27s+just+awesome+GUI%21\">?</a></span></p>", "<a href='../show/It%27s+just+awesome+GUI%21'>?</a></span></p>",
test_renderer(@revision).display_content test_renderer(@revision).display_content
end end
@ -347,7 +346,7 @@ class PageRendererTest < Test::Unit::TestCase
def test_link_to_file def test_link_to_file
assert_markup_parsed_as( assert_markup_parsed_as(
'<p><span class="newWikiWord">doc.pdf<a href="../file/doc.pdf">?</a></span></p>', "<p><span class='newWikiWord'>doc.pdf<a href='../file/doc.pdf'>?</a></span></p>",
'[[doc.pdf:file]]') '[[doc.pdf:file]]')
end end
@ -357,16 +356,16 @@ class PageRendererTest < Test::Unit::TestCase
FileUtils.rm_rf("#{RAILS_ROOT}/public/wiki1/files/*") FileUtils.rm_rf("#{RAILS_ROOT}/public/wiki1/files/*")
@web.wiki_files.create(:file_name => 'square.jpg', :description => 'Square', :content => 'never mind') @web.wiki_files.create(:file_name => 'square.jpg', :description => 'Square', :content => 'never mind')
assert_markup_parsed_as( assert_markup_parsed_as(
'<p><img alt="Blue Square" src="../file/square.jpg" /></p>', "<p><img alt='Blue Square' src='../file/square.jpg'/></p>",
'[[square.jpg|Blue Square:pic]]') '[[square.jpg|Blue Square:pic]]')
assert_markup_parsed_as( assert_markup_parsed_as(
'<p><img alt="Square" src="../file/square.jpg" /></p>', "<p><img alt='Square' src='../file/square.jpg'/></p>",
'[[square.jpg:pic]]') '[[square.jpg:pic]]')
assert_markup_parsed_as( assert_markup_parsed_as(
'<p><a class="existingWikiWord" title="Square" href="../file/square.jpg">Blue Square</a></p>', "<p><a class='existingWikiWord' href='../file/square.jpg' title='Square'>Blue Square</a></p>",
'[[square.jpg|Blue Square:file]]') '[[square.jpg|Blue Square:file]]')
assert_markup_parsed_as( assert_markup_parsed_as(
'<p><a class="existingWikiWord" title="Square" href="../file/square.jpg">Square</a></p>', "<p><a class='existingWikiWord' href='../file/square.jpg' title='Square'>Square</a></p>",
'[[square.jpg:file]]') '[[square.jpg:file]]')
end end
@ -376,33 +375,33 @@ class PageRendererTest < Test::Unit::TestCase
FileUtils.rm_rf("#{RAILS_ROOT}/public/wiki1/files/*") FileUtils.rm_rf("#{RAILS_ROOT}/public/wiki1/files/*")
@web.wiki_files.create(:file_name => 'square.jpg', :description => '', :content => 'never mind') @web.wiki_files.create(:file_name => 'square.jpg', :description => '', :content => 'never mind')
assert_markup_parsed_as( assert_markup_parsed_as(
'<p><img alt="Blue Square" src="../file/square.jpg" /></p>', "<p><img alt='Blue Square' src='../file/square.jpg'/></p>",
'[[square.jpg|Blue Square:pic]]') '[[square.jpg|Blue Square:pic]]')
assert_markup_parsed_as( assert_markup_parsed_as(
'<p><img alt="" src="../file/square.jpg" /></p>', "<p><img alt='' src='../file/square.jpg'/></p>",
'[[square.jpg:pic]]') '[[square.jpg:pic]]')
assert_markup_parsed_as( assert_markup_parsed_as(
'<p><a class="existingWikiWord" title="" href="../file/square.jpg">Blue Square</a></p>', "<p><a class='existingWikiWord' href='../file/square.jpg' title=''>Blue Square</a></p>",
'[[square.jpg|Blue Square:file]]') '[[square.jpg|Blue Square:file]]')
assert_markup_parsed_as( assert_markup_parsed_as(
'<p><a class="existingWikiWord" title="" href="../file/square.jpg"></a></p>', "<p><a class='existingWikiWord' href='../file/square.jpg' title=''></a></p>",
'[[square.jpg:file]]') '[[square.jpg:file]]')
end end
def test_link_to_non_existant_pic def test_link_to_non_existant_pic
assert_markup_parsed_as( assert_markup_parsed_as(
'<p><span class="newWikiWord">NonExistant<a href="../file/NonExistant.jpg">?</a>' + "<p><span class='newWikiWord'>NonExistant<a href='../file/NonExistant.jpg'>?</a>" +
'</span></p>', '</span></p>',
'[[NonExistant.jpg|NonExistant:pic]]') '[[NonExistant.jpg|NonExistant:pic]]')
assert_markup_parsed_as( assert_markup_parsed_as(
'<p><span class="newWikiWord">NonExistant.jpg<a href="../file/NonExistant.jpg">?</a>' + "<p><span class='newWikiWord'>NonExistant.jpg<a href='../file/NonExistant.jpg'>?</a>" +
'</span></p>', '</span></p>',
'[[NonExistant.jpg:pic]]') '[[NonExistant.jpg:pic]]')
end end
def test_wiki_link_with_colon def test_wiki_link_with_colon
assert_markup_parsed_as( assert_markup_parsed_as(
'<p><span class="newWikiWord">Instiki:Colon<a href="../../instiki/show/Colon">?</a></span></p>', "<p><span class='newWikiWord'>Instiki:Colon<a href='../../instiki/show/Colon'>?</a></span></p>",
'[[Instiki:Colon]]') '[[Instiki:Colon]]')
end end
@ -413,7 +412,7 @@ class PageRendererTest < Test::Unit::TestCase
EOL EOL
assert_markup_parsed_as( assert_markup_parsed_as(
"<ul>\n<li><a href=\"~b\">a</a></li>\n\n<li>c~ d</li>\n</ul>", "<ul>\n<li><a href='~b'>a</a></li>\n\n<li>c~ d</li>\n</ul>",
list_with_tildas) list_with_tildas)
end end
@ -471,11 +470,11 @@ class PageRendererTest < Test::Unit::TestCase
included = @web.add_page('Included', 'link to HomePage', Time.now, 'AnAuthor', test_renderer) included = @web.add_page('Included', 'link to HomePage', Time.now, 'AnAuthor', test_renderer)
main = @web.add_page('Main', '[[!include Included]]', Time.now, 'AnAuthor', test_renderer) main = @web.add_page('Main', '[[!include Included]]', Time.now, 'AnAuthor', test_renderer)
assert_equal '<p>link to <a class="existingWikiWord" href="../show/HomePage">Home Page</a></p>', assert_equal "<p>link to <a class='existingWikiWord' href='../show/HomePage'>Home Page</a></p>",
test_renderer(main).display_content test_renderer(main).display_content
assert_equal '<p>link to <a class="existingWikiWord" href="../published/HomePage">Home Page</a></p>', assert_equal "<p>link to <a class='existingWikiWord' href='../published/HomePage'>Home Page</a></p>",
test_renderer(main).display_published test_renderer(main).display_published
assert_equal '<p>link to <a class="existingWikiWord" href="HomePage.html">Home Page</a></p>', assert_equal "<p>link to <a class='existingWikiWord' href='HomePage.html'>Home Page</a></p>",
test_renderer(main).display_content_for_export test_renderer(main).display_content_for_export
end end