Slight change to the macro regexp.

git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@10178 e93f8b46-1217-0410-a6f0-8f06a7374b81
This commit is contained in:
Jean-Philippe Lang 2012-08-08 18:54:01 +00:00
parent 2e4f3d5a60
commit b907398788
2 changed files with 12 additions and 1 deletions

View File

@ -852,7 +852,7 @@ module ApplicationHelper
( (
\{\{ # opening tag \{\{ # opening tag
([\w]+) # macro name ([\w]+) # macro name
(\(([^\}]*)\))? # optional arguments (\((.*?)\))? # optional arguments
\}\} # closing tag \}\} # closing tag
) )
/x unless const_defined?(:MACROS_RE) /x unless const_defined?(:MACROS_RE)

View File

@ -65,6 +65,17 @@ class Redmine::WikiFormatting::MacrosTest < ActionView::TestCase
assert_equal '<p>Bar: () (String)</p>', textilizable("{{bar()}}") assert_equal '<p>Bar: () (String)</p>', textilizable("{{bar()}}")
end end
def test_multiple_macros_on_the_same_line
Redmine::WikiFormatting::Macros.macro :foo do |obj, args|
args.any? ? "args: #{args.join(',')}" : "no args"
end
assert_equal '<p>no args no args</p>', textilizable("{{foo}} {{foo}}")
assert_equal '<p>args: a,b no args</p>', textilizable("{{foo(a,b)}} {{foo}}")
assert_equal '<p>args: a,b args: c,d</p>', textilizable("{{foo(a,b)}} {{foo(c,d)}}")
assert_equal '<p>no args args: c,d</p>', textilizable("{{foo}} {{foo(c,d)}}")
end
def test_macro_hello_world def test_macro_hello_world
text = "{{hello_world}}" text = "{{hello_world}}"
assert textilizable(text).match(/Hello world!/) assert textilizable(text).match(/Hello world!/)