Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-winehq
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-winehq
Commits
1b2f1867
Commit
1b2f1867
authored
Jan 12, 2010
by
Nikolay Sivov
Committed by
Alexandre Julliard
Jan 14, 2010
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
msxml3/tests: Add some tests for IPersistStreamInit implementation of IXMLDocument.
parent
c2459dee
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
136 additions
and
33 deletions
+136
-33
xmldoc.c
dlls/msxml3/tests/xmldoc.c
+134
-32
xmldoc.c
dlls/msxml3/xmldoc.c
+2
-1
No files found.
dlls/msxml3/tests/xmldoc.c
View file @
1b2f1867
...
@@ -49,6 +49,33 @@ static void create_xml_file(LPCSTR filename)
...
@@ -49,6 +49,33 @@ static void create_xml_file(LPCSTR filename)
CloseHandle
(
hf
);
CloseHandle
(
hf
);
}
}
static
void
create_stream_on_file
(
IStream
**
stream
,
LPCSTR
path
)
{
HANDLE
hfile
;
HGLOBAL
hglobal
;
LPVOID
ptr
;
HRESULT
hr
;
DWORD
file_size
,
read
;
hfile
=
CreateFile
(
path
,
GENERIC_READ
,
FILE_SHARE_READ
,
NULL
,
OPEN_EXISTING
,
FILE_ATTRIBUTE_NORMAL
,
NULL
);
ok
(
hfile
!=
INVALID_HANDLE_VALUE
,
"Expected a valid file handle
\n
"
);
file_size
=
GetFileSize
(
hfile
,
NULL
);
hglobal
=
GlobalAlloc
(
GHND
,
file_size
);
ptr
=
GlobalLock
(
hglobal
);
ReadFile
(
hfile
,
ptr
,
file_size
,
&
read
,
NULL
);
ok
(
file_size
==
read
,
"Expected to read the whole file, read %d
\n
"
,
read
);
hr
=
CreateStreamOnHGlobal
(
hglobal
,
TRUE
,
stream
);
ok
(
hr
==
S_OK
,
"Expected S_OK, got %08x
\n
"
,
hr
);
ok
(
*
stream
!=
NULL
,
"Expected non-NULL stream
\n
"
);
CloseHandle
(
hfile
);
GlobalUnlock
(
hglobal
);
}
static
void
test_xmldoc
(
void
)
static
void
test_xmldoc
(
void
)
{
{
HRESULT
hr
;
HRESULT
hr
;
...
@@ -57,10 +84,6 @@ static void test_xmldoc(void)
...
@@ -57,10 +84,6 @@ static void test_xmldoc(void)
IXMLElementCollection
*
collection
=
NULL
,
*
inner
=
NULL
;
IXMLElementCollection
*
collection
=
NULL
,
*
inner
=
NULL
;
IPersistStreamInit
*
psi
=
NULL
;
IPersistStreamInit
*
psi
=
NULL
;
IStream
*
stream
=
NULL
;
IStream
*
stream
=
NULL
;
HGLOBAL
hglobal
;
HANDLE
hfile
;
LPVOID
ptr
;
DWORD
file_size
,
read
;
CHAR
path
[
MAX_PATH
];
CHAR
path
[
MAX_PATH
];
LONG
type
,
num_child
;
LONG
type
,
num_child
;
VARIANT
vIndex
,
vName
;
VARIANT
vIndex
,
vName
;
...
@@ -75,32 +98,11 @@ static void test_xmldoc(void)
...
@@ -75,32 +98,11 @@ static void test_xmldoc(void)
hr
=
CoCreateInstance
(
&
CLSID_XMLDocument
,
NULL
,
CLSCTX_INPROC_SERVER
,
hr
=
CoCreateInstance
(
&
CLSID_XMLDocument
,
NULL
,
CLSCTX_INPROC_SERVER
,
&
IID_IXMLDocument
,
(
LPVOID
*
)
&
doc
);
&
IID_IXMLDocument
,
(
LPVOID
*
)
&
doc
);
if
(
FAILED
(
hr
))
ok
(
hr
==
S_OK
,
"Expected S_OK, got %08x
\n
"
,
hr
);
{
skip
(
"Failed to create XMLDocument instance
\n
"
);
return
;
}
create_xml_file
(
"bank.xml"
);
create_xml_file
(
"bank.xml"
);
GetFullPathNameA
(
"bank.xml"
,
MAX_PATH
,
path
,
NULL
);
GetFullPathNameA
(
"bank.xml"
,
MAX_PATH
,
path
,
NULL
);
create_stream_on_file
(
&
stream
,
path
);
hfile
=
CreateFile
(
path
,
GENERIC_READ
,
FILE_SHARE_READ
,
NULL
,
OPEN_EXISTING
,
FILE_ATTRIBUTE_NORMAL
,
NULL
);
ok
(
hfile
!=
INVALID_HANDLE_VALUE
,
"Expected a valid file handle
\n
"
);
file_size
=
GetFileSize
(
hfile
,
NULL
);
hglobal
=
GlobalAlloc
(
GHND
,
file_size
);
ptr
=
GlobalLock
(
hglobal
);
ReadFile
(
hfile
,
ptr
,
file_size
,
&
read
,
NULL
);
ok
(
file_size
==
read
,
"Expected to read the whole file, read %d
\n
"
,
read
);
hr
=
CreateStreamOnHGlobal
(
hglobal
,
TRUE
,
&
stream
);
ok
(
hr
==
S_OK
,
"Expected S_OK, got %08x
\n
"
,
hr
);
ok
(
stream
!=
NULL
,
"Expected non-NULL stream
\n
"
);
CloseHandle
(
hfile
);
GlobalUnlock
(
hglobal
);
hr
=
IXMLDocument_QueryInterface
(
doc
,
&
IID_IPersistStreamInit
,
(
LPVOID
*
)
&
psi
);
hr
=
IXMLDocument_QueryInterface
(
doc
,
&
IID_IPersistStreamInit
,
(
LPVOID
*
)
&
psi
);
ok
(
hr
==
S_OK
,
"Expected S_OK, got %08x
\n
"
,
hr
);
ok
(
hr
==
S_OK
,
"Expected S_OK, got %08x
\n
"
,
hr
);
...
@@ -271,11 +273,7 @@ static void test_createElement(void)
...
@@ -271,11 +273,7 @@ static void test_createElement(void)
hr
=
CoCreateInstance
(
&
CLSID_XMLDocument
,
NULL
,
CLSCTX_INPROC_SERVER
,
hr
=
CoCreateInstance
(
&
CLSID_XMLDocument
,
NULL
,
CLSCTX_INPROC_SERVER
,
&
IID_IXMLDocument
,
(
LPVOID
*
)
&
doc
);
&
IID_IXMLDocument
,
(
LPVOID
*
)
&
doc
);
if
(
FAILED
(
hr
))
ok
(
hr
==
S_OK
,
"Expected S_OK, got %08x
\n
"
,
hr
);
{
skip
(
"Failed to create XMLDocument instance
\n
"
);
return
;
}
/* invalid vType type */
/* invalid vType type */
V_VT
(
&
vType
)
=
VT_NULL
;
V_VT
(
&
vType
)
=
VT_NULL
;
...
@@ -354,6 +352,103 @@ static void test_createElement(void)
...
@@ -354,6 +352,103 @@ static void test_createElement(void)
IXMLDocument_Release
(
doc
);
IXMLDocument_Release
(
doc
);
}
}
static
void
test_persiststreaminit
(
void
)
{
IXMLDocument
*
doc
=
NULL
;
IPersistStreamInit
*
psi
=
NULL
;
IStream
*
stream
=
NULL
;
STATSTG
stat
;
HRESULT
hr
;
ULARGE_INTEGER
size
;
CHAR
path
[
MAX_PATH
];
hr
=
CoCreateInstance
(
&
CLSID_XMLDocument
,
NULL
,
CLSCTX_INPROC_SERVER
,
&
IID_IXMLDocument
,
(
LPVOID
*
)
&
doc
);
ok
(
hr
==
S_OK
,
"Expected S_OK, got %08x
\n
"
,
hr
);
hr
=
IXMLDocument_QueryInterface
(
doc
,
&
IID_IPersistStreamInit
,
(
LPVOID
*
)
&
psi
);
ok
(
hr
==
S_OK
,
"Expected S_OK, got %08x
\n
"
,
hr
);
ok
(
psi
!=
NULL
,
"Expected non-NULL psi
\n
"
);
/* null arguments */
hr
=
IPersistStreamInit_GetSizeMax
(
psi
,
NULL
);
ok
(
hr
==
E_NOTIMPL
,
"Expected E_NOTIMPL, got %08x
\n
"
,
hr
);
hr
=
IPersistStreamInit_Load
(
psi
,
NULL
);
ok
(
hr
==
E_INVALIDARG
,
"Expected E_INVALIDARG, got %08x
\n
"
,
hr
);
hr
=
IPersistStreamInit_Save
(
psi
,
NULL
,
FALSE
);
todo_wine
ok
(
hr
==
E_INVALIDARG
,
"Expected E_INVALIDARG, got %08x
\n
"
,
hr
);
create_xml_file
(
"bank.xml"
);
GetFullPathNameA
(
"bank.xml"
,
MAX_PATH
,
path
,
NULL
);
create_stream_on_file
(
&
stream
,
path
);
/* GetSizeMax not implemented */
size
.
QuadPart
=
0
;
hr
=
IPersistStreamInit_GetSizeMax
(
psi
,
&
size
);
ok
(
hr
==
E_NOTIMPL
,
"Expected E_NOTIMPL, got %08x
\n
"
,
hr
);
ok
(
size
.
QuadPart
==
0
,
"Expected 0
\n
"
);
hr
=
IPersistStreamInit_Load
(
psi
,
stream
);
IStream_Release
(
stream
);
ok
(
hr
==
S_OK
||
hr
==
XML_E_INVALIDATROOTLEVEL
,
"Expected S_OK, got %08x
\n
"
,
hr
);
if
(
hr
==
XML_E_INVALIDATROOTLEVEL
)
goto
cleanup
;
/* try to save document */
stream
=
NULL
;
hr
=
CreateStreamOnHGlobal
(
NULL
,
TRUE
,
&
stream
);
ok
(
hr
==
S_OK
,
"Expected S_OK, got %08x
\n
"
,
hr
);
hr
=
IPersistStreamInit_Save
(
psi
,
stream
,
FALSE
);
todo_wine
ok
(
hr
==
S_OK
,
"Expected S_OK, got %08x
\n
"
,
hr
);
stat
.
cbSize
.
QuadPart
=
0
;
hr
=
IStream_Stat
(
stream
,
&
stat
,
0
);
ok
(
hr
==
S_OK
,
"Expected S_OK, got %08x
\n
"
,
hr
);
todo_wine
ok
(
stat
.
cbSize
.
QuadPart
>
0
,
"Expected >0
\n
"
);
IStream_Release
(
stream
);
/* reset internal stream */
hr
=
IPersistStreamInit_InitNew
(
psi
);
todo_wine
ok
(
hr
==
S_OK
,
"Expected S_OK, got %08x
\n
"
,
hr
);
stream
=
NULL
;
hr
=
CreateStreamOnHGlobal
(
NULL
,
TRUE
,
&
stream
);
ok
(
hr
==
S_OK
,
"Expected S_OK, got %08x
\n
"
,
hr
);
hr
=
IPersistStreamInit_Save
(
psi
,
stream
,
FALSE
);
todo_wine
ok
(
hr
==
S_OK
,
"Expected S_OK, got %08x
\n
"
,
hr
);
stat
.
cbSize
.
QuadPart
=
0
;
hr
=
IStream_Stat
(
stream
,
&
stat
,
0
);
ok
(
hr
==
S_OK
,
"Expected S_OK, got %08x
\n
"
,
hr
);
todo_wine
ok
(
stat
.
cbSize
.
QuadPart
>
0
,
"Expected >0
\n
"
);
IStream_Release
(
stream
);
cleanup:
IPersistStreamInit_Release
(
psi
);
IXMLDocument_Release
(
doc
);
DeleteFileA
(
"bank.xml"
);
}
static
BOOL
test_try_xmldoc
(
void
)
{
IXMLDocument
*
doc
=
NULL
;
HRESULT
hr
;
hr
=
CoCreateInstance
(
&
CLSID_XMLDocument
,
NULL
,
CLSCTX_INPROC_SERVER
,
&
IID_IXMLDocument
,
(
LPVOID
*
)
&
doc
);
if
(
FAILED
(
hr
))
{
skip
(
"Failed to create XMLDocument instance
\n
"
);
return
FALSE
;
}
IXMLDocument_Release
(
doc
);
return
TRUE
;
}
START_TEST
(
xmldoc
)
START_TEST
(
xmldoc
)
{
{
HRESULT
hr
;
HRESULT
hr
;
...
@@ -361,8 +456,15 @@ START_TEST(xmldoc)
...
@@ -361,8 +456,15 @@ START_TEST(xmldoc)
hr
=
CoInitialize
(
NULL
);
hr
=
CoInitialize
(
NULL
);
ok
(
hr
==
S_OK
,
"failed to init com
\n
"
);
ok
(
hr
==
S_OK
,
"failed to init com
\n
"
);
if
(
!
test_try_xmldoc
())
{
CoUninitialize
();
return
;
}
test_xmldoc
();
test_xmldoc
();
test_createElement
();
test_createElement
();
test_persiststreaminit
();
CoUninitialize
();
CoUninitialize
();
}
}
dlls/msxml3/xmldoc.c
View file @
1b2f1867
...
@@ -657,7 +657,8 @@ static HRESULT WINAPI xmldoc_IPersistStreamInit_Save(
...
@@ -657,7 +657,8 @@ static HRESULT WINAPI xmldoc_IPersistStreamInit_Save(
static
HRESULT
WINAPI
xmldoc_IPersistStreamInit_GetSizeMax
(
static
HRESULT
WINAPI
xmldoc_IPersistStreamInit_GetSizeMax
(
IPersistStreamInit
*
iface
,
ULARGE_INTEGER
*
pcbSize
)
IPersistStreamInit
*
iface
,
ULARGE_INTEGER
*
pcbSize
)
{
{
FIXME
(
"(%p, %p): stub!
\n
"
,
iface
,
pcbSize
);
xmldoc
*
This
=
impl_from_IPersistStreamInit
(
iface
);
TRACE
(
"(%p, %p)
\n
"
,
This
,
pcbSize
);
return
E_NOTIMPL
;
return
E_NOTIMPL
;
}
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment