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
bae702a0
Commit
bae702a0
authored
Apr 03, 2022
by
Daniel Lehman
Committed by
Alexandre Julliard
Apr 07, 2022
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
ntdll/tests: Add some CloseHandle exception tests.
Signed-off-by:
Daniel Lehman
<
dlehman25@gmail.com
>
Signed-off-by:
Alexandre Julliard
<
julliard@winehq.org
>
parent
c814fbe1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
56 additions
and
14 deletions
+56
-14
exception.c
dlls/ntdll/tests/exception.c
+56
-14
No files found.
dlls/ntdll/tests/exception.c
View file @
bae702a0
...
...
@@ -1211,7 +1211,7 @@ static void test_debugger(DWORD cont_status)
if
(
stage
==
10
)
continuestatus
=
DBG_EXCEPTION_NOT_HANDLED
;
}
else
if
(
stage
==
11
||
stage
==
12
||
stage
==
13
)
else
if
(
stage
==
11
||
stage
==
12
)
{
ok
(
de
.
u
.
Exception
.
ExceptionRecord
.
ExceptionCode
==
EXCEPTION_INVALID_HANDLE
,
"unexpected exception code %08lx, expected %08lx
\n
"
,
de
.
u
.
Exception
.
ExceptionRecord
.
ExceptionCode
,
...
...
@@ -1219,7 +1219,13 @@ static void test_debugger(DWORD cont_status)
ok
(
de
.
u
.
Exception
.
ExceptionRecord
.
NumberParameters
==
0
,
"unexpected number of parameters %ld, expected 0
\n
"
,
de
.
u
.
Exception
.
ExceptionRecord
.
NumberParameters
);
if
(
stage
==
12
||
stage
==
13
)
continuestatus
=
DBG_EXCEPTION_NOT_HANDLED
;
if
(
stage
==
12
)
continuestatus
=
DBG_EXCEPTION_NOT_HANDLED
;
}
else
if
(
stage
==
13
)
{
todo_wine
ok
(
FALSE
||
broken
(
TRUE
)
/* < Win10 */
,
"should not throw exception
\n
"
);
continuestatus
=
DBG_EXCEPTION_NOT_HANDLED
;
}
else
if
(
stage
==
14
||
stage
==
15
)
{
...
...
@@ -3905,7 +3911,7 @@ static void test_debugger(DWORD cont_status)
"expected Rip = %p, got %p
\n
"
,
(
char
*
)
code_mem_address
+
2
,
(
char
*
)
ctx
.
Rip
);
if
(
stage
==
10
)
continuestatus
=
DBG_EXCEPTION_NOT_HANDLED
;
}
else
if
(
stage
==
11
||
stage
==
12
||
stage
==
13
)
else
if
(
stage
==
11
||
stage
==
12
)
{
ok
(
de
.
u
.
Exception
.
ExceptionRecord
.
ExceptionCode
==
EXCEPTION_INVALID_HANDLE
,
"unexpected exception code %08lx, expected %08lx
\n
"
,
de
.
u
.
Exception
.
ExceptionRecord
.
ExceptionCode
,
...
...
@@ -3913,7 +3919,13 @@ static void test_debugger(DWORD cont_status)
ok
(
de
.
u
.
Exception
.
ExceptionRecord
.
NumberParameters
==
0
,
"unexpected number of parameters %ld, expected 0
\n
"
,
de
.
u
.
Exception
.
ExceptionRecord
.
NumberParameters
);
if
(
stage
==
12
||
stage
==
13
)
continuestatus
=
DBG_EXCEPTION_NOT_HANDLED
;
if
(
stage
==
12
)
continuestatus
=
DBG_EXCEPTION_NOT_HANDLED
;
}
else
if
(
stage
==
13
)
{
todo_wine
ok
(
FALSE
||
broken
(
TRUE
)
/* < Win10 */
,
"should not throw exception
\n
"
);
continuestatus
=
DBG_EXCEPTION_NOT_HANDLED
;
}
else
if
(
stage
==
14
||
stage
==
15
)
{
...
...
@@ -6603,7 +6615,7 @@ static void test_debugger(DWORD cont_status)
"expected Pc = %p, got 0x%x
\n
"
,
(
char
*
)
code_mem_address
+
3
,
ctx
.
Pc
);
if
(
stage
==
10
)
continuestatus
=
DBG_EXCEPTION_NOT_HANDLED
;
}
else
if
(
stage
==
11
||
stage
==
12
||
stage
==
13
)
else
if
(
stage
==
11
||
stage
==
12
)
{
ok
(
de
.
u
.
Exception
.
ExceptionRecord
.
ExceptionCode
==
EXCEPTION_INVALID_HANDLE
,
"unexpected exception code %08x, expected %08x
\n
"
,
de
.
u
.
Exception
.
ExceptionRecord
.
ExceptionCode
,
...
...
@@ -6611,7 +6623,13 @@ static void test_debugger(DWORD cont_status)
ok
(
de
.
u
.
Exception
.
ExceptionRecord
.
NumberParameters
==
0
,
"unexpected number of parameters %d, expected 0
\n
"
,
de
.
u
.
Exception
.
ExceptionRecord
.
NumberParameters
);
if
(
stage
==
12
||
stage
==
13
)
continuestatus
=
DBG_EXCEPTION_NOT_HANDLED
;
if
(
stage
==
12
)
continuestatus
=
DBG_EXCEPTION_NOT_HANDLED
;
}
else
if
(
stage
==
13
)
{
todo_wine
ok
(
FALSE
||
broken
(
TRUE
)
/* < Win10 */
,
"should not throw exception
\n
"
);
continuestatus
=
DBG_EXCEPTION_NOT_HANDLED
;
}
else
ok
(
FALSE
,
"unexpected stage %x
\n
"
,
stage
);
...
...
@@ -7851,7 +7869,7 @@ static void test_debugger(DWORD cont_status)
"expected Pc = %p, got %p
\n
"
,
(
char
*
)
code_mem_address
+
4
,
(
char
*
)
ctx
.
Pc
);
if
(
stage
==
10
)
continuestatus
=
DBG_EXCEPTION_NOT_HANDLED
;
}
else
if
(
stage
==
11
||
stage
==
12
||
stage
==
13
)
else
if
(
stage
==
11
||
stage
==
12
)
{
ok
(
de
.
u
.
Exception
.
ExceptionRecord
.
ExceptionCode
==
EXCEPTION_INVALID_HANDLE
,
"unexpected exception code %08x, expected %08x
\n
"
,
de
.
u
.
Exception
.
ExceptionRecord
.
ExceptionCode
,
...
...
@@ -7859,7 +7877,13 @@ static void test_debugger(DWORD cont_status)
ok
(
de
.
u
.
Exception
.
ExceptionRecord
.
NumberParameters
==
0
,
"unexpected number of parameters %d, expected 0
\n
"
,
de
.
u
.
Exception
.
ExceptionRecord
.
NumberParameters
);
if
(
stage
==
12
||
stage
==
13
)
continuestatus
=
DBG_EXCEPTION_NOT_HANDLED
;
if
(
stage
==
12
)
continuestatus
=
DBG_EXCEPTION_NOT_HANDLED
;
}
else
if
(
stage
==
13
)
{
todo_wine
ok
(
FALSE
||
broken
(
TRUE
)
/* < Win10 */
,
"should not throw exception
\n
"
);
continuestatus
=
DBG_EXCEPTION_NOT_HANDLED
;
}
else
ok
(
FALSE
,
"unexpected stage %x
\n
"
,
stage
);
...
...
@@ -8575,6 +8599,11 @@ static LONG CALLBACK invalid_handle_vectored_handler(EXCEPTION_POINTERS *Excepti
return
(
rec
->
ExceptionCode
==
EXCEPTION_INVALID_HANDLE
)
?
EXCEPTION_CONTINUE_EXECUTION
:
EXCEPTION_CONTINUE_SEARCH
;
}
static
inline
BOOL
is_magic_handle
(
HANDLE
handle
)
{
return
HandleToLong
(
handle
)
>=
~
5
&&
HandleToLong
(
handle
)
<=
~
0
;
}
static
void
test_closehandle
(
DWORD
numexc
,
HANDLE
handle
)
{
PVOID
vectored_handler
;
...
...
@@ -8590,13 +8619,17 @@ static void test_closehandle(DWORD numexc, HANDLE handle)
invalid_handle_exceptions
=
0
;
CloseHandle
(
handle
);
ok
(
invalid_handle_exceptions
==
numexc
,
"CloseHandle generated %ld exceptions, expected %ld
\n
"
,
invalid_handle_exceptions
,
numexc
);
todo_wine_if
(
is_magic_handle
(
handle
))
ok
(
invalid_handle_exceptions
==
numexc
||
broken
(
!
numexc
&&
is_magic_handle
(
handle
)),
/* < Win10 */
"CloseHandle generated %ld exceptions, expected %ld for %p
\n
"
,
invalid_handle_exceptions
,
numexc
,
handle
);
invalid_handle_exceptions
=
0
;
pNtClose
(
handle
);
ok
(
invalid_handle_exceptions
==
numexc
,
"NtClose generated %ld exceptions, expected %ld
\n
"
,
invalid_handle_exceptions
,
numexc
);
todo_wine_if
(
is_magic_handle
(
handle
))
ok
(
invalid_handle_exceptions
==
numexc
||
broken
(
!
numexc
&&
is_magic_handle
(
handle
)),
/* < Win10 */
"CloseHandle generated %ld exceptions, expected %ld for %p
\n
"
,
invalid_handle_exceptions
,
numexc
,
handle
);
pRtlRemoveVectoredExceptionHandler
(
vectored_handler
);
}
...
...
@@ -10676,10 +10709,19 @@ START_TEST(exception)
test_breakpoint
(
1
);
test_stage
=
11
;
test_closehandle
(
0
,
(
HANDLE
)
0xdeadbeef
);
test_closehandle
(
0
,
(
HANDLE
)
0x7fffffff
);
test_stage
=
12
;
test_closehandle
(
1
,
(
HANDLE
)
0xdeadbeef
);
test_stage
=
13
;
test_closehandle
(
0
,
0
);
/* Special case. */
test_closehandle
(
1
,
(
HANDLE
)
~
(
ULONG_PTR
)
6
);
test_stage
=
13
;
/* special cases */
test_closehandle
(
0
,
0
);
test_closehandle
(
0
,
INVALID_HANDLE_VALUE
);
test_closehandle
(
0
,
GetCurrentProcess
());
test_closehandle
(
0
,
GetCurrentThread
());
test_closehandle
(
0
,
(
HANDLE
)
~
(
ULONG_PTR
)
2
);
test_closehandle
(
0
,
GetCurrentProcessToken
());
test_closehandle
(
0
,
GetCurrentThreadToken
());
test_closehandle
(
0
,
GetCurrentThreadEffectiveToken
());
#if defined(__i386__) || defined(__x86_64__)
test_stage
=
14
;
test_debuggee_xstate
();
...
...
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