#encoding: utf-8 # # Redmine - project management software # Copyright (C) 2006-2017 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.expand_path('../../../../../test_helper', __FILE__) require 'digest/md5' class Redmine::WikiFormatting::TextileFormatterTest < ActionView::TestCase def setup @formatter = Redmine::WikiFormatting::Textile::Formatter end MODIFIERS = { "*" => 'strong', # bold "_" => 'em', # italic "+" => 'ins', # underline "-" => 'del', # deleted "^" => 'sup', # superscript "~" => 'sub' # subscript } def test_modifiers assert_html_output( '*bold*' => 'bold', 'before *bold*' => 'before bold', '*bold* after' => 'bold after', '*two words*' => 'two words', '*two*words*' => 'two*words', '*two * words*' => 'two * words', '*two* *words*' => 'two words', '*(two)* *(words)*' => '(two) (words)' ) end def test_modifiers_combination MODIFIERS.each do |m1, tag1| MODIFIERS.each do |m2, tag2| next if m1 == m2 text = "#{m2}#{m1}Phrase modifiers#{m1}#{m2}" html = "<#{tag2}><#{tag1}>Phrase modifiers" assert_html_output text => html end end end def test_modifier_should_work_with_one_non_ascii_character assert_html_output "*Ä*" => "Ä" end def test_styles # single style assert_html_output({ 'p{color:red}. text' => '

text

', 'p{color:red;}. text' => '

text

', 'p{color: red}. text' => '

text

', 'p{color:#f00}. text' => '

text

', 'p{color:#ff0000}. text' => '

text

', 'p{border:10px}. text' => '

text

', 'p{border:10}. text' => '

text

', 'p{border:10%}. text' => '

text

', 'p{border:10em}. text' => '

text

', 'p{border:1.5em}. text' => '

text

', 'p{border-left:1px}. text' => '

text

', 'p{border-right:1px}. text' => '

text

', 'p{border-top:1px}. text' => '

text

', 'p{border-bottom:1px}. text' => '

text

', 'p{width:50px}. text' => '

text

', 'p{max-width:100px}. text' => '

text

', 'p{height:40px}. text' => '

text

', 'p{max-height:80px}. text' => '

text

', }, false) # multiple styles assert_html_output({ 'p{color:red; border-top:1px}. text' => '

text

', 'p{color:red ; border-top:1px}. text' => '

text

', 'p{color:red;border-top:1px}. text' => '

text

', }, false) # styles with multiple values assert_html_output({ 'p{border:1px solid red;}. text' => '

text

', 'p{border-top-left-radius: 10px 5px;}. text' => '

text

', }, false) end def test_invalid_styles_should_be_filtered assert_html_output({ 'p{invalid}. text' => '

text

', 'p{invalid:red}. text' => '

text

', 'p{color:(red)}. text' => '

text

', 'p{color:red;invalid:blue}. text' => '

text

', 'p{invalid:blue;color:red}. text' => '

text

', 'p{color:"}. text' => '

p{color:"}. text

', }, false) end def test_inline_code assert_html_output( 'this is @some code@' => 'this is some code', '@@' => '<Location /redmine>' ) end def test_lang_attribute assert_html_output( '*[fr]French*' => 'French', '*[fr-fr]French*' => 'French', '*[fr_fr]French*' => 'French' ) end def test_lang_attribute_should_ignore_invalid_value assert_html_output( '*[fr3]French*' => '[fr3]French' ) end def test_nested_lists raw = <<-RAW # Item 1 # Item 2 ** Item 2a ** Item 2b # Item 3 ** Item 3a RAW expected = <<-EXPECTED
  1. Item 1
  2. Item 2
    • Item 2a
    • Item 2b
  3. Item 3
    • Item 3a
EXPECTED assert_equal expected.gsub(%r{\s+}, ''), to_html(raw).gsub(%r{\s+}, '') end def test_escaping assert_html_output( 'this is a