mciqtz32: Use BOOL type where appropriate.
[wine.git] / dlls / rasapi32 / tests / rasapi.c
blobe0ff25f8578f6d681a845af7f31ca0486e61020a
1 /*
2 * Unit test suite for rasapi32 functions
4 * Copyright 2008 Austin English
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.
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.
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
21 #include <stdarg.h>
22 #include <stdio.h>
23 #include <wine/test.h>
24 #include <windef.h>
25 #include <winbase.h>
26 #include "ras.h"
27 #include "raserror.h"
29 static HMODULE hmodule;
30 static DWORD (WINAPI *pRasEnumDevicesA)(LPRASDEVINFOA, LPDWORD, LPDWORD);
32 #define RASAPI32_GET_PROC(func) \
33 p ## func = (void*)GetProcAddress(hmodule, #func); \
34 if(!p ## func) \
35 trace("GetProcAddress(%s) failed\n", #func);
37 static void InitFunctionPtrs(void)
39 hmodule = LoadLibraryA("rasapi32.dll");
41 RASAPI32_GET_PROC(RasEnumDevicesA)
44 static void test_rasenum(void)
46 DWORD result;
47 DWORD cDevices = 0;
48 DWORD bufsize = 0, cb = 0;
49 LPRASDEVINFOA rasDevInfo;
51 if(!pRasEnumDevicesA) {
52 win_skip("Skipping RasEnumDevicesA tests, function not present\n");
53 return;
56 /* create the return buffer */
57 result = pRasEnumDevicesA(NULL, &bufsize, &cDevices);
58 if(ERROR_RASMAN_CANNOT_INITIALIZE == result ||
59 ERROR_STATE_MACHINES_NOT_STARTED == result) {
60 win_skip("RAS configuration problem\n");
61 return;
63 if(ERROR_SUCCESS == result) {
64 win_skip("RasEnumDevicesA found nothing to enumerate\n");
65 return;
67 trace("RasEnumDevicesA: returned %d buffersize %d\n", result, bufsize);
68 ok(result == ERROR_BUFFER_TOO_SMALL,
69 "Expected ERROR_BUFFER_TOO_SMALL, got %08d\n", result);
71 rasDevInfo = HeapAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY,
72 max(bufsize,sizeof(RASDEVINFOA)));
73 if(!rasDevInfo) {
74 win_skip("failed to allocate buffer for RasEnumDevicesA tests\n");
75 return;
78 /* test first parameter */
79 cb = bufsize;
80 result = pRasEnumDevicesA(NULL, &cb, &cDevices);
81 ok(result == ERROR_BUFFER_TOO_SMALL ||
82 result == ERROR_INVALID_USER_BUFFER, /* win98 */
83 "Expected ERROR_BUFFER_TOO_SMALL, got %08d\n", result);
85 rasDevInfo[0].dwSize = 0;
86 cb = bufsize;
87 result = pRasEnumDevicesA(rasDevInfo, &cb, &cDevices);
88 ok(result == ERROR_INVALID_SIZE ||
89 result == ERROR_INVALID_USER_BUFFER, /* win98 */
90 "Expected ERROR_INVALID_SIZE, got %08d\n", result);
92 rasDevInfo[0].dwSize = sizeof(RASDEVINFOA) -1;
93 cb = bufsize;
94 result = pRasEnumDevicesA(rasDevInfo, &cb, &cDevices);
95 ok(result == ERROR_INVALID_SIZE ||
96 result == ERROR_INVALID_USER_BUFFER, /* win98 */
97 "Expected ERROR_INVALID_SIZE, got %08d\n", result);
99 rasDevInfo[0].dwSize = sizeof(RASDEVINFOA) +1;
100 cb = bufsize;
101 result = pRasEnumDevicesA(rasDevInfo, &cb, &cDevices);
102 ok(result == ERROR_INVALID_SIZE ||
103 result == ERROR_INVALID_USER_BUFFER, /* win98 */
104 "Expected ERROR_INVALID_SIZE, got %08d\n", result);
106 /* test second parameter */
107 rasDevInfo[0].dwSize = sizeof(RASDEVINFOA);
108 result = pRasEnumDevicesA(rasDevInfo, NULL, &cDevices);
109 ok(result == ERROR_INVALID_PARAMETER,
110 "Expected ERROR_INVALID_PARAMETER, got %08d\n", result);
112 rasDevInfo[0].dwSize = sizeof(RASDEVINFOA);
113 cb = 0;
114 result = pRasEnumDevicesA(rasDevInfo, &cb, &cDevices);
115 ok(result == ERROR_BUFFER_TOO_SMALL ||
116 result == ERROR_INVALID_SIZE, /* vista, 2k8 */
117 "Expected ERROR_BUFFER_TOO_SMALL/ERROR_INVALID_SIZE, got %08d\n", result);
119 rasDevInfo[0].dwSize = sizeof(RASDEVINFOA);
120 cb = bufsize -1;
121 result = pRasEnumDevicesA(rasDevInfo, &cb, &cDevices);
122 ok(result == ERROR_BUFFER_TOO_SMALL,
123 "Expected ERROR_BUFFER_TOO_SMALL, got %08d\n", result);
125 rasDevInfo[0].dwSize = sizeof(RASDEVINFOA);
126 cb = bufsize +1;
127 result = pRasEnumDevicesA(rasDevInfo, &cb, &cDevices);
128 ok(result == ERROR_SUCCESS,
129 "Expected ERROR_SUCCESS, got %08d\n", result);
131 /* test third parameter */
132 rasDevInfo[0].dwSize = sizeof(RASDEVINFOA);
133 cb = bufsize;
134 result = pRasEnumDevicesA(rasDevInfo, &cb, NULL);
135 ok(result == ERROR_INVALID_PARAMETER,
136 "Expected ERROR_INVALID_PARAMETER, got %08d\n", result);
138 /* test combinations of invalid parameters */
139 result = pRasEnumDevicesA(NULL, NULL, &cDevices);
140 ok(result == ERROR_INVALID_PARAMETER,
141 "Expected ERROR_INVALID_PARAMETER, got %08d\n", result);
143 result = pRasEnumDevicesA(NULL, &cb, NULL);
144 ok(result == ERROR_INVALID_PARAMETER ||
145 result == ERROR_INVALID_USER_BUFFER, /* win98 */
146 "Expected ERROR_INVALID_PARAMETER, got %08d\n", result);
148 cb = 0;
149 rasDevInfo[0].dwSize = 0;
150 result = pRasEnumDevicesA(rasDevInfo, &cb, &cDevices);
151 ok(result == ERROR_INVALID_SIZE ||
152 broken(result == ERROR_BUFFER_TOO_SMALL), /* win98 */
153 "Expected ERROR_INVALID_SIZE, got %08d\n", result);
155 HeapFree(GetProcessHeap(), 0, rasDevInfo);
158 START_TEST(rasapi)
160 InitFunctionPtrs();
162 test_rasenum();
164 FreeLibrary(hmodule);