765f7abc60
Patch supplied by commits from Gerrit Kaiser on Github. Existing routes will still work (backwards compatible) but any new urls will be generated using the new routing rules. Changes listed below: * made the URLs for some project tabs and project settings follow the new rails RESTful conventions of /collection/:id/subcollection/:sub_id * prettier URL for project roadmap * more nice project URLs * use GET for filtering form * prettified URLs used on issues tab * custom route for activity atom feeds * prettier repository urls * fixed broken route definition * fixed failing tests for issuecontroller that were hardcoding the url string * more RESTful routes for boards and messages * RESTful routes for wiki pages * RESTful routes for documents * moved old routes that are retained for compatibility to the bottom and grouped them together * added RESTful URIs for issues * RESTfulness for the news section * fixed route order * changed hardcoded URLs in tests * fixed badly written tests * fixed forgotten parameter in routes * changed hardcoded URLS to new scheme * changed project add url to the standard POST to collection * create new issue by POSTing to collection * changed hardcoded URLs in integrations tests * made project add form work again * restful routes for project deletion * prettier routes for project (un)archival * made routes table more readable * fixed note quoting * user routing * fixed bug * always sort by GET * Fixed: cross-project issue list should not show issues of projects for which the issue tracking module was disabled. * prettified URLs used on issues tab * urls for time log * fixed reply routing * eliminate revision query paremeter for diff and entry actions * fixed test failures with hard-coded urls * ensure ajax links always use get * refactored ajax link generation into separate method #1901 git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@2317 e93f8b46-1217-0410-a6f0-8f06a7374b81
448 lines
22 KiB
Ruby
448 lines
22 KiB
Ruby
# redMine - project management software
|
|
# Copyright (C) 2006-2007 Jean-Philippe Lang
|
|
#
|
|
# This program is free software; you can redistribute it and/or
|
|
# modify it under the terms of the GNU General Public License
|
|
# as published by the Free Software Foundation; either version 2
|
|
# of the License, or (at your option) any later version.
|
|
#
|
|
# This program is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License
|
|
# along with this program; if not, write to the Free Software
|
|
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
|
|
require File.dirname(__FILE__) + '/../../test_helper'
|
|
|
|
class ApplicationHelperTest < HelperTestCase
|
|
include ApplicationHelper
|
|
include ActionView::Helpers::TextHelper
|
|
fixtures :projects, :roles, :enabled_modules, :users,
|
|
:repositories, :changesets,
|
|
:trackers, :issue_statuses, :issues, :versions, :documents,
|
|
:wikis, :wiki_pages, :wiki_contents,
|
|
:boards, :messages,
|
|
:attachments
|
|
|
|
def setup
|
|
super
|
|
end
|
|
|
|
def test_auto_links
|
|
to_test = {
|
|
'http://foo.bar' => '<a class="external" href="http://foo.bar">http://foo.bar</a>',
|
|
'http://foo.bar/~user' => '<a class="external" href="http://foo.bar/~user">http://foo.bar/~user</a>',
|
|
'http://foo.bar.' => '<a class="external" href="http://foo.bar">http://foo.bar</a>.',
|
|
'https://foo.bar.' => '<a class="external" href="https://foo.bar">https://foo.bar</a>.',
|
|
'This is a link: http://foo.bar.' => 'This is a link: <a class="external" href="http://foo.bar">http://foo.bar</a>.',
|
|
'A link (eg. http://foo.bar).' => 'A link (eg. <a class="external" href="http://foo.bar">http://foo.bar</a>).',
|
|
'http://foo.bar/foo.bar#foo.bar.' => '<a class="external" href="http://foo.bar/foo.bar#foo.bar">http://foo.bar/foo.bar#foo.bar</a>.',
|
|
'http://www.foo.bar/Test_(foobar)' => '<a class="external" href="http://www.foo.bar/Test_(foobar)">http://www.foo.bar/Test_(foobar)</a>',
|
|
'(see inline link : http://www.foo.bar/Test_(foobar))' => '(see inline link : <a class="external" href="http://www.foo.bar/Test_(foobar)">http://www.foo.bar/Test_(foobar)</a>)',
|
|
'(see inline link : http://www.foo.bar/Test)' => '(see inline link : <a class="external" href="http://www.foo.bar/Test">http://www.foo.bar/Test</a>)',
|
|
'(see inline link : http://www.foo.bar/Test).' => '(see inline link : <a class="external" href="http://www.foo.bar/Test">http://www.foo.bar/Test</a>).',
|
|
'(see "inline link":http://www.foo.bar/Test_(foobar))' => '(see <a href="http://www.foo.bar/Test_(foobar)" class="external">inline link</a>)',
|
|
'(see "inline link":http://www.foo.bar/Test)' => '(see <a href="http://www.foo.bar/Test" class="external">inline link</a>)',
|
|
'(see "inline link":http://www.foo.bar/Test).' => '(see <a href="http://www.foo.bar/Test" class="external">inline link</a>).',
|
|
'www.foo.bar' => '<a class="external" href="http://www.foo.bar">www.foo.bar</a>',
|
|
'http://foo.bar/page?p=1&t=z&s=' => '<a class="external" href="http://foo.bar/page?p=1&t=z&s=">http://foo.bar/page?p=1&t=z&s=</a>',
|
|
'http://foo.bar/page#125' => '<a class="external" href="http://foo.bar/page#125">http://foo.bar/page#125</a>',
|
|
'http://foo@www.bar.com' => '<a class="external" href="http://foo@www.bar.com">http://foo@www.bar.com</a>',
|
|
'http://foo:bar@www.bar.com' => '<a class="external" href="http://foo:bar@www.bar.com">http://foo:bar@www.bar.com</a>',
|
|
'ftp://foo.bar' => '<a class="external" href="ftp://foo.bar">ftp://foo.bar</a>',
|
|
'ftps://foo.bar' => '<a class="external" href="ftps://foo.bar">ftps://foo.bar</a>',
|
|
'sftp://foo.bar' => '<a class="external" href="sftp://foo.bar">sftp://foo.bar</a>',
|
|
}
|
|
to_test.each { |text, result| assert_equal "<p>#{result}</p>", textilizable(text) }
|
|
end
|
|
|
|
def test_auto_mailto
|
|
assert_equal '<p><a href="mailto:test@foo.bar" class="email">test@foo.bar</a></p>',
|
|
textilizable('test@foo.bar')
|
|
end
|
|
|
|
def test_inline_images
|
|
to_test = {
|
|
'!http://foo.bar/image.jpg!' => '<img src="http://foo.bar/image.jpg" alt="" />',
|
|
'floating !>http://foo.bar/image.jpg!' => 'floating <div style="float:right"><img src="http://foo.bar/image.jpg" alt="" /></div>',
|
|
'with class !(some-class)http://foo.bar/image.jpg!' => 'with class <img src="http://foo.bar/image.jpg" class="some-class" alt="" />',
|
|
# inline styles should be stripped
|
|
'with style !{width:100px;height100px}http://foo.bar/image.jpg!' => 'with style <img src="http://foo.bar/image.jpg" alt="" />',
|
|
'with title !http://foo.bar/image.jpg(This is a title)!' => 'with title <img src="http://foo.bar/image.jpg" title="This is a title" alt="This is a title" />',
|
|
'with title !http://foo.bar/image.jpg(This is a double-quoted "title")!' => 'with title <img src="http://foo.bar/image.jpg" title="This is a double-quoted "title"" alt="This is a double-quoted "title"" />',
|
|
}
|
|
to_test.each { |text, result| assert_equal "<p>#{result}</p>", textilizable(text) }
|
|
end
|
|
|
|
def test_acronyms
|
|
to_test = {
|
|
'this is an acronym: GPL(General Public License)' => 'this is an acronym: <acronym title="General Public License">GPL</acronym>',
|
|
'GPL(This is a double-quoted "title")' => '<acronym title="This is a double-quoted "title"">GPL</acronym>',
|
|
}
|
|
to_test.each { |text, result| assert_equal "<p>#{result}</p>", textilizable(text) }
|
|
|
|
end
|
|
|
|
def test_attached_images
|
|
to_test = {
|
|
'Inline image: !logo.gif!' => 'Inline image: <img src="/attachments/download/3" title="This is a logo" alt="This is a logo" />',
|
|
'Inline image: !logo.GIF!' => 'Inline image: <img src="/attachments/download/3" title="This is a logo" alt="This is a logo" />'
|
|
}
|
|
attachments = Attachment.find(:all)
|
|
to_test.each { |text, result| assert_equal "<p>#{result}</p>", textilizable(text, :attachments => attachments) }
|
|
end
|
|
|
|
def test_textile_external_links
|
|
to_test = {
|
|
'This is a "link":http://foo.bar' => 'This is a <a href="http://foo.bar" class="external">link</a>',
|
|
'This is an intern "link":/foo/bar' => 'This is an intern <a href="/foo/bar">link</a>',
|
|
'"link (Link title)":http://foo.bar' => '<a href="http://foo.bar" title="Link title" class="external">link</a>',
|
|
'"link (Link title with "double-quotes")":http://foo.bar' => '<a href="http://foo.bar" title="Link title with "double-quotes"" class="external">link</a>',
|
|
"This is not a \"Link\":\n\nAnother paragraph" => "This is not a \"Link\":</p>\n\n\n\t<p>Another paragraph",
|
|
# no multiline link text
|
|
"This is a double quote \"on the first line\nand another on a second line\":test" => "This is a double quote \"on the first line<br />\nand another on a second line\":test"
|
|
}
|
|
to_test.each { |text, result| assert_equal "<p>#{result}</p>", textilizable(text) }
|
|
end
|
|
|
|
def test_redmine_links
|
|
issue_link = link_to('#3', {:controller => 'issues', :action => 'show', :id => 3},
|
|
:class => 'issue', :title => 'Error 281 when updating a recipe (New)')
|
|
|
|
changeset_link = link_to('r1', {:controller => 'repositories', :action => 'revision', :id => 'ecookbook', :rev => 1},
|
|
:class => 'changeset', :title => 'My very first commit')
|
|
|
|
document_link = link_to('Test document', {:controller => 'documents', :action => 'show', :id => 1},
|
|
:class => 'document')
|
|
|
|
version_link = link_to('1.0', {:controller => 'versions', :action => 'show', :id => 2},
|
|
:class => 'version')
|
|
|
|
message_url = {:controller => 'messages', :action => 'show', :board_id => 1, :id => 4}
|
|
|
|
source_url = {:controller => 'repositories', :action => 'entry', :id => 'ecookbook', :path => ['some', 'file']}
|
|
source_url_with_ext = {:controller => 'repositories', :action => 'entry', :id => 'ecookbook', :path => ['some', 'file.ext']}
|
|
|
|
to_test = {
|
|
# tickets
|
|
'#3, #3 and #3.' => "#{issue_link}, #{issue_link} and #{issue_link}.",
|
|
# changesets
|
|
'r1' => changeset_link,
|
|
# documents
|
|
'document#1' => document_link,
|
|
'document:"Test document"' => document_link,
|
|
# versions
|
|
'version#2' => version_link,
|
|
'version:1.0' => version_link,
|
|
'version:"1.0"' => version_link,
|
|
# source
|
|
'source:/some/file' => link_to('source:/some/file', source_url, :class => 'source'),
|
|
'source:/some/file.' => link_to('source:/some/file', source_url, :class => 'source') + ".",
|
|
'source:/some/file.ext.' => link_to('source:/some/file.ext', source_url_with_ext, :class => 'source') + ".",
|
|
'source:/some/file. ' => link_to('source:/some/file', source_url, :class => 'source') + ".",
|
|
'source:/some/file.ext. ' => link_to('source:/some/file.ext', source_url_with_ext, :class => 'source') + ".",
|
|
'source:/some/file, ' => link_to('source:/some/file', source_url, :class => 'source') + ",",
|
|
'source:/some/file@52' => link_to('source:/some/file@52', source_url.merge(:rev => 52), :class => 'source'),
|
|
'source:/some/file.ext@52' => link_to('source:/some/file.ext@52', source_url_with_ext.merge(:rev => 52), :class => 'source'),
|
|
'source:/some/file#L110' => link_to('source:/some/file#L110', source_url.merge(:anchor => 'L110'), :class => 'source'),
|
|
'source:/some/file.ext#L110' => link_to('source:/some/file.ext#L110', source_url_with_ext.merge(:anchor => 'L110'), :class => 'source'),
|
|
'source:/some/file@52#L110' => link_to('source:/some/file@52#L110', source_url.merge(:rev => 52, :anchor => 'L110'), :class => 'source'),
|
|
'export:/some/file' => link_to('export:/some/file', source_url.merge(:format => 'raw'), :class => 'source download'),
|
|
# message
|
|
'message#4' => link_to('Post 2', message_url, :class => 'message'),
|
|
'message#5' => link_to('RE: post 2', message_url.merge(:anchor => 'message-5'), :class => 'message'),
|
|
# escaping
|
|
'!#3.' => '#3.',
|
|
'!r1' => 'r1',
|
|
'!document#1' => 'document#1',
|
|
'!document:"Test document"' => 'document:"Test document"',
|
|
'!version#2' => 'version#2',
|
|
'!version:1.0' => 'version:1.0',
|
|
'!version:"1.0"' => 'version:"1.0"',
|
|
'!source:/some/file' => 'source:/some/file',
|
|
# invalid expressions
|
|
'source:' => 'source:',
|
|
# url hash
|
|
"http://foo.bar/FAQ#3" => '<a class="external" href="http://foo.bar/FAQ#3">http://foo.bar/FAQ#3</a>',
|
|
}
|
|
@project = Project.find(1)
|
|
to_test.each { |text, result| assert_equal "<p>#{result}</p>", textilizable(text) }
|
|
end
|
|
|
|
def test_wiki_links
|
|
to_test = {
|
|
'[[CookBook documentation]]' => '<a href="/projects/ecookbook/wiki/CookBook_documentation" class="wiki-page">CookBook documentation</a>',
|
|
'[[Another page|Page]]' => '<a href="/projects/ecookbook/wiki/Another_page" class="wiki-page">Page</a>',
|
|
# link with anchor
|
|
'[[CookBook documentation#One-section]]' => '<a href="/projects/ecookbook/wiki/CookBook_documentation#One-section" class="wiki-page">CookBook documentation</a>',
|
|
'[[Another page#anchor|Page]]' => '<a href="/projects/ecookbook/wiki/Another_page#anchor" class="wiki-page">Page</a>',
|
|
# page that doesn't exist
|
|
'[[Unknown page]]' => '<a href="/projects/ecookbook/wiki/Unknown_page" class="wiki-page new">Unknown page</a>',
|
|
'[[Unknown page|404]]' => '<a href="/projects/ecookbook/wiki/Unknown_page" class="wiki-page new">404</a>',
|
|
# link to another project wiki
|
|
'[[onlinestore:]]' => '<a href="/projects/onlinestore/wiki/" class="wiki-page">onlinestore</a>',
|
|
'[[onlinestore:|Wiki]]' => '<a href="/projects/onlinestore/wiki/" class="wiki-page">Wiki</a>',
|
|
'[[onlinestore:Start page]]' => '<a href="/projects/onlinestore/wiki/Start_page" class="wiki-page">Start page</a>',
|
|
'[[onlinestore:Start page|Text]]' => '<a href="/projects/onlinestore/wiki/Start_page" class="wiki-page">Text</a>',
|
|
'[[onlinestore:Unknown page]]' => '<a href="/projects/onlinestore/wiki/Unknown_page" class="wiki-page new">Unknown page</a>',
|
|
# striked through link
|
|
'-[[Another page|Page]]-' => '<del><a href="/projects/ecookbook/wiki/Another_page" class="wiki-page">Page</a></del>',
|
|
'-[[Another page|Page]] link-' => '<del><a href="/projects/ecookbook/wiki/Another_page" class="wiki-page">Page</a> link</del>',
|
|
# escaping
|
|
'![[Another page|Page]]' => '[[Another page|Page]]',
|
|
}
|
|
@project = Project.find(1)
|
|
to_test.each { |text, result| assert_equal "<p>#{result}</p>", textilizable(text) }
|
|
end
|
|
|
|
def test_html_tags
|
|
to_test = {
|
|
"<div>content</div>" => "<p><div>content</div></p>",
|
|
"<div class=\"bold\">content</div>" => "<p><div class=\"bold\">content</div></p>",
|
|
"<script>some script;</script>" => "<p><script>some script;</script></p>",
|
|
# do not escape pre/code tags
|
|
"<pre>\nline 1\nline2</pre>" => "<pre>\nline 1\nline2</pre>",
|
|
"<pre><code>\nline 1\nline2</code></pre>" => "<pre><code>\nline 1\nline2</code></pre>",
|
|
"<pre><div>content</div></pre>" => "<pre><div>content</div></pre>",
|
|
"HTML comment: <!-- no comments -->" => "<p>HTML comment: <!-- no comments --></p>",
|
|
"<!-- opening comment" => "<p><!-- opening comment</p>",
|
|
# remove attributes except class
|
|
"<pre class='foo'>some text</pre>" => "<pre class='foo'>some text</pre>",
|
|
"<pre onmouseover='alert(1)'>some text</pre>" => "<pre>some text</pre>",
|
|
}
|
|
to_test.each { |text, result| assert_equal result, textilizable(text) }
|
|
end
|
|
|
|
def test_allowed_html_tags
|
|
to_test = {
|
|
"<pre>preformatted text</pre>" => "<pre>preformatted text</pre>",
|
|
"<notextile>no *textile* formatting</notextile>" => "no *textile* formatting",
|
|
"<notextile>this is <tag>a tag</tag></notextile>" => "this is <tag>a tag</tag>"
|
|
}
|
|
to_test.each { |text, result| assert_equal result, textilizable(text) }
|
|
end
|
|
|
|
def syntax_highlight
|
|
raw = <<-RAW
|
|
<pre><code class="ruby">
|
|
# Some ruby code here
|
|
</pre></code>
|
|
RAW
|
|
|
|
expected = <<-EXPECTED
|
|
<pre><code class="ruby CodeRay"><span class="no">1</span> <span class="c"># Some ruby code here</span>
|
|
</pre></code>
|
|
EXPECTED
|
|
|
|
assert_equal expected.gsub(%r{[\r\n\t]}, ''), textilizable(raw).gsub(%r{[\r\n\t]}, '')
|
|
end
|
|
|
|
def test_wiki_links_in_tables
|
|
to_test = {"|[[Page|Link title]]|[[Other Page|Other title]]|\n|Cell 21|[[Last page]]|" =>
|
|
'<tr><td><a href="/projects/ecookbook/wiki/Page" class="wiki-page new">Link title</a></td>' +
|
|
'<td><a href="/projects/ecookbook/wiki/Other_Page" class="wiki-page new">Other title</a></td>' +
|
|
'</tr><tr><td>Cell 21</td><td><a href="/projects/ecookbook/wiki/Last_page" class="wiki-page new">Last page</a></td></tr>'
|
|
}
|
|
@project = Project.find(1)
|
|
to_test.each { |text, result| assert_equal "<table>#{result}</table>", textilizable(text).gsub(/[\t\n]/, '') }
|
|
end
|
|
|
|
def test_text_formatting
|
|
to_test = {'*_+bold, italic and underline+_*' => '<strong><em><ins>bold, italic and underline</ins></em></strong>',
|
|
'(_text within parentheses_)' => '(<em>text within parentheses</em>)',
|
|
'a *Humane Web* Text Generator' => 'a <strong>Humane Web</strong> Text Generator',
|
|
'a H *umane* W *eb* T *ext* G *enerator*' => 'a H <strong>umane</strong> W <strong>eb</strong> T <strong>ext</strong> G <strong>enerator</strong>',
|
|
'a *H* umane *W* eb *T* ext *G* enerator' => 'a <strong>H</strong> umane <strong>W</strong> eb <strong>T</strong> ext <strong>G</strong> enerator',
|
|
}
|
|
to_test.each { |text, result| assert_equal "<p>#{result}</p>", textilizable(text) }
|
|
end
|
|
|
|
def test_wiki_horizontal_rule
|
|
assert_equal '<hr />', textilizable('---')
|
|
assert_equal '<p>Dashes: ---</p>', textilizable('Dashes: ---')
|
|
end
|
|
|
|
def test_acronym
|
|
assert_equal '<p>This is an acronym: <acronym title="American Civil Liberties Union">ACLU</acronym>.</p>',
|
|
textilizable('This is an acronym: ACLU(American Civil Liberties Union).')
|
|
end
|
|
|
|
def test_footnotes
|
|
raw = <<-RAW
|
|
This is some text[1].
|
|
|
|
fn1. This is the foot note
|
|
RAW
|
|
|
|
expected = <<-EXPECTED
|
|
<p>This is some text<sup><a href=\"#fn1\">1</a></sup>.</p>
|
|
<p id="fn1" class="footnote"><sup>1</sup> This is the foot note</p>
|
|
EXPECTED
|
|
|
|
assert_equal expected.gsub(%r{[\r\n\t]}, ''), textilizable(raw).gsub(%r{[\r\n\t]}, '')
|
|
end
|
|
|
|
def test_table_of_content
|
|
raw = <<-RAW
|
|
{{toc}}
|
|
|
|
h1. Title
|
|
|
|
Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Maecenas sed libero.
|
|
|
|
h2. Subtitle
|
|
|
|
Nullam commodo metus accumsan nulla. Curabitur lobortis dui id dolor.
|
|
|
|
h2. Subtitle with %{color:red}red text%
|
|
|
|
h1. Another title
|
|
|
|
RAW
|
|
|
|
expected = '<ul class="toc">' +
|
|
'<li class="heading1"><a href="#Title">Title</a></li>' +
|
|
'<li class="heading2"><a href="#Subtitle">Subtitle</a></li>' +
|
|
'<li class="heading2"><a href="#Subtitle-with-red-text">Subtitle with red text</a></li>' +
|
|
'<li class="heading1"><a href="#Another-title">Another title</a></li>' +
|
|
'</ul>'
|
|
|
|
assert textilizable(raw).gsub("\n", "").include?(expected)
|
|
end
|
|
|
|
def test_blockquote
|
|
# orig raw text
|
|
raw = <<-RAW
|
|
John said:
|
|
> Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Maecenas sed libero.
|
|
> Nullam commodo metus accumsan nulla. Curabitur lobortis dui id dolor.
|
|
> * Donec odio lorem,
|
|
> * sagittis ac,
|
|
> * malesuada in,
|
|
> * adipiscing eu, dolor.
|
|
>
|
|
> >Nulla varius pulvinar diam. Proin id arcu id lorem scelerisque condimentum. Proin vehicula turpis vitae lacus.
|
|
> Proin a tellus. Nam vel neque.
|
|
|
|
He's right.
|
|
RAW
|
|
|
|
# expected html
|
|
expected = <<-EXPECTED
|
|
<p>John said:</p>
|
|
<blockquote>
|
|
Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Maecenas sed libero.
|
|
Nullam commodo metus accumsan nulla. Curabitur lobortis dui id dolor.
|
|
<ul>
|
|
<li>Donec odio lorem,</li>
|
|
<li>sagittis ac,</li>
|
|
<li>malesuada in,</li>
|
|
<li>adipiscing eu, dolor.</li>
|
|
</ul>
|
|
<blockquote>
|
|
<p>Nulla varius pulvinar diam. Proin id arcu id lorem scelerisque condimentum. Proin vehicula turpis vitae lacus.</p>
|
|
</blockquote>
|
|
<p>Proin a tellus. Nam vel neque.</p>
|
|
</blockquote>
|
|
<p>He's right.</p>
|
|
EXPECTED
|
|
|
|
assert_equal expected.gsub(%r{\s+}, ''), textilizable(raw).gsub(%r{\s+}, '')
|
|
end
|
|
|
|
def test_table
|
|
raw = <<-RAW
|
|
This is a table with empty cells:
|
|
|
|
|cell11|cell12||
|
|
|cell21||cell23|
|
|
|cell31|cell32|cell33|
|
|
RAW
|
|
|
|
expected = <<-EXPECTED
|
|
<p>This is a table with empty cells:</p>
|
|
|
|
<table>
|
|
<tr><td>cell11</td><td>cell12</td><td></td></tr>
|
|
<tr><td>cell21</td><td></td><td>cell23</td></tr>
|
|
<tr><td>cell31</td><td>cell32</td><td>cell33</td></tr>
|
|
</table>
|
|
EXPECTED
|
|
|
|
assert_equal expected.gsub(%r{\s+}, ''), textilizable(raw).gsub(%r{\s+}, '')
|
|
end
|
|
|
|
def test_default_formatter
|
|
Setting.text_formatting = 'unknown'
|
|
text = 'a *link*: http://www.example.net/'
|
|
assert_equal '<p>a *link*: <a href="http://www.example.net/">http://www.example.net/</a></p>', textilizable(text)
|
|
Setting.text_formatting = 'textile'
|
|
end
|
|
|
|
def test_date_format_default
|
|
today = Date.today
|
|
Setting.date_format = ''
|
|
assert_equal l_date(today), format_date(today)
|
|
end
|
|
|
|
def test_date_format
|
|
today = Date.today
|
|
Setting.date_format = '%d %m %Y'
|
|
assert_equal today.strftime('%d %m %Y'), format_date(today)
|
|
end
|
|
|
|
def test_time_format_default
|
|
now = Time.now
|
|
Setting.date_format = ''
|
|
Setting.time_format = ''
|
|
assert_equal l_datetime(now), format_time(now)
|
|
assert_equal l_time(now), format_time(now, false)
|
|
end
|
|
|
|
def test_time_format
|
|
now = Time.now
|
|
Setting.date_format = '%d %m %Y'
|
|
Setting.time_format = '%H %M'
|
|
assert_equal now.strftime('%d %m %Y %H %M'), format_time(now)
|
|
assert_equal now.strftime('%H %M'), format_time(now, false)
|
|
end
|
|
|
|
def test_utc_time_format
|
|
now = Time.now.utc
|
|
Setting.date_format = '%d %m %Y'
|
|
Setting.time_format = '%H %M'
|
|
assert_equal Time.now.strftime('%d %m %Y %H %M'), format_time(now)
|
|
assert_equal Time.now.strftime('%H %M'), format_time(now, false)
|
|
end
|
|
|
|
def test_due_date_distance_in_words
|
|
to_test = { Date.today => 'Due in 0 days',
|
|
Date.today + 1 => 'Due in 1 day',
|
|
Date.today + 100 => 'Due in 100 days',
|
|
Date.today + 20000 => 'Due in 20000 days',
|
|
Date.today - 1 => '1 day late',
|
|
Date.today - 100 => '100 days late',
|
|
Date.today - 20000 => '20000 days late',
|
|
}
|
|
to_test.each do |date, expected|
|
|
assert_equal expected, due_date_distance_in_words(date)
|
|
end
|
|
end
|
|
|
|
def test_avatar
|
|
# turn on avatars
|
|
Setting.gravatar_enabled = '1'
|
|
assert avatar(User.find_by_mail('jsmith@somenet.foo')).include?(Digest::MD5.hexdigest('jsmith@somenet.foo'))
|
|
assert avatar('jsmith <jsmith@somenet.foo>').include?(Digest::MD5.hexdigest('jsmith@somenet.foo'))
|
|
assert_nil avatar('jsmith')
|
|
assert_nil avatar(nil)
|
|
|
|
# turn off avatars
|
|
Setting.gravatar_enabled = '0'
|
|
assert_nil avatar(User.find_by_mail('jsmith@somenet.foo'))
|
|
end
|
|
end
|