[MPR_WINETEST] Sync with Wine Staging 3.3. CORE-14434
[reactos.git] / modules / rostests / winetests / mpr / mpr.c
1 /*
2 * Copyright 2012 Andrew Eikum for CodeWeavers
3 *
4 * This library is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU Lesser General Public
6 * License as published by the Free Software Foundation; either
7 * version 2.1 of the License, or (at your option) any later version.
8 *
9 * This library is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 * Lesser General Public License for more details.
13 *
14 * You should have received a copy of the GNU Lesser General Public
15 * License along with this library; if not, write to the Free Software
16 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
17 */
18
19 #define COBJMACROS
20
21 #include <stdio.h>
22
23 #include "windows.h"
24 #include "winnetwk.h"
25 #include "wine/test.h"
26
27 static void test_WNetGetUniversalName(void)
28 {
29 DWORD ret;
30 char buffer[1024];
31 DWORD drive_type, info_size, fail_size;
32 char driveA[] = "A:\\";
33 char driveandpathA[] = "A:\\file.txt";
34 WCHAR driveW[] = {'A',':','\\',0};
35
36 for(; *driveA <= 'Z'; ++*driveA, ++*driveandpathA, ++*driveW){
37 drive_type = GetDriveTypeW(driveW);
38
39 info_size = sizeof(buffer);
40 ret = WNetGetUniversalNameA(driveA, UNIVERSAL_NAME_INFO_LEVEL,
41 buffer, &info_size);
42
43 if(drive_type == DRIVE_REMOTE)
44 ok(ret == WN_NO_ERROR, "WNetGetUniversalNameA failed: %08x\n", ret);
45 else
46 /* WN_NO_NET_OR_BAD_PATH (DRIVE_FIXED) returned from the virtual drive (usual Q:)
47 created by the microsoft application virtualization client */
48 ok((ret == WN_NOT_CONNECTED) || (ret == WN_NO_NET_OR_BAD_PATH),
49 "WNetGetUniversalNameA(%s, ...) returned %u (drive_type: %u)\n",
50 driveA, ret, drive_type);
51
52 ok(info_size == sizeof(buffer), "Got wrong size: %u\n", info_size);
53
54 fail_size = 0;
55 ret = WNetGetUniversalNameA(driveA, UNIVERSAL_NAME_INFO_LEVEL,
56 buffer, &fail_size);
57 if(drive_type == DRIVE_REMOTE)
58 todo_wine ok(ret == WN_BAD_VALUE || ret == WN_MORE_DATA, "WNetGetUniversalNameA failed: %08x\n", ret);
59 else
60 ok(ret == WN_NOT_CONNECTED || ret == WN_NO_NET_OR_BAD_PATH,
61 "(%s) WNetGetUniversalNameW gave wrong error: %u\n", driveA, ret);
62
63 fail_size = sizeof(driveA) / sizeof(char) - 1;
64 ret = WNetGetUniversalNameA(driveA, UNIVERSAL_NAME_INFO_LEVEL,
65 buffer, &fail_size);
66 if(drive_type == DRIVE_REMOTE)
67 ok(ret == WN_MORE_DATA, "WNetGetUniversalNameA failed: %08x\n", ret);
68
69 ret = WNetGetUniversalNameA(driveandpathA, UNIVERSAL_NAME_INFO_LEVEL,
70 buffer, &info_size);
71 if(drive_type == DRIVE_REMOTE)
72 todo_wine ok(ret == WN_NO_ERROR, "WNetGetUniversalNameA failed: %08x\n", ret);
73
74 info_size = sizeof(buffer);
75 ret = WNetGetUniversalNameW(driveW, UNIVERSAL_NAME_INFO_LEVEL,
76 buffer, &info_size);
77
78 if(drive_type == DRIVE_REMOTE)
79 ok(ret == WN_NO_ERROR, "WNetGetUniversalNameW failed: %08x\n", ret);
80 else
81 ok((ret == WN_NOT_CONNECTED) || (ret == WN_NO_NET_OR_BAD_PATH),
82 "WNetGetUniversalNameW(%s, ...) returned %u (drive_type: %u)\n",
83 wine_dbgstr_w(driveW), ret, drive_type);
84 if(drive_type != DRIVE_REMOTE)
85 ok(info_size == sizeof(buffer), "Got wrong size: %u\n", info_size);
86 }
87 }
88
89 static void test_WNetGetRemoteName(void)
90 {
91 DWORD ret;
92 char buffer[1024];
93 DWORD drive_type, info_size, fail_size;
94 char driveA[] = "A:\\";
95 char driveandpathA[] = "A:\\file.txt";
96 WCHAR driveW[] = {'A',':','\\',0};
97
98 for(; *driveA <= 'Z'; ++*driveA, ++*driveandpathA, ++*driveW){
99 drive_type = GetDriveTypeW(driveW);
100
101 info_size = sizeof(buffer);
102 ret = WNetGetUniversalNameA(driveA, REMOTE_NAME_INFO_LEVEL,
103 buffer, &info_size);
104 if(drive_type == DRIVE_REMOTE)
105 todo_wine
106 ok(ret == WN_NO_ERROR, "WNetGetUniversalNameA failed: %08x\n", ret);
107 else
108 ok(ret == WN_NOT_CONNECTED || ret == WN_NO_NET_OR_BAD_PATH,
109 "(%s) WNetGetUniversalNameA gave wrong error: %u\n", driveA, ret);
110 ok(info_size == sizeof(buffer), "Got wrong size: %u\n", info_size);
111
112 fail_size = 0;
113 ret = WNetGetUniversalNameA(driveA, REMOTE_NAME_INFO_LEVEL,
114 buffer, &fail_size);
115 if(drive_type == DRIVE_REMOTE)
116 todo_wine
117 ok(ret == WN_BAD_VALUE || ret == WN_MORE_DATA, "WNetGetUniversalNameA failed: %08x\n", ret);
118 else
119 ok(ret == WN_NOT_CONNECTED || ret == WN_NO_NET_OR_BAD_PATH,
120 "(%s) WNetGetUniversalNameA gave wrong error: %u\n", driveA, ret);
121 ret = WNetGetUniversalNameA(driveA, REMOTE_NAME_INFO_LEVEL,
122 buffer, NULL);
123 todo_wine ok(ret == WN_BAD_POINTER, "WNetGetUniversalNameA failed: %08x\n", ret);
124
125 ret = WNetGetUniversalNameA(driveA, REMOTE_NAME_INFO_LEVEL,
126 NULL, &info_size);
127
128 if(drive_type == DRIVE_REMOTE)
129 todo_wine
130 ok(ret == WN_BAD_POINTER || ret == WN_BAD_VALUE, "WNetGetUniversalNameA failed: %08x\n", ret);
131 else
132 ok(ret == WN_NOT_CONNECTED || ret == WN_BAD_VALUE,
133 "(%s) WNetGetUniversalNameA gave wrong error: %u\n", driveA, ret);
134
135 fail_size = sizeof(driveA) / sizeof(char) - 1;
136 ret = WNetGetUniversalNameA(driveA, REMOTE_NAME_INFO_LEVEL,
137 buffer, &fail_size);
138 if(drive_type == DRIVE_REMOTE)
139 todo_wine ok(ret == WN_MORE_DATA, "WNetGetUniversalNameA failed: %08x\n", ret);
140
141 ret = WNetGetUniversalNameA(driveandpathA, REMOTE_NAME_INFO_LEVEL,
142 buffer, &info_size);
143 if(drive_type == DRIVE_REMOTE)
144 todo_wine ok(ret == WN_NO_ERROR, "WNetGetUniversalNameA failed: %08x\n", ret);
145
146 info_size = sizeof(buffer);
147 ret = WNetGetUniversalNameW(driveW, REMOTE_NAME_INFO_LEVEL,
148 buffer, &info_size);
149 todo_wine{
150 if(drive_type == DRIVE_REMOTE)
151 ok(ret == WN_NO_ERROR, "WNetGetUniversalNameW failed: %08x\n", ret);
152 else
153 ok(ret == WN_NOT_CONNECTED || ret == WN_NO_NET_OR_BAD_PATH,
154 "(%s) WNetGetUniversalNameW gave wrong error: %u\n", driveA, ret);
155 }
156 ok(info_size == sizeof(buffer), "Got wrong size: %u\n", info_size);
157 }
158 }
159
160 static DWORD (WINAPI *pWNetCachePassword)( LPSTR, WORD, LPSTR, WORD, BYTE, WORD );
161 static DWORD (WINAPI *pWNetGetCachedPassword)( LPSTR, WORD, LPSTR, LPWORD, BYTE );
162 static UINT (WINAPI *pWNetEnumCachedPasswords)( LPSTR, WORD, BYTE, ENUMPASSWORDPROC, DWORD);
163 static UINT (WINAPI *pWNetRemoveCachedPassword)( LPSTR, WORD, BYTE );
164 static DWORD (WINAPI *pWNetUseConnectionA)( HWND, LPNETRESOURCEA, LPCSTR, LPCSTR, DWORD, LPSTR, LPDWORD, LPDWORD );
165
166 #define MPR_GET_PROC(func) \
167 p ## func = (void*)GetProcAddress(hmpr, #func)
168
169 static void InitFunctionPtrs(void)
170 {
171 HMODULE hmpr = GetModuleHandleA("mpr.dll");
172
173 MPR_GET_PROC(WNetCachePassword);
174 MPR_GET_PROC(WNetGetCachedPassword);
175 MPR_GET_PROC(WNetEnumCachedPasswords);
176 MPR_GET_PROC(WNetRemoveCachedPassword);
177 MPR_GET_PROC(WNetUseConnectionA);
178 }
179
180 static const char* m_resource = "wine-test-resource";
181 static const char* m_password = "wine-test-password";
182 static const BYTE m_type = 1;
183 static const DWORD m_param = 8;
184 static BOOL m_callback_reached;
185
186 static BOOL CALLBACK enum_password_proc(PASSWORD_CACHE_ENTRY* pce, DWORD param)
187 {
188 WORD size = 0;
189 char* buf;
190
191 ok(param == m_param, "param, got %d, got %d\n", param, m_param);
192
193 size = offsetof( PASSWORD_CACHE_ENTRY, abResource[pce->cbResource + pce->cbPassword] );
194 ok(pce->cbEntry == size, "cbEntry, got %d, expected %d\n", pce->cbEntry, size);
195 ok(pce->cbResource == strlen(m_resource), "cbResource, got %d\n", pce->cbResource);
196 ok(pce->cbPassword == strlen(m_password), "cbPassword, got %d\n", pce->cbPassword);
197 ok(pce->iEntry == 0, "iEntry, got %d, got %d\n", pce->iEntry, 0);
198 ok(pce->nType == m_type, "nType, got %d, got %d\n", pce->nType, m_type);
199
200 buf = (char*)pce->abResource;
201 ok(strncmp(buf, m_resource, pce->cbResource)==0, "enumerated resource differs, got %.*s, expected %s\n", pce->cbResource, buf, m_resource);
202
203 buf += pce->cbResource;
204 ok(strncmp(buf, m_password, pce->cbPassword)==0, "enumerated resource differs, got %.*s, expected %s\n", pce->cbPassword, buf, m_password);
205
206 m_callback_reached = 1;
207 return TRUE;
208 }
209
210 static void test_WNetCachePassword(void)
211 {
212 char resource_buf[32];
213 char password_buf[32];
214 char prefix_buf[32];
215 WORD resource_len;
216 WORD password_len;
217 WORD prefix_len;
218 DWORD ret;
219
220 InitFunctionPtrs();
221
222 if (pWNetCachePassword &&
223 pWNetGetCachedPassword &&
224 pWNetEnumCachedPasswords &&
225 pWNetRemoveCachedPassword)
226 {
227 strcpy(resource_buf, m_resource);
228 resource_len = strlen(m_resource);
229 strcpy(password_buf, m_password);
230 password_len = strlen(m_password);
231 ret = pWNetCachePassword(resource_buf, resource_len, password_buf, password_len, m_type, 0);
232 ok(ret == WN_SUCCESS, "WNetCachePassword failed: got %d, expected %d\n", ret, WN_SUCCESS);
233
234 strcpy(resource_buf, m_resource);
235 resource_len = strlen(m_resource);
236 strcpy(password_buf, "------");
237 password_len = sizeof(password_buf);
238 ret = pWNetGetCachedPassword(resource_buf, resource_len, password_buf, &password_len, m_type);
239 ok(ret == WN_SUCCESS, "WNetGetCachedPassword failed: got %d, expected %d\n", ret, WN_SUCCESS);
240 ok(password_len == strlen(m_password), "password length different, got %d\n", password_len);
241 ok(strncmp(password_buf, m_password, password_len)==0, "passwords different, got %.*s, expected %s\n", password_len, password_buf, m_password);
242
243 prefix_len = 9;
244 strcpy(prefix_buf, m_resource);
245 prefix_buf[prefix_len] = '0';
246 ret = pWNetEnumCachedPasswords(prefix_buf, prefix_len, m_type, enum_password_proc, m_param);
247 ok(ret == WN_SUCCESS, "WNetEnumCachedPasswords failed: got %d, expected %d\n", ret, WN_SUCCESS);
248 ok(m_callback_reached == 1, "callback was not reached\n");
249
250 strcpy(resource_buf, m_resource);
251 resource_len = strlen(m_resource);
252 ret = pWNetRemoveCachedPassword(resource_buf, resource_len, m_type);
253 ok(ret == WN_SUCCESS, "WNetRemoveCachedPassword failed: got %d, expected %d\n", ret, WN_SUCCESS);
254 } else {
255 win_skip("WNetCachePassword() is not supported.\n");
256 }
257 }
258
259 static void test_WNetUseConnection(void)
260 {
261 DWORD ret, bufSize, outRes;
262 LPNETRESOURCEA netRes;
263 char outBuf[4], drive[] = "J:", letter;
264
265 if (!pWNetUseConnectionA)
266 {
267 win_skip("WNetUseConnection() is not supported.\n");
268 return;
269 }
270 netRes = HeapAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY, sizeof(NETRESOURCEA) + sizeof("\\\\127.0.0.1\\c$") + sizeof("J:"));
271 netRes->dwType = RESOURCETYPE_DISK;
272 netRes->dwDisplayType = RESOURCEDISPLAYTYPE_SHARE;
273 netRes->dwUsage = RESOURCEUSAGE_CONNECTABLE;
274 netRes->lpLocalName = (LPSTR)((LPBYTE)netRes + sizeof(NETRESOURCEA));
275 netRes->lpRemoteName = (LPSTR)((LPBYTE)netRes + sizeof(NETRESOURCEA) + sizeof("J:"));
276
277 for (letter = 'J'; letter <= 'Z'; letter++)
278 {
279 drive[0] = letter;
280 strcpy(netRes->lpLocalName, drive);
281 strcpy(netRes->lpRemoteName, "\\\\127.0.0.1\\c$");
282 bufSize = 0;
283 ret = pWNetUseConnectionA(NULL, netRes, NULL, NULL, 0, NULL, &bufSize, &outRes);
284 if (ret != ERROR_ALREADY_ASSIGNED) break;
285 }
286 if (ret == ERROR_ALREADY_ASSIGNED) goto end; /* no drives available */
287 todo_wine ok(ret == WN_SUCCESS, "Unexpected return: %u\n", ret);
288 ok(bufSize == 0, "Unexpected buffer size: %u\n", bufSize);
289 if (ret == WN_SUCCESS) WNetCancelConnectionA(drive, TRUE);
290
291 bufSize = 0;
292 ret = pWNetUseConnectionA(NULL, netRes, NULL, NULL, 0, outBuf, &bufSize, &outRes);
293 todo_wine ok(ret == ERROR_INVALID_PARAMETER, "Unexpected return: %u\n", ret);
294 ok(bufSize == 0, "Unexpected buffer size: %u\n", bufSize);
295 if (ret == WN_SUCCESS) WNetCancelConnectionA(drive, TRUE);
296
297 todo_wine {
298 bufSize = 1;
299 ret = pWNetUseConnectionA(NULL, netRes, NULL, NULL, 0, outBuf, &bufSize, &outRes);
300 ok(ret == ERROR_MORE_DATA, "Unexpected return: %u\n", ret);
301 ok(bufSize == 3, "Unexpected buffer size: %u\n", bufSize);
302 if (ret == WN_SUCCESS) WNetCancelConnectionA(drive, TRUE);
303
304 bufSize = 4;
305 ret = pWNetUseConnectionA(NULL, netRes, NULL, NULL, 0, outBuf, &bufSize, &outRes);
306 ok(ret == WN_SUCCESS, "Unexpected return: %u\n", ret);
307 }
308 ok(bufSize == 4, "Unexpected buffer size: %u\n", bufSize);
309 if (ret == WN_SUCCESS) WNetCancelConnectionA(drive, TRUE);
310
311 end:
312 HeapFree(GetProcessHeap(), 0, netRes);
313 }
314
315 START_TEST(mpr)
316 {
317 test_WNetGetUniversalName();
318 test_WNetGetRemoteName();
319 test_WNetCachePassword();
320 test_WNetUseConnection();
321 }