blob: 9bc068ea72d73d3da9921df03e016bdf930812dd (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
|
// Licensed to the .NET Foundation under one or more agreements.
// The .NET Foundation licenses this file to you under the MIT license.
// See the LICENSE file in the project root for more information.
/*=============================================================================
**
** Source: test3.c
**
** Dependencies: PAL_Initialize
** PAL_Terminate
** CreateEvent
** CloseHandle
**
** Purpose:
**
** Test to ensure proper operation of the ResetEvent()
** API by calling it on an event handle that's been
** closed. We expect it to return an appropriate error
** result.
**
**
**
**===========================================================================*/
#include <palsuite.h>
int __cdecl main( int argc, char **argv )
{
/* local variables */
HANDLE hEvent = NULL;
LPSECURITY_ATTRIBUTES lpEventAttributes = NULL;
BOOL bManualReset = TRUE;
BOOL bInitialState = FALSE;
/* PAL initialization */
if( (PAL_Initialize(argc, argv)) != 0 )
{
return( FAIL );
}
/* create an event which we can use with ResetEvent */
hEvent = CreateEvent( lpEventAttributes,
bManualReset,
bInitialState,
NULL );
if( hEvent == INVALID_HANDLE_VALUE )
{
/* ERROR */
Fail( "ERROR:%lu:CreateEvent() call failed\n", GetLastError() );
}
/* close the event handle */
if( ! CloseHandle( hEvent ) )
{
Fail( "ERROR:%lu:CloseHandle() call failed\n", GetLastError() );
}
/* try to reset the event */
if( ResetEvent( hEvent ) )
{
/* ERROR */
Fail( "FAIL:ResetEvent() call succeeded on a closed event handle\n" );
}
/* verify the result of GetLastError() */
if( GetLastError() != ERROR_INVALID_HANDLE )
{
/* ERROR */
Fail( "FAIL:ResetEvent() call failed on a closed event handle "
"but returned an unexpected error result %lu\n" );
}
/* PAL termination */
PAL_Terminate();
/* return success */
return PASS;
}
|