[BREAKS BUILD] Corrected and refactored revision_test.rb

Same story as with uri_test.rb; this test was skipped by Rake, because there was a syntax error in it.
Now there is no syntax error, but there is a failing test instead (introduced by changeset:48)
This commit is contained in:
Alexey Verkhovsky 2005-01-18 22:32:50 +00:00
parent 07e43d2dae
commit ca22e59c38

View file

@ -4,7 +4,8 @@ require File.dirname(__FILE__) + '/../test_helper'
require 'web' require 'web'
require 'revision' require 'revision'
class WebStub < Web; class WebStub < Web
def initialize(); end
attr_accessor :markup attr_accessor :markup
def pages() PagesStub.new end def pages() PagesStub.new end
def safe_mode() false end def safe_mode() false end
@ -20,58 +21,16 @@ end
class RevisionTest < Test::Unit::TestCase class RevisionTest < Test::Unit::TestCase
def setup def setup
@page = PageStub.new
@web = WebStub.new @web = WebStub.new
@page.web = @web
@web.markup = :textile @web.markup = :textile
@page = PageStub.new
@page.web = @web
@revision = Revision.new(@page, 1, @revision = Revision.new(@page, 1,
'HisWay would be MyWay in kinda ThatWay in HisWay though MyWay \\OverThere -- ' + 'HisWay would be MyWay in kinda ThatWay in HisWay though MyWay \\OverThere -- ' +
'see SmartEngine in that SmartEngineGUI', 'see SmartEngine in that SmartEngineGUI',
Time.local(2004, 4, 4, 16, 50), 'DavidHeinemeierHansson') Time.local(2004, 4, 4, 16, 50), 'DavidHeinemeierHansson')
@revision_with_auto_links = Revision.new(@page, 1,
"http://www.loudthinking.com/ points to ThatWay from david@loudthinking.com",
Time.local(2004, 4, 4, 16, 50), 'DavidHeinemeierHansson')
@revision_with_aliased_links = Revision.new(@page, 1,
'Would a [[SmartEngine|clever motor]] go by any other name?',
Time.local(2004, 4, 4, 16, 50), 'MarkReid')
@revision_with_wiki_word_in_em = Revision.new(@page, 1, '_should we go ThatWay or ThisWay _',
Time.local(2004, 4, 4, 16, 50), 'MarkReid')
@revision_with_pre_blocks = Revision.new(@page, 1,
'A <code>class SmartEngine end</code> would not mark up <pre>CodeBlocks</pre>',
Time.local(2004, 4, 4, 16, 50), 'MarkReid')
@revision_with_wikiword_in_tag = Revision.new(@page, 1,
'That is some <em style=\"WikiWord\">Stylish Emphasis</em>',
Time.local(2004, 4, 4, 16, 50), 'MarkReid')
@revision_with_autolink_in_parentheses = Revision.new(
@page, 1, 'The W3C body (http://www.w3c.org) sets web standards',
Time.local(2004, 4, 4, 16, 50), 'MarkReid')
@revision_with_link_in_parentheses = Revision.new(
@page, 1,
'Instiki is a "Wiki Clone":http://www.c2.com/cgi/wiki?WikiWikiClones ' +
'("What is a wiki?":http://wiki.org/wiki.cgi?WhatIsWiki) that\'s so easy to setup',
Time.local(2004, 4, 4, 16, 50), 'MarkReid'
)
@revision_with_image_link = Revision.new(@page, 1,
'This !http://hobix.com/sample.jpg! is a Textile image link.',
Time.local(2004, 4, 4, 16, 50), 'MarkReid')
@revision_with_nowiki_text = Revision.new(@page, 1,
'Do not mark up <nowiki>[[this text]]</nowiki> or <nowiki>http://www.thislink.com</nowiki>.',
Time.local(2004, 4, 4, 16, 50), 'MarkReid')
@revision_with_bracketted_wiki_word = Revision.new(@page, 1,
'This is a WikiWord and a tricky name [[Sperberg-McQueen]].',
Time.local(2004, 4, 4, 16, 50), 'MarkReid')
end end
def test_wiki_words def test_wiki_words
@ -101,27 +60,24 @@ class RevisionTest < Test::Unit::TestCase
def test_bluecloth def test_bluecloth
@web.markup = :markdown @web.markup = :markdown
@revision = Revision.new(@page, 1, "My Headline\n===========\n\n that SmartEngineGUI", assert_markup_parsed_as(
Time.local(2004, 4, 4, 16, 50), 'DavidHeinemeierHansson') %{<h1>My Headline</h1>\n\n<p>that <span class="newWikiWord">} +
%{Smart Engine GUI<a href="../show/SmartEngineGUI">?</a></span></p>},
"My Headline\n===========\n\n that SmartEngineGUI")
@revision_with_code_block = Revision.new(@page, 1, code_block = [
[ 'This is a code block:', 'This is a code block:',
'', '',
' def a_method(arg)', ' def a_method(arg)',
' return ThatWay', ' return ThatWay',
'', '',
'Nice!'].join("\n"), 'Nice!'
Time.local(2004, 4, 4, 16, 50), ].join("\n")
'MarkReid'
)
assert_equal %{<h1>My Headline</h1>\n\n<p>that <span class="newWikiWord">} + assert_markup_parsed_as(
%{Smart Engine GUI<a href="../show/SmartEngineGUI">?</a></span></p>}, %{<p>This is a code block:</p>\n\n<pre><code>def a_method(arg)\n} +
@revision.display_content
assert_equal %{<p>This is a code block:</p>\n\n<pre><code>def a_method(arg)\n} +
%{return ThatWay\n</code></pre>\n\n<p>Nice!</p>}, %{return ThatWay\n</code></pre>\n\n<p>Nice!</p>},
@revision_with_code_block.display_content code_block)
end end
def test_rdoc def test_rdoc
@ -130,65 +86,81 @@ class RevisionTest < Test::Unit::TestCase
@revision = Revision.new(@page, 1, '+hello+ that SmartEngineGUI', @revision = Revision.new(@page, 1, '+hello+ that SmartEngineGUI',
Time.local(2004, 4, 4, 16, 50), 'DavidHeinemeierHansson') Time.local(2004, 4, 4, 16, 50), '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", @revision.display_content "<a href=\"../show/SmartEngineGUI\">?</a></span>\n\n", @revision.display_content
end end
def test_content_with_auto_links def test_content_with_auto_links
assert_equal '<p><a href="http://www.loudthinking.com/">http://www.loudthinking.com/</a> ' + assert_markup_parsed_as(
'<p><a href="http://www.loudthinking.com/">http://www.loudthinking.com/</a> ' +
'points to <a class="existingWikiWord" href="../show/ThatWay">That Way</a> from ' + 'points to <a class="existingWikiWord" href="../show/ThatWay">That Way</a> from ' +
'<a href="mailto:david@loudthinking.com">david@loudthinking.com</a></p>', '<a href="mailto:david@loudthinking.com">david@loudthinking.com</a></p>',
@revision_with_auto_links.display_content 'http://www.loudthinking.com/ points to ThatWay from david@loudthinking.com')
end end
def test_content_with_aliased_links def test_content_with_aliased_links
assert_equal '<p>Would a <a class="existingWikiWord" href="../show/SmartEngine">clever motor' + assert_markup_parsed_as(
'</a> go by any other name?</p>', @revision_with_aliased_links.display_content '<p>Would a <a class="existingWikiWord" href="../show/SmartEngine">clever motor' +
'</a> go by any other name?</p>',
'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_equal '<p><em>should we go <a class="existingWikiWord" href="../show/ThatWay">' + assert_markup_parsed_as(
'<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>', @revision_with_wiki_word_in_em.display_content '</span> </em></p>',
'_should we go ThatWay or ThisWay _')
end end
def test_content_with_wikiword_in_tag def test_content_with_wikiword_in_tag
assert_equal '<p>That is some <em style="WikiWord">Stylish Emphasis</em></p>', assert_markup_parsed_as(
@revision_with_wikiword_in_tag.display_content '<p>That is some <em style="WikiWord">Stylish Emphasis</em></p>',
'That is some <em style="WikiWord">Stylish Emphasis</em>')
end end
def test_content_with_pre_blocks def test_content_with_pre_blocks
assert_equal 'A <code>class SmartEngine end</code> would not mark up <pre>CodeBlocks</pre>', assert_markup_parsed_as(
@revision_with_pre_blocks.display_content 'A <code>class SmartEngine end</code> would not mark up <pre>CodeBlocks</pre>',
'A <code>class SmartEngine end</code> would not mark up <pre>CodeBlocks</pre>')
end end
def test_content_with_autolink_in_parentheses def test_content_with_autolink_in_parentheses
assert_equal '<p>The <span class="caps">W3C</span> body (<a href="http://www.w3c.org">' + assert_markup_parsed_as(
'<p>The <span class="caps">W3C</span> body (<a href="http://www.w3c.org">' +
'http://www.w3c.org</a>) sets web standards</p>', 'http://www.w3c.org</a>) sets web standards</p>',
@revision_with_autolink_in_parentheses.display_content 'The W3C body (http://www.w3c.org) sets web standards')
end end
def test_content_with_link_in_parentheses def test_content_with_link_in_parentheses
assert_equal '<p>Instiki is a <a href="http://www.c2.com/cgi/wiki?WikiWikiClones">Wiki Clone' + assert_markup_parsed_as(
'<p>Instiki is a <a href="http://www.c2.com/cgi/wiki?WikiWikiClones">Wiki Clone' +
'</a> (<a href="http://wiki.org/wiki.cgi?WhatIsWiki">What is a wiki?</a>) that&#8217;s ' + '</a> (<a href="http://wiki.org/wiki.cgi?WhatIsWiki">What is a wiki?</a>) that&#8217;s ' +
'so easy to setup</p>', @revision_with_link_in_parentheses.display_content 'so easy to setup</p>',
'Instiki is a "Wiki Clone":http://www.c2.com/cgi/wiki?WikiWikiClones ' +
'("What is a wiki?":http://wiki.org/wiki.cgi?WhatIsWiki) that\'s so easy to setup')
end end
def test_content_with_image_link def test_content_with_image_link
assert_equal '<p>This <img src="http://hobix.com/sample.jpg" alt="" /> is a Textile image ' + assert_markup_parsed_as(
'link.</p>', @revision_with_image_link.display_content '<p>This <img src="http://hobix.com/sample.jpg" alt="" /> is a Textile image link.</p>',
'This !http://hobix.com/sample.jpg! is a Textile image link.')
end end
def test_content_with_nowiki_text def test_content_with_nowiki_text
assert_equal '<p>Do not mark up [[this text]] or http://www.thislink.com.</p>', assert_markup_parsed_as(
@revision_with_nowiki_text.display_content '<p>Do not mark up [[this text]] or http://www.thislink.com.</p>',
'Do not mark up <nowiki>[[this text]]</nowiki> ' +
'or <nowiki>http://www.thislink.com</nowiki>.')
end end
def test_content_with_bracketted_wiki_word def test_content_with_bracketted_wiki_word
@web.brackets_only = true @web.brackets_only = true
assert_equal '<p>This is a WikiWord and a tricky name <span class="newWikiWord">' + assert_markup_parsed_as(
'<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>',
@revision_with_bracketted_wiki_word.display_content 'This is a WikiWord and a tricky name [[Sperberg-McQueen]].')
end end
def test_content_for_export def test_content_for_export
@ -228,21 +200,23 @@ class RevisionTest < Test::Unit::TestCase
end end
def test_revisions_diff def test_revisions_diff
page = PageStub.new
web = WebStub.new
web.markup = :textile
page.web = web
page.revisions = [ 0 ] @page.revisions = [
page.revisions << Revision.new(page, 1, 'What a blue and lovely morning', Revision.new(@page, 0, 'What a blue and lovely morning',
Time.local(2004, 4, 4, 16, 50), 'DavidHeinemeierHansson') Time.local(2004, 4, 4, 16, 50), 'DavidHeinemeierHansson'),
Revision.new(@page, 1, 'What a red and lovely morning today',
page.revisions << Revision.new(page, 2, 'What a red and lovely morning today',
Time.local(2004, 4, 4, 16, 50), 'DavidHeinemeierHansson') Time.local(2004, 4, 4, 16, 50), 'DavidHeinemeierHansson')
]
assert_equal "<p>What a <del class=\"diffmod\">blue </del><ins class=\"diffmod\">red " + assert_equal "<p>What a <del class=\"diffmod\">blue </del><ins class=\"diffmod\">red " +
"</ins>and lovely <del class=\"diffmod\">morning</del><ins class=\"diffmod\">morning " + "</ins>and lovely <del class=\"diffmod\">morning</del><ins class=\"diffmod\">morning " +
"today</ins></p>", page.revisions.last.display_diff "today</ins></p>", @page.revisions.last.display_diff
end
def assert_markup_parsed_as(expected_output, input)
revision = Revision.new(@page, 1, input, Time.local(2004, 4, 4, 16, 50), 'AnAuthor')
assert_equal expected_output, revision.display_content, 'Textile output not as expected'
end end
end end