summaryrefslogtreecommitdiff
path: root/src/pal/tests/palsuite/threading/DuplicateHandle/test3/test3.cpp
blob: fc91b5ec22f2793f22e403e3e4d55ae750742c06 (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
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
// 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 (DuplicateHandle)
**
** Purpose:   Tests the PAL implementation of the DuplicateHandle function.
**            This will test duplication of an OpenEvent handle. Test an 
**            event in a signaled state to wait, and then set the duplicate
**            to nonsignaled state and perform the wait again. The wait on
**            the event should fail. Test the duplication of closed and NULL
**            events, these should fail.  
**
**
**===================================================================*/
#include <palsuite.h>

int __cdecl main(int argc, char **argv)
{
    HANDLE  hCreateEvent;
    HANDLE  hOpenEvent;
    HANDLE  hDupEvent;
    WCHAR   lpEventName[]={'E','v','e','n','t','\0'};

    /*Initialize the PAL.*/
    if ((PAL_Initialize(argc,argv)) != 0)
    {
        return (FAIL);
    }
    
    /*Create an Event, and set it in the signaled state.*/
    hCreateEvent = CreateEventW(0,
                                TRUE, 
                                TRUE, 
                                lpEventName);
    if (hCreateEvent == NULL)
    {
        Fail("ERROR: %u :unable to create event %s\n", 
              GetLastError(),
              lpEventName);
    }

    /*Open another handle to hCreateHandle with OpenEvent*/
    hOpenEvent = OpenEventW(EVENT_ALL_ACCESS,
                            TRUE,
                            lpEventName);
    if (hOpenEvent == NULL)
    {
        Trace("ERROR: %u :unable to create handle with OpenEvent to %s\n",
             GetLastError(),
             lpEventName);
        CloseHandle(hCreateEvent);
        Fail("");
    }

    /*Create a duplicate Event handle*/
    if (!(DuplicateHandle(GetCurrentProcess(), 
                          hOpenEvent,
                          GetCurrentProcess(),
                          &hDupEvent,
                          GENERIC_READ|GENERIC_WRITE,
                          FALSE, 
                          DUPLICATE_SAME_ACCESS)))
    {
        Trace("ERROR: %u :Fail to create the duplicate handle"
                " to hCreateEvent=0x%lx\n",
                GetLastError(),
                hCreateEvent);
        CloseHandle(hCreateEvent);
        CloseHandle(hOpenEvent);
        Fail("");
    }

    /*Perform wait on Event that is in signaled state*/
    if ((WaitForSingleObject(hOpenEvent, 1000)) != WAIT_OBJECT_0)
    {
        Trace("ERROR: %u :WaitForSignalObject on hOpenEvent=0x%lx set to "
                " signaled state failed\n",
                GetLastError(),
                hOpenEvent);
        CloseHandle(hCreateEvent);
        CloseHandle(hOpenEvent);
        CloseHandle(hDupEvent);
        Fail("");
    }

    /*Set the Duplicate Event handle to nonsignaled state*/
    if ((ResetEvent(hDupEvent)) == 0)
    {
        Trace("ERROR: %u: unable to reset hDupEvent=0x%lx\n", 
             GetLastError(),
             hDupEvent);
        CloseHandle(hCreateEvent);
        CloseHandle(hOpenEvent);
        CloseHandle(hDupEvent);
        Fail("");
    }

    /*Perform wait on Event that is in signaled state*/
    if ((WaitForSingleObject(hOpenEvent, 1000)) == WAIT_OBJECT_0)
    {
        Trace("ERROR: %u :WaitForSignalObject succeeded on hOpenEvent=0x%lx "
                " when Duplicate hDupEvent=0x%lx set to nonsignaled state"
                " succeeded\n",
                GetLastError(),
                hOpenEvent,
                hDupEvent);
        CloseHandle(hCreateEvent);
        CloseHandle(hOpenEvent);
        CloseHandle(hDupEvent);
        Fail("");
    }

    /*Close handles the events*/
    CloseHandle(hCreateEvent);
    CloseHandle(hOpenEvent);
    CloseHandle(hDupEvent);

    PAL_Terminate();
    return (PASS);
}