Module: Test::Unit::XML
- Included in:
- TestCase
- Defined in:
- lib/test/unit/xml/nodeiterator.rb,
lib/test/unit/xml/xml_assertions.rb,
lib/test/unit/xml/xmlequalfilter.rb
Defined Under Namespace
Classes: NodeIterator, XmlEqualFilter
Instance Method Summary collapse
-
#assert_xml_equal(expected_doc, actual_doc, message = nil) ⇒ Object
This method checks whether two well-formed XML documents are equal.
-
#assert_xml_not_equal(expected_doc, actual_doc, message = nil) ⇒ Object
This method compares two XML documents and returns
true
if they are not equal,false
otherwise.
Instance Method Details
#assert_xml_equal(expected_doc, actual_doc, message = nil) ⇒ Object
This method checks whether two well-formed XML documents are equal. Two XML documents are considered equal if:
-
They contain the same type of nodes, in the same order, except for text nodes that are empty, or contain only whitespace. Such text nodes are ignored.
-
The corresponding nodes in the two documents are equal.
Nodes are tested for equality as follows:
- XML Declarations
-
XML declarations are equal if they have the same version, encoding, and stand-alone pseudo-attributes.
- Doctype
-
Doctypes are equal if they fulfill all of the following conditions:
-
They have the same public identifier, or neither has a public identifier
-
If one of the doctypes has a system identifier that is a URN, the other doctype must have a system identifier that is the same URN. System identifiers that are URLs are ignored for comparison purposes. The reason is that the same DTD is very often stored in many different locations (for example different directories on different computers). Therefore the physical location of the DTD does not say anything useful about whether two documents are equal.
-
An entity declaration present in one of the doctype declarations must also be present in the other.
-
A notation declaration present in one of the doctype declarations must also be present in the other.
-
- Internal General Entity Declaration
-
Internal General entity declarations are equal if they have the same name, and the same value.
- External General Entity Declaration
-
External general entity declarations are equal if they have the same name, and if the identifiers are of the same type (PUBLIC or SYSTEM) and have the same value. Note that if the identifiers are URLs, a comparison may fail even though both URLS point to the same resource, for example if one URL is relative and the other is absolute.
- Notation Declaration
-
Notation declarations are equal if they have the same name, and if the identifiers are of the same type (PUBLIC or SYSTEM) and have the same value.
- Elements
-
Elements are considered equal if they have the same generic identifier (tag name), belong to the same namespace, and have the same attributes. Note that the namespace prefixes of two elements may be different as long as they belong to the same namespace.
- Attributes
-
Attributes are equal if they belong to the same namespace, have the same name, and the same value.
- Namespace Declarations
-
Namespace declarations (attributes named
xmlns:prefix
) are ignored. There are several reasons for this:-
As long as two elements or attributes belong to the same namespace, it does not matter what prefixes are used. XML processors may also change prefixes in unpredictable ways without this being an error.
-
XML processors may move namespace declarations from one element to another (usually an ancestor, sometimes a descendant) without this being an error, or under control by the programmer.
-
XML processors may add extraneous namespace declarations in a manner that is hard for programmers to control.
-
- Processing Instructions
-
Processing instructions are considered equal if the string values of their targets and contents are equal.
- Text
-
Text nodes are equal if their values are equal. However, empty text nodes, and text nodes containing only whitespace are ignored.
- CDATA
-
CDATA nodes are equal if their text content is equal. Whitespace is not normalized.
- Comments
-
Comments are equal if they have the same content.
The expected_doc
and actual_doc
arguments to this method may be of the following types:
-
A
REXML
node, usually aREXML::Document
orREXML::Element
-
A
File
or otherIO
object representing an XML document -
A string containing an XML document
96 97 98 99 100 101 102 103 104 105 106 107 |
# File 'lib/test/unit/xml/xml_assertions.rb', line 96 def assert_xml_equal(expected_doc, actual_doc, = nil) expected_doc = parse_xml(expected_doc) actual_doc = parse_xml(actual_doc) _wrap_assertion do = (, <<EOT, actual_doc.inspect, expected_doc.inspect) <?> expected to be equal to <?> but was not. EOT assert_block(){are_equal?(expected_doc, actual_doc)} end end |
#assert_xml_not_equal(expected_doc, actual_doc, message = nil) ⇒ Object
This method compares two XML documents and returns true
if they are not equal, false
otherwise. This is the inverse of assert_xml_equal.
112 113 114 115 116 117 118 119 120 121 122 123 |
# File 'lib/test/unit/xml/xml_assertions.rb', line 112 def assert_xml_not_equal(expected_doc, actual_doc, = nil) expected_doc = parse_xml(expected_doc) actual_doc = parse_xml(actual_doc) _wrap_assertion do = (, <<EOT, actual_doc.inspect, expected_doc.inspect) <?> expected not to be equal to <?> but was equal. EOT assert_block(){ ! are_equal?(expected_doc, actual_doc)} end end |