mirror of
				https://github.com/AxioDL/tinyxml2.git
				synced 2025-10-25 19:30:26 +00:00 
			
		
		
		
	"Found" and "expected" were swapped in some tests
This commit is contained in:
		
							parent
							
								
									369f306b37
								
							
						
					
					
						commit
						9832a5f05d
					
				
							
								
								
									
										123
									
								
								xmltest.cpp
									
									
									
									
									
								
							
							
						
						
									
										123
									
								
								xmltest.cpp
									
									
									
									
									
								
							| @ -435,10 +435,10 @@ int main( int argc, const char ** argv ) | ||||
| 		XMLTest( "Programmatic DOM", true, doc->FirstChildElement()->FirstChildElement()->BoolAttribute( "attrib" ) ); | ||||
| 		int value1 = 10; | ||||
| 		int value2 = doc->FirstChildElement()->LastChildElement()->IntAttribute( "attrib", 10 ); | ||||
| 		int result = doc->FirstChildElement()->LastChildElement()->QueryIntAttribute( "attrib", &value1 ); | ||||
| 		XMLTest( "Programmatic DOM", result, (int)XML_NO_ATTRIBUTE ); | ||||
| 		XMLTest( "Programmatic DOM", value1, 10 ); | ||||
| 		XMLTest( "Programmatic DOM", value2, 10 ); | ||||
| 		XMLError result = doc->FirstChildElement()->LastChildElement()->QueryIntAttribute( "attrib", &value1 ); | ||||
| 		XMLTest( "Programmatic DOM", XML_NO_ATTRIBUTE, result ); | ||||
| 		XMLTest( "Programmatic DOM", 10, value1 ); | ||||
| 		XMLTest( "Programmatic DOM", 10, value2 ); | ||||
| 
 | ||||
| 		doc->Print(); | ||||
| 
 | ||||
| @ -499,7 +499,7 @@ int main( int argc, const char ** argv ) | ||||
| 
 | ||||
| 		XMLDocument doc; | ||||
| 		doc.Parse( error ); | ||||
| 		XMLTest( "Bad XML", doc.ErrorID(), XML_ERROR_PARSING_ATTRIBUTE ); | ||||
| 		XMLTest( "Bad XML", XML_ERROR_PARSING_ATTRIBUTE, doc.ErrorID() ); | ||||
| 	} | ||||
| 
 | ||||
| 	{ | ||||
| @ -510,30 +510,31 @@ int main( int argc, const char ** argv ) | ||||
| 
 | ||||
| 		XMLElement* ele = doc.FirstChildElement(); | ||||
| 
 | ||||
| 		int iVal, result; | ||||
| 		int iVal; | ||||
| 		XMLError result; | ||||
| 		double dVal; | ||||
| 
 | ||||
| 		result = ele->QueryDoubleAttribute( "attr0", &dVal ); | ||||
| 		XMLTest( "Query attribute: int as double", result, (int)XML_SUCCESS); | ||||
| 		XMLTest( "Query attribute: int as double", (int)dVal, 1 ); | ||||
| 		XMLTest( "Query attribute: int as double", (int)ele->DoubleAttribute("attr0"), 1); | ||||
| 		XMLTest( "Query attribute: int as double", XML_SUCCESS, result); | ||||
| 		XMLTest( "Query attribute: int as double", 1, (int)dVal ); | ||||
| 		XMLTest( "Query attribute: int as double", 1, (int)ele->DoubleAttribute("attr0")); | ||||
| 
 | ||||
| 		result = ele->QueryDoubleAttribute( "attr1", &dVal ); | ||||
| 		XMLTest( "Query attribute: double as double", result, (int)XML_SUCCESS); | ||||
| 		XMLTest( "Query attribute: double as double", dVal, 2.0 ); | ||||
| 		XMLTest( "Query attribute: double as double", ele->DoubleAttribute("attr1"), 2.0 ); | ||||
| 		XMLTest( "Query attribute: double as double", XML_SUCCESS, result); | ||||
| 		XMLTest( "Query attribute: double as double", 2.0, dVal ); | ||||
| 		XMLTest( "Query attribute: double as double", 2.0, ele->DoubleAttribute("attr1") ); | ||||
| 
 | ||||
| 		result = ele->QueryIntAttribute( "attr1", &iVal ); | ||||
| 		XMLTest( "Query attribute: double as int", result, (int)XML_SUCCESS); | ||||
| 		XMLTest( "Query attribute: double as int", iVal, 2 ); | ||||
| 		XMLTest( "Query attribute: double as int", XML_SUCCESS, result); | ||||
| 		XMLTest( "Query attribute: double as int", 2, iVal ); | ||||
| 
 | ||||
| 		result = ele->QueryIntAttribute( "attr2", &iVal ); | ||||
| 		XMLTest( "Query attribute: not a number", result, (int)XML_WRONG_ATTRIBUTE_TYPE ); | ||||
| 		XMLTest( "Query attribute: not a number", ele->DoubleAttribute("attr2", 4.0), 4.0 ); | ||||
| 		XMLTest( "Query attribute: not a number", XML_WRONG_ATTRIBUTE_TYPE, result ); | ||||
| 		XMLTest( "Query attribute: not a number", 4.0, ele->DoubleAttribute("attr2", 4.0) ); | ||||
| 
 | ||||
| 		result = ele->QueryIntAttribute( "bar", &iVal ); | ||||
| 		XMLTest( "Query attribute: does not exist", result, (int)XML_NO_ATTRIBUTE ); | ||||
| 		XMLTest( "Query attribute: does not exist", ele->BoolAttribute("bar", true), true ); | ||||
| 		XMLTest( "Query attribute: does not exist", XML_NO_ATTRIBUTE, result ); | ||||
| 		XMLTest( "Query attribute: does not exist", true, ele->BoolAttribute("bar", true) ); | ||||
| 	} | ||||
| 
 | ||||
| 	{ | ||||
| @ -558,7 +559,7 @@ int main( int argc, const char ** argv ) | ||||
| 		ele->QueryAttribute( "int", &iVal2 ); | ||||
| 		ele->QueryAttribute( "double", &dVal2 ); | ||||
| 
 | ||||
| 		XMLTest( "Attribute match test", ele->Attribute( "str", "strValue" ), "strValue" ); | ||||
| 		XMLTest( "Attribute match test", "strValue", ele->Attribute( "str", "strValue" ) ); | ||||
| 		XMLTest( "Attribute round trip. c-string.", "strValue", cStr ); | ||||
| 		XMLTest( "Attribute round trip. int.", 1, iVal ); | ||||
| 		XMLTest( "Attribute round trip. double.", -1, (int)dVal ); | ||||
| @ -796,7 +797,7 @@ int main( int argc, const char ** argv ) | ||||
| 		{ | ||||
| 			XMLDocument doc; | ||||
| 			doc.LoadFile("resources/printer.xml"); | ||||
| 			XMLTest("XMLPrinter Stream mode: load", doc.ErrorID(), XML_SUCCESS, true); | ||||
| 			XMLTest("XMLPrinter Stream mode: load", XML_SUCCESS, doc.ErrorID(), true); | ||||
| 
 | ||||
| 			const XMLDocument& cdoc = doc; | ||||
| 
 | ||||
| @ -829,8 +830,8 @@ int main( int argc, const char ** argv ) | ||||
| 		doc.Parse( str ); | ||||
| 		doc.Print(); | ||||
| 
 | ||||
| 		XMLTest( "CDATA parse.", doc.FirstChildElement()->FirstChild()->Value(), | ||||
| 								 "I am > the rules!\n...since I make symbolic puns", | ||||
| 		XMLTest( "CDATA parse.", "I am > the rules!\n...since I make symbolic puns", | ||||
| 								 doc.FirstChildElement()->FirstChild()->Value(), | ||||
| 								 false ); | ||||
| 	} | ||||
| 
 | ||||
| @ -846,8 +847,9 @@ int main( int argc, const char ** argv ) | ||||
| 		doc.Parse( str ); | ||||
| 		doc.Print(); | ||||
| 
 | ||||
| 		XMLTest( "CDATA parse. [ tixml1:1480107 ]", doc.FirstChildElement()->FirstChild()->Value(), | ||||
| 		XMLTest( "CDATA parse. [ tixml1:1480107 ]", | ||||
| 								 "<b>I am > the rules!</b>\n...since I make symbolic puns", | ||||
| 								 doc.FirstChildElement()->FirstChild()->Value(), | ||||
| 								 false ); | ||||
| 	} | ||||
| 
 | ||||
| @ -864,7 +866,7 @@ int main( int argc, const char ** argv ) | ||||
| 		XMLNode* childNode0 = parent->InsertEndChild( childText0 ); | ||||
| 		XMLNode* childNode1 = parent->InsertAfterChild( childNode0, childText1 ); | ||||
| 
 | ||||
| 		XMLTest( "Test InsertAfterChild on empty node. ", ( childNode1 == parent->LastChild() ), true ); | ||||
| 		XMLTest( "Test InsertAfterChild on empty node. ", true, ( childNode1 == parent->LastChild() ) ); | ||||
| 	} | ||||
| 
 | ||||
| 	{ | ||||
| @ -919,10 +921,11 @@ int main( int argc, const char ** argv ) | ||||
| 		XMLDocument doc( false ); | ||||
| 		doc.Parse( passages ); | ||||
| 
 | ||||
| 		XMLTest( "No entity parsing.", doc.FirstChildElement()->FirstChildElement()->Attribute( "context" ), | ||||
| 				 "Line 5 has "quotation marks" and 'apostrophe marks'." ); | ||||
| 		XMLTest( "No entity parsing.", doc.FirstChildElement()->FirstChildElement()->FirstChild()->Value(), | ||||
| 				 "Crazy &ttk;" ); | ||||
| 		XMLTest( "No entity parsing.", | ||||
| 				 "Line 5 has "quotation marks" and 'apostrophe marks'.", | ||||
| 				 doc.FirstChildElement()->FirstChildElement()->Attribute( "context" ) ); | ||||
| 		XMLTest( "No entity parsing.", "Crazy &ttk;", | ||||
| 				 doc.FirstChildElement()->FirstChildElement()->FirstChild()->Value() ); | ||||
| 		doc.Print(); | ||||
| 	} | ||||
| 
 | ||||
| @ -931,9 +934,9 @@ int main( int argc, const char ** argv ) | ||||
| 
 | ||||
| 		XMLDocument doc; | ||||
| 		doc.Parse( test ); | ||||
| 		XMLTest( "dot in names", doc.Error(), false ); | ||||
| 		XMLTest( "dot in names", doc.FirstChildElement()->Name(), "a.elem" ); | ||||
| 		XMLTest( "dot in names", doc.FirstChildElement()->Attribute( "xmi.version" ), "2.0" ); | ||||
| 		XMLTest( "dot in names", false, doc.Error() ); | ||||
| 		XMLTest( "dot in names", "a.elem", doc.FirstChildElement()->Name() ); | ||||
| 		XMLTest( "dot in names", "2.0", doc.FirstChildElement()->Attribute( "xmi.version" ) ); | ||||
| 	} | ||||
| 
 | ||||
| 	{ | ||||
| @ -944,7 +947,7 @@ int main( int argc, const char ** argv ) | ||||
| 
 | ||||
| 		XMLText* text = doc.FirstChildElement()->FirstChildElement()->FirstChild()->ToText(); | ||||
| 		XMLTest( "Entity with one digit.", | ||||
| 				 text->Value(), "1.1 Start easy ignore fin thickness\n", | ||||
| 				 "1.1 Start easy ignore fin thickness\n", text->Value(), | ||||
| 				 false ); | ||||
| 	} | ||||
| 
 | ||||
| @ -1022,7 +1025,7 @@ int main( int argc, const char ** argv ) | ||||
| 		XMLDocument doc; | ||||
| 		doc.Parse( "<test></test>" ); | ||||
| 		const char result[] = { 0x0e, 0 }; | ||||
| 		XMLTest( "Low entities.", doc.FirstChildElement()->GetText(), result ); | ||||
| 		XMLTest( "Low entities.", result, doc.FirstChildElement()->GetText() ); | ||||
| 		doc.Print(); | ||||
| 	} | ||||
| 
 | ||||
| @ -1030,18 +1033,18 @@ int main( int argc, const char ** argv ) | ||||
| 		// Attribute values with trailing quotes not handled correctly
 | ||||
| 		XMLDocument doc; | ||||
| 		doc.Parse( "<foo attribute=bar\" />" ); | ||||
| 		XMLTest( "Throw error with bad end quotes.", doc.Error(), true ); | ||||
| 		XMLTest( "Throw error with bad end quotes.", true, doc.Error() ); | ||||
| 	} | ||||
| 
 | ||||
| 	{ | ||||
| 		// [ 1663758 ] Failure to report error on bad XML
 | ||||
| 		XMLDocument xml; | ||||
| 		xml.Parse("<x>"); | ||||
| 		XMLTest("Missing end tag at end of input", xml.Error(), true); | ||||
| 		XMLTest("Missing end tag at end of input", true, xml.Error()); | ||||
| 		xml.Parse("<x> "); | ||||
| 		XMLTest("Missing end tag with trailing whitespace", xml.Error(), true); | ||||
| 		XMLTest("Missing end tag with trailing whitespace", true, xml.Error()); | ||||
| 		xml.Parse("<x></y>"); | ||||
| 		XMLTest("Mismatched tags", xml.ErrorID(), XML_ERROR_MISMATCHED_ELEMENT); | ||||
| 		XMLTest("Mismatched tags", XML_ERROR_MISMATCHED_ELEMENT, xml.ErrorID() ); | ||||
| 	} | ||||
| 
 | ||||
| 
 | ||||
| @ -1286,7 +1289,7 @@ int main( int argc, const char ** argv ) | ||||
| 		doc.Parse( xml ); | ||||
| 
 | ||||
| 		XMLElement* ele = XMLHandle( doc ).FirstChildElement( "element" ).FirstChild().ToElement(); | ||||
| 		XMLTest( "Handle, success, mutable", ele->Value(), "sub" ); | ||||
| 		XMLTest( "Handle, success, mutable", "sub", ele->Value() ); | ||||
| 
 | ||||
| 		XMLHandle docH( doc ); | ||||
| 		ele = docH.FirstChildElement( "none" ).FirstChildElement( "element" ).ToElement(); | ||||
| @ -1315,8 +1318,8 @@ int main( int argc, const char ** argv ) | ||||
| 		doc.Print( &printer ); | ||||
| 
 | ||||
| 		static const char* result  = "\xef\xbb\xbf<?xml version=\"1.0\" encoding=\"UTF-8\"?>"; | ||||
| 		XMLTest( "BOM and default declaration", printer.CStr(), result, false ); | ||||
| 		XMLTest( "CStrSize", printer.CStrSize(), 42, false ); | ||||
| 		XMLTest( "BOM and default declaration", result, printer.CStr(), false ); | ||||
| 		XMLTest( "CStrSize", 42, printer.CStrSize(), false ); | ||||
| 	} | ||||
| 	{ | ||||
| 		const char* xml = "<ipxml ws='1'><info bla=' /></ipxml>"; | ||||
| @ -1346,50 +1349,50 @@ int main( int argc, const char ** argv ) | ||||
| 		pointElement->FirstChildElement( "valid" )->QueryBoolText( &boolValue ); | ||||
| 
 | ||||
| 
 | ||||
| 		XMLTest( "QueryIntText", intValue, 1,						false ); | ||||
| 		XMLTest( "QueryUnsignedText", unsignedValue, (unsigned)1,	false ); | ||||
| 		XMLTest( "QueryFloatText", floatValue, 1.2f,				false ); | ||||
| 		XMLTest( "QueryDoubleText", doubleValue, 1.2,				false ); | ||||
| 		XMLTest( "QueryBoolText", boolValue, true,					false ); | ||||
| 		XMLTest( "QueryIntText", 1, intValue,						false ); | ||||
| 		XMLTest( "QueryUnsignedText", (unsigned)1, unsignedValue,	false ); | ||||
| 		XMLTest( "QueryFloatText", 1.2f, floatValue,				false ); | ||||
| 		XMLTest( "QueryDoubleText", 1.2, doubleValue,				false ); | ||||
| 		XMLTest( "QueryBoolText", true, boolValue,					false ); | ||||
| 	} | ||||
| 
 | ||||
| 	{ | ||||
| 		const char* xml = "<element><_sub/><:sub/><sub:sub/><sub-sub/></element>"; | ||||
| 		XMLDocument doc; | ||||
| 		doc.Parse( xml ); | ||||
| 		XMLTest( "Non-alpha element lead letter parses.", doc.Error(), false ); | ||||
| 		XMLTest( "Non-alpha element lead letter parses.", false, doc.Error() ); | ||||
| 	} | ||||
|      | ||||
|     { | ||||
|         const char* xml = "<element _attr1=\"foo\" :attr2=\"bar\"></element>"; | ||||
|         XMLDocument doc; | ||||
|         doc.Parse( xml ); | ||||
|         XMLTest("Non-alpha attribute lead character parses.", doc.Error(), false); | ||||
|         XMLTest("Non-alpha attribute lead character parses.", false, doc.Error()); | ||||
|     } | ||||
|      | ||||
|     { | ||||
|         const char* xml = "<3lement></3lement>"; | ||||
|         XMLDocument doc; | ||||
|         doc.Parse( xml ); | ||||
|         XMLTest("Element names with lead digit fail to parse.", doc.Error(), true); | ||||
|         XMLTest("Element names with lead digit fail to parse.", true, doc.Error()); | ||||
|     } | ||||
| 
 | ||||
| 	{ | ||||
| 		const char* xml = "<element/>WOA THIS ISN'T GOING TO PARSE"; | ||||
| 		XMLDocument doc; | ||||
| 		doc.Parse( xml, 10 ); | ||||
| 		XMLTest( "Set length of incoming data", doc.Error(), false ); | ||||
| 		XMLTest( "Set length of incoming data", false, doc.Error() ); | ||||
| 	} | ||||
| 
 | ||||
|     { | ||||
|         XMLDocument doc; | ||||
|         XMLTest( "Document is initially empty", doc.NoChildren(), true ); | ||||
|         XMLTest( "Document is initially empty", true, doc.NoChildren() ); | ||||
|         doc.Clear(); | ||||
|         XMLTest( "Empty is empty after Clear()", doc.NoChildren(), true ); | ||||
|         XMLTest( "Empty is empty after Clear()", true, doc.NoChildren() ); | ||||
|         doc.LoadFile( "resources/dream.xml" ); | ||||
|         XMLTest( "Document has something to Clear()", doc.NoChildren(), false ); | ||||
|         XMLTest( "Document has something to Clear()", false, doc.NoChildren() ); | ||||
|         doc.Clear(); | ||||
|         XMLTest( "Document Clear()'s", doc.NoChildren(), true ); | ||||
|         XMLTest( "Document Clear()'s", true, doc.NoChildren() ); | ||||
|     } | ||||
|      | ||||
| 	// ----------- Whitespace ------------
 | ||||
| @ -1693,15 +1696,15 @@ int main( int argc, const char ** argv ) | ||||
| 
 | ||||
| 	    XMLDocument doc; | ||||
| 	    doc.Parse(xml0); | ||||
| 	    XMLTest("Test that the code changes do not affect normal parsing", doc.Error(), false); | ||||
| 	    XMLTest("Test that the code changes do not affect normal parsing", false, doc.Error() ); | ||||
| 	    doc.Parse(xml1); | ||||
| 	    XMLTest("Test that the second declaration is allowed", doc.Error(), false); | ||||
| 	    XMLTest("Test that the second declaration is allowed", false, doc.Error() ); | ||||
| 	    doc.Parse(xml2); | ||||
| 	    XMLTest("Test that declaration after a child is not allowed", doc.ErrorID(), XML_ERROR_PARSING_DECLARATION); | ||||
| 	    XMLTest("Test that declaration after a child is not allowed", XML_ERROR_PARSING_DECLARATION, doc.ErrorID() ); | ||||
| 	    doc.Parse(xml3); | ||||
| 	    XMLTest("Test that declaration after a child is not allowed", doc.ErrorID(), XML_ERROR_PARSING_DECLARATION); | ||||
| 	    XMLTest("Test that declaration after a child is not allowed", XML_ERROR_PARSING_DECLARATION, doc.ErrorID() ); | ||||
| 	    doc.Parse(xml4); | ||||
| 	    XMLTest("Test that declaration inside a child is not allowed", doc.ErrorID(), XML_ERROR_PARSING_DECLARATION); | ||||
| 	    XMLTest("Test that declaration inside a child is not allowed", XML_ERROR_PARSING_DECLARATION, doc.ErrorID() ); | ||||
| 	} | ||||
| 
 | ||||
|     { | ||||
| @ -1774,7 +1777,7 @@ int main( int argc, const char ** argv ) | ||||
| 		// an interesting test case.
 | ||||
| 		XMLDocument doc; | ||||
| 		XMLError err = doc.Parse(xml); | ||||
| 		XMLTest("Crash bug parsing", err, XML_SUCCESS); | ||||
| 		XMLTest("Crash bug parsing", XML_SUCCESS, err ); | ||||
| 
 | ||||
| 		XMLElement* playlist = doc.FirstChildElement("playlist"); | ||||
| 		XMLTest("Crash bug parsing", true, playlist != 0); | ||||
| @ -1803,7 +1806,7 @@ int main( int argc, const char ** argv ) | ||||
| 		for (const XMLElement* p = playlist->FirstChildElement("property"); p; p = p->NextSiblingElement("property")) { | ||||
| 			nProperty++; | ||||
| 		} | ||||
| 		XMLTest("Crash bug parsing", nProperty, 2); | ||||
| 		XMLTest("Crash bug parsing", 2, nProperty); | ||||
| 	} | ||||
| 
 | ||||
|     // ----------- Line Number Tracking --------------
 | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user