diff options
author | kou <kou@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2004-02-13 11:02:03 +0000 |
---|---|---|
committer | kou <kou@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2004-02-13 11:02:03 +0000 |
commit | c0306157d9dbb12447ba5288b8a2db73b2beef11 (patch) | |
tree | 7c900356e107f5a66c051a535e9dfab8b103eca8 /test/rss/test_trackback.rb | |
parent | 82482f67e25e8239d17a0ee9d209dca3c6fbb2f9 (diff) |
* test/rss/test_trackback.rb: added tests for TrackBack with RSS
2.0.
* test/rss/common.rb: added methods make RSS 2.0.
* lib/rss/trackback.rb: TrackBack API is decided.
* lib/rss/rss.rb: RSS::VERSION 0.0.7 -> 0.0.8
* lib/rss/parser.rb, lib/rss/rss.rb: replaced $DEBUG by RSS::DEBUG.
* lib/rss/2.0.rb: removed RSS 2.0 URI. Because RSS 2.0 doesn't
have URI.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@5691 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'test/rss/test_trackback.rb')
-rw-r--r-- | test/rss/test_trackback.rb | 33 |
1 files changed, 28 insertions, 5 deletions
diff --git a/test/rss/test_trackback.rb b/test/rss/test_trackback.rb index 85ab533617..936f3683f0 100644 --- a/test/rss/test_trackback.rb +++ b/test/rss/test_trackback.rb @@ -5,6 +5,7 @@ require "cgi-lib" require "rexml/document" require "rss/1.0" +require "rss/2.0" require "rss/trackback" require "common" @@ -26,6 +27,10 @@ class TestTrackBack < Test::Unit::TestCase "<#{@prefix}:#{name} rdf:resource=\"#{CGI.escapeHTML(value.to_s)}\"/>" end.join("\n") + @content_nodes2 = @elems.collect do |name, value| + "<#{@prefix}:#{name}>#{CGI.escapeHTML(value.to_s)}</#{@prefix}:#{name}>" + end.join("\n") + @rss_source = make_RDF(<<-EOR, {@prefix => @uri}) #{make_channel()} #{make_image()} @@ -34,6 +39,14 @@ class TestTrackBack < Test::Unit::TestCase EOR @rss = Parser.parse(@rss_source) + + @rss2_source = make_Rss2(nil, {@prefix => @uri}) do + make_channel2(nil) do + make_item2(@content_nodes2) + end + end + + @rss2 = Parser.parse(@rss2_source, false) end def test_parser @@ -76,11 +89,21 @@ EOR @elems.each do |name, value| @parents.each do |parent| - elem = @rss.send(parent).send("#{RSS::TRACKBACK_PREFIX}_#{name}") - meth = "resource" - assert_equal(value, elem.send(meth)) - elem.send("#{meth}=", new_value[name].to_s) - assert_equal(new_value[name], elem.send(meth)) + accessor = "#{RSS::TRACKBACK_PREFIX}_#{name}" + target_accessor = "resource" + target = @rss.send(parent).send(accessor) + target2 = @rss2.channel.send(parent, -1) + assert_equal(value, target.send(target_accessor)) + assert_equal(value, target2.send(accessor)) + target.send("#{target_accessor}=", new_value[name].to_s) + if name == :about + # abount is zero or more + target2.send("#{accessor}=", 0, new_value[name].to_s) + else + target2.send("#{accessor}=", new_value[name].to_s) + end + assert_equal(new_value[name], target.send(target_accessor)) + assert_equal(new_value[name], target2.send(accessor)) end end |