msxml3/tests: Tests more XMLSAXReader versions.

This commit is contained in:
Piotr Caban 2011-10-24 20:09:12 +02:00 committed by Alexandre Julliard
parent 2b671cad96
commit 6238926a2e
1 changed files with 109 additions and 57 deletions

View File

@ -100,7 +100,7 @@ static const WCHAR szCarriageRetTest[] = {
'<','B','a','n','k','A','c','c','o','u','n','t','>','\r','\n', '<','B','a','n','k','A','c','c','o','u','n','t','>','\r','\n',
'\t','<','N','u','m','b','e','r','>','1','2','3','4','<','/','N','u','m','b','e','r','>','\r','\n', '\t','<','N','u','m','b','e','r','>','1','2','3','4','<','/','N','u','m','b','e','r','>','\r','\n',
'\t','<','N','a','m','e','>','C','a','p','t','a','i','n',' ','A','h','a','b','<','/','N','a','m','e','>','\r','\n', '\t','<','N','a','m','e','>','C','a','p','t','a','i','n',' ','A','h','a','b','<','/','N','a','m','e','>','\r','\n',
'<','/','B','a','n','k','A','c','c','o','u','n','t','>','\0' '<','/','B','a','n','k','A','c','c','o','u','n','t','>','\r','\n','\0'
}; };
static const WCHAR szUtf16XML[] = { static const WCHAR szUtf16XML[] = {
@ -125,6 +125,8 @@ typedef struct _contenthandlercheck {
CH id; CH id;
int line; int line;
int column; int column;
int line_v6;
int column_v6;
const char *arg1; const char *arg1;
const char *arg2; const char *arg2;
const char *arg3; const char *arg3;
@ -132,58 +134,77 @@ typedef struct _contenthandlercheck {
} content_handler_test; } content_handler_test;
static content_handler_test contentHandlerTest1[] = { static content_handler_test contentHandlerTest1[] = {
{ CH_PUTDOCUMENTLOCATOR, 0, 0 }, { CH_PUTDOCUMENTLOCATOR, 0, 0, 1, 0 },
{ CH_STARTDOCUMENT, 0, 0 }, { CH_STARTDOCUMENT, 0, 0, 1, 22 },
{ CH_STARTELEMENT, 2, 14, "", "BankAccount", "BankAccount" }, { CH_STARTELEMENT, 2, 14, 2, 13, "", "BankAccount", "BankAccount" },
{ CH_CHARACTERS, 2, 14, "\n " }, { CH_CHARACTERS, 2, 14, 3, 4, "\n " },
{ CH_STARTELEMENT, 3, 12, "", "Number", "Number" }, { CH_STARTELEMENT, 3, 12, 3, 11, "", "Number", "Number" },
{ CH_CHARACTERS, 3, 12, "1234" }, { CH_CHARACTERS, 3, 12, 3, 16, "1234" },
{ CH_ENDELEMENT, 3, 18, "", "Number", "Number" }, { CH_ENDELEMENT, 3, 18, 3, 24, "", "Number", "Number" },
{ CH_CHARACTERS, 3, 25, "\n " }, { CH_CHARACTERS, 3, 25, 4, 4, "\n " },
{ CH_STARTELEMENT, 4, 10, "", "Name", "Name" }, { CH_STARTELEMENT, 4, 10, 4, 9, "", "Name", "Name" },
{ CH_CHARACTERS, 4, 10, "Captain Ahab" }, { CH_CHARACTERS, 4, 10, 4, 22, "Captain Ahab" },
{ CH_ENDELEMENT, 4, 24, "", "Name", "Name" }, { CH_ENDELEMENT, 4, 24, 4, 28, "", "Name", "Name" },
{ CH_CHARACTERS, 4, 29, "\n" }, { CH_CHARACTERS, 4, 29, 5, 1, "\n" },
{ CH_ENDELEMENT, 5, 3, "", "BankAccount", "BankAccount" }, { CH_ENDELEMENT, 5, 3, 5, 14, "", "BankAccount", "BankAccount" },
{ CH_ENDDOCUMENT, 0, 0 }, { CH_ENDDOCUMENT, 0, 0, 6, 0 },
{ CH_ENDTEST } { CH_ENDTEST }
}; };
static content_handler_test contentHandlerTest2[] = { static content_handler_test contentHandlerTest2[] = {
{ CH_PUTDOCUMENTLOCATOR, 0, 0 }, { CH_PUTDOCUMENTLOCATOR, 0, 0, 1, 0 },
{ CH_STARTDOCUMENT, 0, 0 }, { CH_STARTDOCUMENT, 0, 0, 1, 21 },
{ CH_STARTELEMENT, 2, 14, "", "BankAccount", "BankAccount" }, { CH_STARTELEMENT, 2, 14, 2, 13, "", "BankAccount", "BankAccount" },
{ CH_CHARACTERS, 2, 14, "\n" }, { CH_CHARACTERS, 2, 14, 3, 0, "\n" },
{ CH_CHARACTERS, 2, 16, "\t" }, { CH_CHARACTERS, 2, 16, 3, 2, "\t" },
{ CH_STARTELEMENT, 3, 10, "", "Number", "Number" }, { CH_STARTELEMENT, 3, 10, 3, 9, "", "Number", "Number" },
{ CH_CHARACTERS, 3, 10, "1234" }, { CH_CHARACTERS, 3, 10, 3, 14, "1234" },
{ CH_ENDELEMENT, 3, 16, "", "Number", "Number" }, { CH_ENDELEMENT, 3, 16, 3, 22, "", "Number", "Number" },
{ CH_CHARACTERS, 3, 23, "\n" }, { CH_CHARACTERS, 3, 23, 4, 0, "\n" },
{ CH_CHARACTERS, 3, 25, "\t" }, { CH_CHARACTERS, 3, 25, 4, 2, "\t" },
{ CH_STARTELEMENT, 4, 8, "", "Name", "Name" }, { CH_STARTELEMENT, 4, 8, 4, 7, "", "Name", "Name" },
{ CH_CHARACTERS, 4, 8, "Captain Ahab" }, { CH_CHARACTERS, 4, 8, 4, 20, "Captain Ahab" },
{ CH_ENDELEMENT, 4, 22, "", "Name", "Name" }, { CH_ENDELEMENT, 4, 22, 4, 26, "", "Name", "Name" },
{ CH_CHARACTERS, 4, 27, "\n" }, { CH_CHARACTERS, 4, 27, 5, 0, "\n" },
{ CH_ENDELEMENT, 5, 3, "", "BankAccount", "BankAccount" }, { CH_ENDELEMENT, 5, 3, 5, 14, "", "BankAccount", "BankAccount" },
{ CH_ENDDOCUMENT, 0, 0 }, { CH_ENDDOCUMENT, 0, 0, 6, 0 },
{ CH_ENDTEST } { CH_ENDTEST }
}; };
static content_handler_test contentHandlerTestError[] = { static content_handler_test contentHandlerTestError[] = {
{ CH_PUTDOCUMENTLOCATOR, 0, 0, NULL, NULL, NULL, E_FAIL }, { CH_PUTDOCUMENTLOCATOR, 0, 0, 1, 0, NULL, NULL, NULL, E_FAIL },
{ EH_FATALERROR, 0, 0, NULL, NULL, NULL, E_FAIL }, { EH_FATALERROR, 0, 0, 0, 0, NULL, NULL, NULL, E_FAIL },
{ CH_ENDTEST } { CH_ENDTEST }
}; };
static content_handler_test contentHandlerTestCallbackResults[] = { static content_handler_test contentHandlerTestCallbackResults[] = {
{ CH_PUTDOCUMENTLOCATOR, 0, 0, NULL, NULL, NULL, S_FALSE }, { CH_PUTDOCUMENTLOCATOR, 0, 0, 1, 0, NULL, NULL, NULL, S_FALSE },
{ CH_STARTDOCUMENT, 0, 0, NULL, NULL, NULL, S_FALSE }, { CH_STARTDOCUMENT, 0, 0, 1, 22, NULL, NULL, NULL, S_FALSE },
{ EH_FATALERROR, 0, 0, NULL, NULL, NULL, S_FALSE }, { EH_FATALERROR, 0, 0, 0, 0, NULL, NULL, NULL, S_FALSE },
{ CH_ENDTEST }
};
static content_handler_test contentHandlerTestCallbackResult6[] = {
{ CH_PUTDOCUMENTLOCATOR, 0, 0, 1, 0, NULL, NULL, NULL, S_FALSE },
{ CH_STARTDOCUMENT, 0, 0, 1, 22, NULL, NULL, NULL, S_FALSE },
{ CH_STARTELEMENT, 2, 14, 2, 13, "", "BankAccount", "BankAccount", S_FALSE },
{ CH_CHARACTERS, 2, 14, 3, 4, "\n ", NULL, NULL, S_FALSE },
{ CH_STARTELEMENT, 3, 12, 3, 11, "", "Number", "Number", S_FALSE },
{ CH_CHARACTERS, 3, 12, 3, 16, "1234", NULL, NULL, S_FALSE },
{ CH_ENDELEMENT, 3, 18, 3, 24, "", "Number", "Number", S_FALSE },
{ CH_CHARACTERS, 3, 25, 4, 4, "\n ", NULL, NULL, S_FALSE },
{ CH_STARTELEMENT, 4, 10, 4, 9, "", "Name", "Name", S_FALSE },
{ CH_CHARACTERS, 4, 10, 4, 22, "Captain Ahab", NULL, NULL, S_FALSE },
{ CH_ENDELEMENT, 4, 24, 4, 28, "", "Name", "Name", S_FALSE },
{ CH_CHARACTERS, 4, 29, 5, 1, "\n", NULL, NULL, S_FALSE },
{ CH_ENDELEMENT, 5, 3, 5, 14, "", "BankAccount", "BankAccount", S_FALSE },
{ CH_ENDDOCUMENT, 0, 0, 6, 0, NULL, NULL, NULL, S_FALSE },
{ CH_ENDTEST } { CH_ENDTEST }
}; };
static content_handler_test *expectCall; static content_handler_test *expectCall;
static ISAXLocator *locator; static ISAXLocator *locator;
int msxml_version;
static void test_saxstr(unsigned line, const WCHAR *szStr, int nStr, const char *szTest) static void test_saxstr(unsigned line, const WCHAR *szStr, int nStr, const char *szTest)
{ {
@ -263,7 +284,8 @@ static HRESULT WINAPI contentHandler_putDocumentLocator(
return E_FAIL; return E_FAIL;
locator = pLocator; locator = pLocator;
test_locator(__LINE__, expectCall->line, expectCall->column); test_locator(__LINE__, msxml_version>=6 ? expectCall->line_v6 : expectCall->line,
msxml_version>=6 ? expectCall->column_v6 : expectCall->column);
return (expectCall++)->ret; return (expectCall++)->ret;
} }
@ -274,7 +296,8 @@ static HRESULT WINAPI contentHandler_startDocument(
if(!test_expect_call(CH_STARTDOCUMENT)) if(!test_expect_call(CH_STARTDOCUMENT))
return E_FAIL; return E_FAIL;
test_locator(__LINE__, expectCall->line, expectCall->column); test_locator(__LINE__, msxml_version>=6 ? expectCall->line_v6 : expectCall->line,
msxml_version>=6 ? expectCall->column_v6 : expectCall->column);
return (expectCall++)->ret; return (expectCall++)->ret;
} }
@ -285,7 +308,8 @@ static HRESULT WINAPI contentHandler_endDocument(
if(!test_expect_call(CH_ENDDOCUMENT)) if(!test_expect_call(CH_ENDDOCUMENT))
return E_FAIL; return E_FAIL;
test_locator(__LINE__, expectCall->line, expectCall->column); test_locator(__LINE__, msxml_version>=6 ? expectCall->line_v6 : expectCall->line,
msxml_version>=6 ? expectCall->column_v6 : expectCall->column);
return (expectCall++)->ret; return (expectCall++)->ret;
} }
@ -302,7 +326,8 @@ static HRESULT WINAPI contentHandler_startPrefixMapping(
test_saxstr(__LINE__, pPrefix, nPrefix, expectCall->arg1); test_saxstr(__LINE__, pPrefix, nPrefix, expectCall->arg1);
test_saxstr(__LINE__, pUri, nUri, expectCall->arg2); test_saxstr(__LINE__, pUri, nUri, expectCall->arg2);
test_locator(__LINE__, expectCall->line, expectCall->column); test_locator(__LINE__, msxml_version>=6 ? expectCall->line_v6 : expectCall->line,
msxml_version>=6 ? expectCall->column_v6 : expectCall->column);
return (expectCall++)->ret; return (expectCall++)->ret;
} }
@ -316,7 +341,8 @@ static HRESULT WINAPI contentHandler_endPrefixMapping(
return E_FAIL; return E_FAIL;
test_saxstr(__LINE__, pPrefix, nPrefix, expectCall->arg1); test_saxstr(__LINE__, pPrefix, nPrefix, expectCall->arg1);
test_locator(__LINE__, expectCall->line, expectCall->column); test_locator(__LINE__, msxml_version>=6 ? expectCall->line_v6 : expectCall->line,
msxml_version>=6 ? expectCall->column_v6 : expectCall->column);
return (expectCall++)->ret; return (expectCall++)->ret;
} }
@ -337,7 +363,8 @@ static HRESULT WINAPI contentHandler_startElement(
test_saxstr(__LINE__, pNamespaceUri, nNamespaceUri, expectCall->arg1); test_saxstr(__LINE__, pNamespaceUri, nNamespaceUri, expectCall->arg1);
test_saxstr(__LINE__, pLocalName, nLocalName, expectCall->arg2); test_saxstr(__LINE__, pLocalName, nLocalName, expectCall->arg2);
test_saxstr(__LINE__, pQName, nQName, expectCall->arg3); test_saxstr(__LINE__, pQName, nQName, expectCall->arg3);
test_locator(__LINE__, expectCall->line, expectCall->column); test_locator(__LINE__, msxml_version>=6 ? expectCall->line_v6 : expectCall->line,
msxml_version>=6 ? expectCall->column_v6 : expectCall->column);
return (expectCall++)->ret; return (expectCall++)->ret;
} }
@ -357,7 +384,8 @@ static HRESULT WINAPI contentHandler_endElement(
test_saxstr(__LINE__, pNamespaceUri, nNamespaceUri, expectCall->arg1); test_saxstr(__LINE__, pNamespaceUri, nNamespaceUri, expectCall->arg1);
test_saxstr(__LINE__, pLocalName, nLocalName, expectCall->arg2); test_saxstr(__LINE__, pLocalName, nLocalName, expectCall->arg2);
test_saxstr(__LINE__, pQName, nQName, expectCall->arg3); test_saxstr(__LINE__, pQName, nQName, expectCall->arg3);
test_locator(__LINE__, expectCall->line, expectCall->column); test_locator(__LINE__, msxml_version>=6 ? expectCall->line_v6 : expectCall->line,
msxml_version>=6 ? expectCall->column_v6 : expectCall->column);
return (expectCall++)->ret; return (expectCall++)->ret;
} }
@ -371,7 +399,8 @@ static HRESULT WINAPI contentHandler_characters(
return E_FAIL; return E_FAIL;
test_saxstr(__LINE__, pChars, nChars, expectCall->arg1); test_saxstr(__LINE__, pChars, nChars, expectCall->arg1);
test_locator(__LINE__, expectCall->line, expectCall->column); test_locator(__LINE__, msxml_version>=6 ? expectCall->line_v6 : expectCall->line,
msxml_version>=6 ? expectCall->column_v6 : expectCall->column);
return (expectCall++)->ret; return (expectCall++)->ret;
} }
@ -385,7 +414,8 @@ static HRESULT WINAPI contentHandler_ignorableWhitespace(
return E_FAIL; return E_FAIL;
test_saxstr(__LINE__, pChars, nChars, expectCall->arg1); test_saxstr(__LINE__, pChars, nChars, expectCall->arg1);
test_locator(__LINE__, expectCall->line, expectCall->column); test_locator(__LINE__, msxml_version>=6 ? expectCall->line_v6 : expectCall->line,
msxml_version>=6 ? expectCall->column_v6 : expectCall->column);
return (expectCall++)->ret; return (expectCall++)->ret;
} }
@ -402,7 +432,8 @@ static HRESULT WINAPI contentHandler_processingInstruction(
test_saxstr(__LINE__, pTarget, nTarget, expectCall->arg1); test_saxstr(__LINE__, pTarget, nTarget, expectCall->arg1);
test_saxstr(__LINE__, pData, nData, expectCall->arg2); test_saxstr(__LINE__, pData, nData, expectCall->arg2);
test_locator(__LINE__, expectCall->line, expectCall->column); test_locator(__LINE__, msxml_version>=6 ? expectCall->line_v6 : expectCall->line,
msxml_version>=6 ? expectCall->column_v6 : expectCall->column);
return (expectCall++)->ret; return (expectCall++)->ret;
} }
@ -416,7 +447,8 @@ static HRESULT WINAPI contentHandler_skippedEntity(
return E_FAIL; return E_FAIL;
test_saxstr(__LINE__, pName, nName, expectCall->arg1); test_saxstr(__LINE__, pName, nName, expectCall->arg1);
test_locator(__LINE__, expectCall->line, expectCall->column); test_locator(__LINE__, msxml_version>=6 ? expectCall->line_v6 : expectCall->line,
msxml_version>=6 ? expectCall->column_v6 : expectCall->column);
return (expectCall++)->ret; return (expectCall++)->ret;
} }
@ -1041,7 +1073,7 @@ static const IStreamVtbl StreamVtbl = {
static IStream mxstream = { &StreamVtbl }; static IStream mxstream = { &StreamVtbl };
static void test_saxreader(void) static void test_saxreader(int version)
{ {
HRESULT hr; HRESULT hr;
ISAXXMLReader *reader = NULL; ISAXXMLReader *reader = NULL;
@ -1062,15 +1094,30 @@ static void test_saxreader(void)
BSTR bstrData; BSTR bstrData;
VARIANT_BOOL vBool; VARIANT_BOOL vBool;
hr = CoCreateInstance(&CLSID_SAXXMLReader, NULL, CLSCTX_INPROC_SERVER, msxml_version = version;
&IID_ISAXXMLReader, (LPVOID*)&reader); if(version == 3) {
hr = CoCreateInstance(&CLSID_SAXXMLReader30, NULL, CLSCTX_INPROC_SERVER,
&IID_ISAXXMLReader, (LPVOID*)&reader);
} else if(version == 6) {
hr = CoCreateInstance(&CLSID_SAXXMLReader60, NULL, CLSCTX_INPROC_SERVER,
&IID_ISAXXMLReader, (LPVOID*)&reader);
if(hr == REGDB_E_CLASSNOTREG) {
win_skip("SAXXMLReader6 not registered\n");
return;
}
} else {
hr = CoCreateInstance(&CLSID_SAXXMLReader, NULL, CLSCTX_INPROC_SERVER,
&IID_ISAXXMLReader, (LPVOID*)&reader);
}
ok(hr == S_OK, "Expected S_OK, got %08x\n", hr); ok(hr == S_OK, "Expected S_OK, got %08x\n", hr);
hr = ISAXXMLReader_getContentHandler(reader, NULL); if(version != 6) {
ok(hr == E_POINTER, "Expected E_POINTER, got %08x\n", hr); hr = ISAXXMLReader_getContentHandler(reader, NULL);
ok(hr == E_POINTER, "Expected E_POINTER, got %08x\n", hr);
hr = ISAXXMLReader_getErrorHandler(reader, NULL); hr = ISAXXMLReader_getErrorHandler(reader, NULL);
ok(hr == E_POINTER, "Expected E_POINTER, got %08x\n", hr); ok(hr == E_POINTER, "Expected E_POINTER, got %08x\n", hr);
}
hr = ISAXXMLReader_getContentHandler(reader, &lpContentHandler); hr = ISAXXMLReader_getContentHandler(reader, &lpContentHandler);
ok(hr == S_OK, "Expected S_OK, got %08x\n", hr); ok(hr == S_OK, "Expected S_OK, got %08x\n", hr);
@ -1160,9 +1207,12 @@ static void test_saxreader(void)
ok(hr == E_FAIL, "Expected E_FAIL, got %08x\n", hr); ok(hr == E_FAIL, "Expected E_FAIL, got %08x\n", hr);
test_expect_call(CH_ENDTEST); test_expect_call(CH_ENDTEST);
expectCall = contentHandlerTestCallbackResults; if(version >= 6)
expectCall = contentHandlerTestCallbackResult6;
else
expectCall = contentHandlerTestCallbackResults;
hr = ISAXXMLReader_parseURL(reader, testXmlW); hr = ISAXXMLReader_parseURL(reader, testXmlW);
ok(hr == S_FALSE, "Expected S_FALSE, got %08x\n", hr); ok(hr == (version>=6 ? S_OK : S_FALSE), "Expected S_FALSE, got %08x\n", hr);
test_expect_call(CH_ENDTEST); test_expect_call(CH_ENDTEST);
DeleteFileA(testXmlA); DeleteFileA(testXmlA);
@ -2394,7 +2444,9 @@ START_TEST(saxreader)
} }
ISAXXMLReader_Release(reader); ISAXXMLReader_Release(reader);
test_saxreader(); test_saxreader(0);
test_saxreader(3);
test_saxreader(6);
test_saxreader_properties(); test_saxreader_properties();
test_saxreader_features(); test_saxreader_features();
test_encoding(); test_encoding();