зеркало из https://github.com/github/ruby.git
* test/rss/*: Test::Unit::TestCase -> RSS::TestCase and
Test::Unit::Assertions -> RSS::Assertions. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@5991 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
Родитель
cfbe158fae
Коммит
abe876ed4e
|
@ -1,3 +1,8 @@
|
||||||
|
Sun Mar 21 18:57:37 2004 Kouhei Sutou <kou@cozmixng.org>
|
||||||
|
|
||||||
|
* test/rss/*: Test::Unit::TestCase -> RSS::TestCase and
|
||||||
|
Test::Unit::Assertions -> RSS::Assertions.
|
||||||
|
|
||||||
Sun Mar 21 18:48:20 2004 Kouhei Sutou <kou@cozmixng.org>
|
Sun Mar 21 18:48:20 2004 Kouhei Sutou <kou@cozmixng.org>
|
||||||
|
|
||||||
* lib/rss/{rss,dublincore,syndication}.rb: handled W3CDTF correctly.
|
* lib/rss/{rss,dublincore,syndication}.rb: handled W3CDTF correctly.
|
||||||
|
|
|
@ -1,130 +0,0 @@
|
||||||
# -*- tab-width: 2 -*- vim: ts=2
|
|
||||||
|
|
||||||
module Test
|
|
||||||
module Unit
|
|
||||||
module Assertions
|
|
||||||
|
|
||||||
def assert_parse(rss, assert_method, *args)
|
|
||||||
send("assert_#{assert_method}", *args) do
|
|
||||||
::RSS::Parser.parse(rss)
|
|
||||||
end
|
|
||||||
send("assert_#{assert_method}", *args) do
|
|
||||||
::RSS::Parser.parse(rss, false).validate
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
def assert_ns(prefix, uri)
|
|
||||||
_wrap_assertion do
|
|
||||||
begin
|
|
||||||
yield
|
|
||||||
flunk("Not raise NSError")
|
|
||||||
rescue ::RSS::NSError => e
|
|
||||||
assert_equal(prefix, e.prefix)
|
|
||||||
assert_equal(uri, e.uri)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
def assert_missing_tag(tag, parent)
|
|
||||||
_wrap_assertion do
|
|
||||||
begin
|
|
||||||
yield
|
|
||||||
flunk("Not raise MissingTagError")
|
|
||||||
rescue ::RSS::MissingTagError => e
|
|
||||||
assert_equal(tag, e.tag)
|
|
||||||
assert_equal(parent, e.parent)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
def assert_too_much_tag(tag, parent)
|
|
||||||
_wrap_assertion do
|
|
||||||
begin
|
|
||||||
yield
|
|
||||||
flunk("Not raise TooMuchTagError")
|
|
||||||
rescue ::RSS::TooMuchTagError => e
|
|
||||||
assert_equal(tag, e.tag)
|
|
||||||
assert_equal(parent, e.parent)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
def assert_missing_attribute(tag, attrname)
|
|
||||||
_wrap_assertion do
|
|
||||||
begin
|
|
||||||
yield
|
|
||||||
flunk("Not raise MissingAttributeError")
|
|
||||||
rescue ::RSS::MissingAttributeError => e
|
|
||||||
assert_equal(tag, e.tag)
|
|
||||||
assert_equal(attrname, e.attribute)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
def assert_not_excepted_tag(tag, parent)
|
|
||||||
_wrap_assertion do
|
|
||||||
begin
|
|
||||||
yield
|
|
||||||
flunk("Not raise NotExceptedTagError")
|
|
||||||
rescue ::RSS::NotExceptedTagError => e
|
|
||||||
assert_equal(tag, e.tag)
|
|
||||||
assert_equal(parent, e.parent)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
def assert_not_available_value(tag, value)
|
|
||||||
_wrap_assertion do
|
|
||||||
begin
|
|
||||||
yield
|
|
||||||
flunk("Not raise NotAvailableValueError")
|
|
||||||
rescue ::RSS::NotAvailableValueError => e
|
|
||||||
assert_equal(tag, e.tag)
|
|
||||||
assert_equal(value, e.value)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
def assert_xml_stylesheet_attrs(xsl, attrs)
|
|
||||||
_wrap_assertion do
|
|
||||||
normalized_attrs = {}
|
|
||||||
attrs.each do |name, value|
|
|
||||||
normalized_attrs[name.to_s] = value
|
|
||||||
end
|
|
||||||
::RSS::XMLStyleSheet::ATTRIBUTES.each do |name|
|
|
||||||
assert_equal(normalized_attrs[name], xsl.send(name))
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
def assert_xml_stylesheet(target, xsl, attrs)
|
|
||||||
_wrap_assertion do
|
|
||||||
if attrs.has_key?(:href)
|
|
||||||
if !attrs.has_key?(:type) and attrs.has_key?(:guess_type)
|
|
||||||
attrs[:type] = attrs[:guess_type]
|
|
||||||
end
|
|
||||||
assert_equal("xml-stylesheet", target)
|
|
||||||
assert_xml_stylesheet_attrs(xsl, attrs)
|
|
||||||
else
|
|
||||||
assert_nil(target)
|
|
||||||
assert_equal("", xsl.to_s)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
def assert_xml_stylesheet_pis(attrs_ary)
|
|
||||||
rdf = ::RSS::RDF.new()
|
|
||||||
xss_strs = []
|
|
||||||
attrs_ary.each do |attrs|
|
|
||||||
xss = ::RSS::XMLStyleSheet.new(*attrs)
|
|
||||||
xss_strs.push(xss.to_s)
|
|
||||||
rdf.xml_stylesheets.push(xss)
|
|
||||||
end
|
|
||||||
pi_str = rdf.to_s.gsub(/<\?xml .*\n/, "").gsub(/\s*<rdf:RDF.*\z/m, "")
|
|
||||||
assert_equal(xss_strs.join("\n"), pi_str)
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
|
@ -0,0 +1,127 @@
|
||||||
|
# -*- tab-width: 2 -*- vim: ts=2
|
||||||
|
|
||||||
|
module RSS
|
||||||
|
module Assertions
|
||||||
|
|
||||||
|
def assert_parse(rss, assert_method, *args)
|
||||||
|
send("assert_#{assert_method}", *args) do
|
||||||
|
::RSS::Parser.parse(rss)
|
||||||
|
end
|
||||||
|
send("assert_#{assert_method}", *args) do
|
||||||
|
::RSS::Parser.parse(rss, false).validate
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def assert_ns(prefix, uri)
|
||||||
|
_wrap_assertion do
|
||||||
|
begin
|
||||||
|
yield
|
||||||
|
flunk("Not raise NSError")
|
||||||
|
rescue ::RSS::NSError => e
|
||||||
|
assert_equal(prefix, e.prefix)
|
||||||
|
assert_equal(uri, e.uri)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def assert_missing_tag(tag, parent)
|
||||||
|
_wrap_assertion do
|
||||||
|
begin
|
||||||
|
yield
|
||||||
|
flunk("Not raise MissingTagError")
|
||||||
|
rescue ::RSS::MissingTagError => e
|
||||||
|
assert_equal(tag, e.tag)
|
||||||
|
assert_equal(parent, e.parent)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def assert_too_much_tag(tag, parent)
|
||||||
|
_wrap_assertion do
|
||||||
|
begin
|
||||||
|
yield
|
||||||
|
flunk("Not raise TooMuchTagError")
|
||||||
|
rescue ::RSS::TooMuchTagError => e
|
||||||
|
assert_equal(tag, e.tag)
|
||||||
|
assert_equal(parent, e.parent)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def assert_missing_attribute(tag, attrname)
|
||||||
|
_wrap_assertion do
|
||||||
|
begin
|
||||||
|
yield
|
||||||
|
flunk("Not raise MissingAttributeError")
|
||||||
|
rescue ::RSS::MissingAttributeError => e
|
||||||
|
assert_equal(tag, e.tag)
|
||||||
|
assert_equal(attrname, e.attribute)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def assert_not_excepted_tag(tag, parent)
|
||||||
|
_wrap_assertion do
|
||||||
|
begin
|
||||||
|
yield
|
||||||
|
flunk("Not raise NotExceptedTagError")
|
||||||
|
rescue ::RSS::NotExceptedTagError => e
|
||||||
|
assert_equal(tag, e.tag)
|
||||||
|
assert_equal(parent, e.parent)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def assert_not_available_value(tag, value)
|
||||||
|
_wrap_assertion do
|
||||||
|
begin
|
||||||
|
yield
|
||||||
|
flunk("Not raise NotAvailableValueError")
|
||||||
|
rescue ::RSS::NotAvailableValueError => e
|
||||||
|
assert_equal(tag, e.tag)
|
||||||
|
assert_equal(value, e.value)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def assert_xml_stylesheet_attrs(xsl, attrs)
|
||||||
|
_wrap_assertion do
|
||||||
|
normalized_attrs = {}
|
||||||
|
attrs.each do |name, value|
|
||||||
|
normalized_attrs[name.to_s] = value
|
||||||
|
end
|
||||||
|
::RSS::XMLStyleSheet::ATTRIBUTES.each do |name|
|
||||||
|
assert_equal(normalized_attrs[name], xsl.send(name))
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def assert_xml_stylesheet(target, xsl, attrs)
|
||||||
|
_wrap_assertion do
|
||||||
|
if attrs.has_key?(:href)
|
||||||
|
if !attrs.has_key?(:type) and attrs.has_key?(:guess_type)
|
||||||
|
attrs[:type] = attrs[:guess_type]
|
||||||
|
end
|
||||||
|
assert_equal("xml-stylesheet", target)
|
||||||
|
assert_xml_stylesheet_attrs(xsl, attrs)
|
||||||
|
else
|
||||||
|
assert_nil(target)
|
||||||
|
assert_equal("", xsl.to_s)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def assert_xml_stylesheet_pis(attrs_ary)
|
||||||
|
rdf = ::RSS::RDF.new()
|
||||||
|
xss_strs = []
|
||||||
|
attrs_ary.each do |attrs|
|
||||||
|
xss = ::RSS::XMLStyleSheet.new(*attrs)
|
||||||
|
xss_strs.push(xss.to_s)
|
||||||
|
rdf.xml_stylesheets.push(xss)
|
||||||
|
end
|
||||||
|
pi_str = rdf.to_s.gsub(/<\?xml .*\n/, "").gsub(/\s*<rdf:RDF.*\z/m, "")
|
||||||
|
assert_equal(xss_strs.join("\n"), pi_str)
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
||||||
|
end
|
|
@ -1,10 +1,13 @@
|
||||||
# -*- tab-width: 2 -*- vim: ts=2
|
# -*- tab-width: 2 -*- vim: ts=2
|
||||||
|
|
||||||
require 'my-assertions'
|
require "test/unit"
|
||||||
|
require 'rss-assertions'
|
||||||
|
|
||||||
module TestRSSMixin
|
module RSS
|
||||||
|
class TestCase < Test::Unit::TestCase
|
||||||
|
|
||||||
include RSS
|
include RSS
|
||||||
|
include Assertions
|
||||||
|
|
||||||
XMLDECL_VERSION = "1.0"
|
XMLDECL_VERSION = "1.0"
|
||||||
XMLDECL_ENCODING = "UTF-8"
|
XMLDECL_ENCODING = "UTF-8"
|
||||||
|
@ -25,6 +28,10 @@ module TestRSSMixin
|
||||||
"http://xml.com/pub/2000/08/09/rdfdb/index.html",
|
"http://xml.com/pub/2000/08/09/rdfdb/index.html",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
def default_test
|
||||||
|
# This class isn't tested
|
||||||
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
def make_xmldecl(v=XMLDECL_VERSION, e=XMLDECL_ENCODING, s=XMLDECL_STANDALONE)
|
def make_xmldecl(v=XMLDECL_VERSION, e=XMLDECL_ENCODING, s=XMLDECL_STANDALONE)
|
||||||
rv = "<?xml version='#{v}'"
|
rv = "<?xml version='#{v}'"
|
||||||
|
@ -153,4 +160,5 @@ EOC
|
||||||
</item>
|
</item>
|
||||||
EOI
|
EOI
|
||||||
end
|
end
|
||||||
|
end
|
||||||
end
|
end
|
|
@ -1,14 +1,13 @@
|
||||||
# -*- tab-width: 2 -*- vim: ts=2
|
# -*- tab-width: 2 -*- vim: ts=2
|
||||||
|
|
||||||
require "test/unit"
|
|
||||||
require "rexml/document"
|
require "rexml/document"
|
||||||
|
|
||||||
|
require "rss-testcase"
|
||||||
|
|
||||||
require "rss/1.0"
|
require "rss/1.0"
|
||||||
require "common"
|
|
||||||
|
|
||||||
class TestCore < Test::Unit::TestCase
|
module RSS
|
||||||
|
class TestCore < TestCase
|
||||||
include TestRSSMixin
|
|
||||||
|
|
||||||
def setup
|
def setup
|
||||||
|
|
||||||
|
@ -256,4 +255,5 @@ class TestCore < Test::Unit::TestCase
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -1,12 +1,12 @@
|
||||||
# -*- tab-width: 2 -*- vim: ts=2
|
# -*- tab-width: 2 -*- vim: ts=2
|
||||||
|
|
||||||
require "test/unit"
|
require "rss-testcase"
|
||||||
|
|
||||||
require "rss/1.0"
|
require "rss/1.0"
|
||||||
require "rss/2.0"
|
require "rss/2.0"
|
||||||
require "common"
|
|
||||||
|
|
||||||
class TestAccessor < Test::Unit::TestCase
|
module RSS
|
||||||
include TestRSSMixin
|
class TestAccessor < TestCase
|
||||||
|
|
||||||
def test_date
|
def test_date
|
||||||
channel = Rss::Channel.new
|
channel = Rss::Channel.new
|
||||||
|
@ -22,4 +22,5 @@ class TestAccessor < Test::Unit::TestCase
|
||||||
assert_nil(channel.pubDate)
|
assert_nil(channel.pubDate)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -1,15 +1,15 @@
|
||||||
# -*- tab-width: 2 -*- vim: ts=2
|
# -*- tab-width: 2 -*- vim: ts=2
|
||||||
|
|
||||||
require "test/unit"
|
|
||||||
require "cgi"
|
require "cgi"
|
||||||
require "rexml/document"
|
require "rexml/document"
|
||||||
|
|
||||||
|
require "rss-testcase"
|
||||||
|
|
||||||
require "rss/1.0"
|
require "rss/1.0"
|
||||||
require "rss/content"
|
require "rss/content"
|
||||||
require "common"
|
|
||||||
|
|
||||||
class TestContent < Test::Unit::TestCase
|
module RSS
|
||||||
include TestRSSMixin
|
class TestContent < TestCase
|
||||||
|
|
||||||
def setup
|
def setup
|
||||||
@prefix = "content"
|
@prefix = "content"
|
||||||
|
@ -93,4 +93,5 @@ EOR
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -1,15 +1,15 @@
|
||||||
# -*- tab-width: 2 -*- vim: ts=2
|
# -*- tab-width: 2 -*- vim: ts=2
|
||||||
|
|
||||||
require "test/unit"
|
|
||||||
require "cgi"
|
require "cgi"
|
||||||
require "rexml/document"
|
require "rexml/document"
|
||||||
|
|
||||||
|
require "rss-testcase"
|
||||||
|
|
||||||
require "rss/1.0"
|
require "rss/1.0"
|
||||||
require "rss/dublincore"
|
require "rss/dublincore"
|
||||||
require "common"
|
|
||||||
|
|
||||||
class TestDublinCore < Test::Unit::TestCase
|
module RSS
|
||||||
include TestRSSMixin
|
class TestDublinCore < TestCase
|
||||||
|
|
||||||
def setup
|
def setup
|
||||||
@prefix = "dc"
|
@prefix = "dc"
|
||||||
|
@ -25,8 +25,8 @@ class TestDublinCore < Test::Unit::TestCase
|
||||||
@elems = {
|
@elems = {
|
||||||
:title => "hoge",
|
:title => "hoge",
|
||||||
:description =>
|
:description =>
|
||||||
" XML is placing increasingly heavy loads on the existing technical
|
" XML is placing increasingly heavy loads on
|
||||||
infrastructure of the Internet.",
|
the existing technical infrastructure of the Internet.",
|
||||||
:creator => "Rael Dornfest (mailto:rael@oreilly.com)",
|
:creator => "Rael Dornfest (mailto:rael@oreilly.com)",
|
||||||
:subject => "XML",
|
:subject => "XML",
|
||||||
:publisher => "The O'Reilly Network",
|
:publisher => "The O'Reilly Network",
|
||||||
|
@ -122,4 +122,5 @@ EOR
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -1,11 +1,19 @@
|
||||||
# -*- tab-width: 2 -*- vim: ts=2
|
# -*- tab-width: 2 -*- vim: ts=2
|
||||||
|
|
||||||
require "test/unit"
|
require "rss-testcase"
|
||||||
require "rss/1.0"
|
|
||||||
require "common"
|
|
||||||
|
|
||||||
class TestParser < Test::Unit::TestCase
|
require "rss/1.0"
|
||||||
include TestRSSMixin
|
|
||||||
|
module RSS
|
||||||
|
class TestParser < TestCase
|
||||||
|
|
||||||
|
def setup
|
||||||
|
@_default_parser = Parser.default_parser
|
||||||
|
end
|
||||||
|
|
||||||
|
def teardown
|
||||||
|
Parser.default_parser = @_default_parser
|
||||||
|
end
|
||||||
|
|
||||||
def test_RDF
|
def test_RDF
|
||||||
assert_ns("", RDF::URI) do
|
assert_ns("", RDF::URI) do
|
||||||
|
@ -426,4 +434,6 @@ EOR
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -1,15 +1,15 @@
|
||||||
# -*- tab-width: 2 -*- vim: ts=2
|
# -*- tab-width: 2 -*- vim: ts=2
|
||||||
|
|
||||||
require "test/unit"
|
|
||||||
require "cgi"
|
require "cgi"
|
||||||
require "rexml/document"
|
require "rexml/document"
|
||||||
|
|
||||||
|
require "rss-testcase"
|
||||||
|
|
||||||
require "rss/1.0"
|
require "rss/1.0"
|
||||||
require "rss/syndication"
|
require "rss/syndication"
|
||||||
require "common"
|
|
||||||
|
|
||||||
class TestSyndication < Test::Unit::TestCase
|
module RSS
|
||||||
include TestRSSMixin
|
class TestSyndication < TestCase
|
||||||
|
|
||||||
def setup
|
def setup
|
||||||
@prefix = "sy"
|
@prefix = "sy"
|
||||||
|
@ -121,4 +121,5 @@ EOR
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -1,16 +1,16 @@
|
||||||
# -*- tab-width: 2 -*- vim: ts=2
|
# -*- tab-width: 2 -*- vim: ts=2
|
||||||
|
|
||||||
require "test/unit"
|
|
||||||
require "cgi"
|
require "cgi"
|
||||||
require "rexml/document"
|
require "rexml/document"
|
||||||
|
|
||||||
|
require "rss-testcase"
|
||||||
|
|
||||||
require "rss/1.0"
|
require "rss/1.0"
|
||||||
require "rss/2.0"
|
require "rss/2.0"
|
||||||
require "rss/trackback"
|
require "rss/trackback"
|
||||||
require "common"
|
|
||||||
|
|
||||||
class TestTrackBack < Test::Unit::TestCase
|
module RSS
|
||||||
include TestRSSMixin
|
class TestTrackBack < TestCase
|
||||||
|
|
||||||
def setup
|
def setup
|
||||||
@prefix = "trackback"
|
@prefix = "trackback"
|
||||||
|
@ -132,4 +132,6 @@ EOR
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -1,14 +1,14 @@
|
||||||
# -*- tab-width: 2 -*- vim: ts=2
|
# -*- tab-width: 2 -*- vim: ts=2
|
||||||
|
|
||||||
require "test/unit"
|
|
||||||
require "rexml/document"
|
require "rexml/document"
|
||||||
|
|
||||||
|
require "rss-testcase"
|
||||||
|
|
||||||
require "rss/1.0"
|
require "rss/1.0"
|
||||||
require "rss/xml-stylesheet"
|
require "rss/xml-stylesheet"
|
||||||
require "common"
|
|
||||||
|
|
||||||
class TestXMLStyleSheet < Test::Unit::TestCase
|
module RSS
|
||||||
include TestRSSMixin
|
class TestXMLStyleSheet < TestCase
|
||||||
|
|
||||||
def test_accessor
|
def test_accessor
|
||||||
[
|
[
|
||||||
|
@ -106,4 +106,5 @@ class TestXMLStyleSheet < Test::Unit::TestCase
|
||||||
[target, contents]
|
[target, contents]
|
||||||
end
|
end
|
||||||
|
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
Загрузка…
Ссылка в новой задаче