Commit 25018e09d903cb9a6cb064ea447888fe2e1c1d39
1 parent
6cb08f2f
Exists in
master
and in
29 other branches
macro: fix attributes after nokogiri change and write some tests
Showing
2 changed files
with
39 additions
and
2 deletions
Show diff stats
lib/noosfero/plugin/macro.rb
... | ... | @@ -33,9 +33,9 @@ class Noosfero::Plugin::Macro |
33 | 33 | end |
34 | 34 | |
35 | 35 | def attributes(macro) |
36 | - macro.attributes.to_hash. | |
36 | + macro.attributes. | |
37 | 37 | select {|key, value| key[0..10] == 'data-macro-'}. |
38 | - inject({}){|result, a| result.merge({a[0][11..-1] => a[1]})}. | |
38 | + inject({}){|result, a| result.merge({a[0][11..-1] => a[1].value})}. | |
39 | 39 | with_indifferent_access |
40 | 40 | end |
41 | 41 | ... | ... |
... | ... | @@ -0,0 +1,37 @@ |
1 | +require File.dirname(__FILE__) + '/../test_helper' | |
2 | + | |
3 | +class MacroTest < ActiveSupport::TestCase | |
4 | + | |
5 | + class Plugin1 < Noosfero::Plugin | |
6 | + end | |
7 | + | |
8 | + class Plugin1::Macro < Noosfero::Plugin::Macro | |
9 | + def parse(params, inner_html, source) | |
10 | + "Testing: #{inner_html}" | |
11 | + end | |
12 | + end | |
13 | + | |
14 | + MACRO = "<div class='macro nonEdit' data-macro='#{Plugin1::Macro.identifier}' data-macro-attr1='1' data-macro-attr2='2' data-macro-attr3='3'>It works!</div>" | |
15 | + | |
16 | + def setup | |
17 | + @macro = Plugin1::Macro.new | |
18 | + @macro_element = Nokogiri::HTML(MACRO).css('.macro').first | |
19 | + end | |
20 | + | |
21 | + attr_reader :macro, :macro_element | |
22 | + | |
23 | + should 'access plugin' do | |
24 | + assert_equal Plugin1, Plugin1::Macro.plugin | |
25 | + end | |
26 | + | |
27 | + should 'parse attributes' do | |
28 | + attributes = macro.attributes(macro_element) | |
29 | + assert_equal '1', attributes['attr1'] | |
30 | + assert_equal '2', attributes['attr2'] | |
31 | + assert_equal '3', attributes['attr3'] | |
32 | + end | |
33 | + | |
34 | + should 'convert macro' do | |
35 | + assert_equal 'Testing: It works!', macro.convert(macro_element, nil) | |
36 | + end | |
37 | +end | ... | ... |