summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJean-Philippe Lang <jp_lang@yahoo.fr>2012-11-27 19:59:33 +0000
committerJean-Philippe Lang <jp_lang@yahoo.fr>2012-11-27 19:59:33 +0000
commit14e56006a1f83ceb70291234d7b609150446aefb (patch)
treea33f78387899ec3b5c43e0cf8f7637b1d8ad189a
parentbf5b6014f7e985a87a1d0b6c0567939dbfe118a9 (diff)
downloadredmine-14e56006a1f83ceb70291234d7b609150446aefb.tar.gz
redmine-14e56006a1f83ceb70291234d7b609150446aefb.zip
Fixed that #extract_macro_options should not be greedy (#12451).
git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@10885 e93f8b46-1217-0410-a6f0-8f06a7374b81
-rw-r--r--lib/redmine/wiki_formatting/macros.rb2
-rw-r--r--test/unit/lib/redmine/wiki_formatting/macros_test.rb19
2 files changed, 20 insertions, 1 deletions
diff --git a/lib/redmine/wiki_formatting/macros.rb b/lib/redmine/wiki_formatting/macros.rb
index a50f2d289..64b7814b9 100644
--- a/lib/redmine/wiki_formatting/macros.rb
+++ b/lib/redmine/wiki_formatting/macros.rb
@@ -48,7 +48,7 @@ module Redmine
def extract_macro_options(args, *keys)
options = {}
- while args.last.to_s.strip =~ %r{^(.+)\=(.+)$} && keys.include?($1.downcase.to_sym)
+ while args.last.to_s.strip =~ %r{^(.+?)\=(.+)$} && keys.include?($1.downcase.to_sym)
options[$1.downcase.to_sym] = $2
args.pop
end
diff --git a/test/unit/lib/redmine/wiki_formatting/macros_test.rb b/test/unit/lib/redmine/wiki_formatting/macros_test.rb
index 08b0af462..cd3ac7a48 100644
--- a/test/unit/lib/redmine/wiki_formatting/macros_test.rb
+++ b/test/unit/lib/redmine/wiki_formatting/macros_test.rb
@@ -100,6 +100,25 @@ class Redmine::WikiFormatting::MacrosTest < ActionView::TestCase
assert_equal '<p>Hello world! Object: Issue, Called with no argument and no block of text.</p>', textilizable(text, :object => Issue.find(1))
end
+ def test_extract_macro_options_should_with_args
+ options = extract_macro_options(["arg1", "arg2"], :foo, :size)
+ assert_equal([["arg1", "arg2"], {}], options)
+ end
+
+ def test_extract_macro_options_should_with_options
+ options = extract_macro_options(["foo=bar", "size=2"], :foo, :size)
+ assert_equal([[], {:foo => "bar", :size => "2"}], options)
+ end
+
+ def test_extract_macro_options_should_with_args_and_options
+ options = extract_macro_options(["arg1", "arg2", "foo=bar", "size=2"], :foo, :size)
+ assert_equal([["arg1", "arg2"], {:foo => "bar", :size => "2"}], options)
+ end
+
+ def test_extract_macro_options_should_parse_options_lazily
+ options = extract_macro_options(["params=x=1&y=2"], :params)
+ assert_equal([[], {:params => "x=1&y=2"}], options)
+ end
def test_macro_exception_should_be_displayed
Redmine::WikiFormatting::Macros.macro :exception do |obj, args|