1 /*
2  * Unit test suite for rpc functions
3  *
4  * Copyright 2008 Robert Shearman (for CodeWeavers)
5  *
6  * This library is free software; you can redistribute it and/or
7  * modify it under the terms of the GNU Lesser General Public
8  * License as published by the Free Software Foundation; either
9  * version 2.1 of the License, or (at your option) any later version.
10  *
11  * This library is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14  * Lesser General Public License for more details.
15  *
16  * You should have received a copy of the GNU Lesser General Public
17  * License along with this library; if not, write to the Free Software
18  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
19  */
20 
21 #include <stdarg.h>
22 
23 #include "wine/test.h"
24 
25 #include <rpc.h>
26 #include <rpcasync.h>
27 
28 static void test_RpcAsyncInitializeHandle(void)
29 {
30     char buffer[256];
31     RPC_ASYNC_STATE async;
32     RPC_STATUS status;
33     int i;
34     void *unset_ptr;
35 
36     status = RpcAsyncInitializeHandle((PRPC_ASYNC_STATE)buffer, sizeof(buffer));
37     ok(status == ERROR_INVALID_PARAMETER, "RpcAsyncInitializeHandle with large Size should have returned ERROR_INVALID_PARAMETER instead of %d\n", status);
38 
39     status = RpcAsyncInitializeHandle(&async, sizeof(async) - 1);
40     ok(status == ERROR_INVALID_PARAMETER, "RpcAsyncInitializeHandle with small Size should have returned ERROR_INVALID_PARAMETER instead of %d\n", status);
41 
42     memset(&async, 0xcc, sizeof(async));
43     memset(&unset_ptr, 0xcc, sizeof(unset_ptr));
44     status = RpcAsyncInitializeHandle(&async, sizeof(async));
45     ok(status == RPC_S_OK, "RpcAsyncInitializeHandle failed with error %d\n", status);
46 
47     ok(async.Size == sizeof(async), "async.Size wrong: %d\n", async.Size);
48     ok(async.Signature == 0x43595341, "async.Signature should be 0x43595341, but is 0x%x instead\n", async.Signature);
49     ok(async.Lock == 0, "async.Lock should be 0, but is %d instead\n", async.Lock);
50     ok(async.Flags == 0, "async.Flags should be 0, but is %d instead\n", async.Flags);
51     ok(async.StubInfo == NULL, "async.StubInfo should be NULL, not %p\n", async.StubInfo);
52     ok(async.UserInfo == unset_ptr, "async.UserInfo should be unset, not %p\n", async.UserInfo);
53     ok(async.RuntimeInfo == NULL, "async.RuntimeInfo should be NULL, not %p\n", async.RuntimeInfo);
54     ok(async.Event == 0xcccccccc, "async.Event should be unset, not %d\n", async.Event);
55     ok(async.NotificationType == 0xcccccccc, "async.NotificationType should be unset, not %d\n", async.NotificationType);
56     for (i = 0; i < 4; i++)
57         ok(async.Reserved[i] == 0x0, "async.Reserved[%d] should be 0x0, not 0x%lx\n", i, async.Reserved[i]);
58 }
59 
60 static void test_RpcAsyncGetCallStatus(void)
61 {
62     RPC_ASYNC_STATE async;
63     RPC_STATUS status;
64 
65     status = RpcAsyncInitializeHandle(&async, sizeof(async));
66     ok(status == RPC_S_OK, "RpcAsyncInitializeHandle failed with error %d\n", status);
67 
68     status = RpcAsyncGetCallStatus(&async);
69     todo_wine
70     ok(status == RPC_S_INVALID_BINDING, "RpcAsyncGetCallStatus should have returned RPC_S_INVALID_BINDING instead of %d\n", status);
71 
72     memset(&async, 0, sizeof(async));
73     status = RpcAsyncGetCallStatus(&async);
74     todo_wine
75     ok(status == RPC_S_INVALID_BINDING, "RpcAsyncGetCallStatus should have returned RPC_S_INVALID_BINDING instead of %d\n", status);
76 }
77 
78 START_TEST( rpc_async )
79 {
80     test_RpcAsyncInitializeHandle();
81     test_RpcAsyncGetCallStatus();
82 }
83