push 9e645869891abdc47a8701768b7a401b196a1e38
[wine/hacks.git] / dlls / version / tests / info.c
blobfa120df0293b3c4a056897e927609d7d6dcd0e98
1 /*
2 * Copyright (C) 2004 Stefan Leichter
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.
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.
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
19 #include <stdarg.h>
20 #include <stdio.h>
21 #include <assert.h>
23 #include "windef.h"
24 #include "winbase.h"
25 #include "winerror.h"
26 #include "winver.h"
27 #include "wine/test.h"
29 #define MY_LAST_ERROR ((DWORD)-1)
30 #define EXPECT_BAD_PATH__NOT_FOUND \
31 ok( (ERROR_PATH_NOT_FOUND == GetLastError()) || \
32 (ERROR_RESOURCE_DATA_NOT_FOUND == GetLastError()) || \
33 (ERROR_FILE_NOT_FOUND == GetLastError()) || \
34 (ERROR_BAD_PATHNAME == GetLastError()) || \
35 (ERROR_SUCCESS == GetLastError()), \
36 "Last error wrong! ERROR_RESOURCE_DATA_NOT_FOUND/ERROR_BAD_PATHNAME (98)/" \
37 "ERROR_PATH_NOT_FOUND (NT4)/ERROR_FILE_NOT_FOUND (2k3) " \
38 "ERROR_SUCCESS (2k) expected, got %u\n", GetLastError());
39 #define EXPECT_INVALID__NOT_FOUND \
40 ok( (ERROR_PATH_NOT_FOUND == GetLastError()) || \
41 (ERROR_RESOURCE_DATA_NOT_FOUND == GetLastError()) || \
42 (ERROR_FILE_NOT_FOUND == GetLastError()) || \
43 (ERROR_INVALID_PARAMETER == GetLastError()) || \
44 (ERROR_SUCCESS == GetLastError()), \
45 "Last error wrong! ERROR_RESOURCE_DATA_NOT_FOUND/ERROR_INVALID_PARAMETER (98)/" \
46 "ERROR_PATH_NOT_FOUND (NT4)/ERROR_FILE_NOT_FOUND (2k3) " \
47 "ERROR_SUCCESS (2k) expected, got %u\n", GetLastError());
49 static void create_file(const CHAR *name)
51 HANDLE file;
52 DWORD written;
54 file = CreateFileA(name, GENERIC_WRITE, 0, NULL, CREATE_ALWAYS, 0, NULL);
55 ok(file != INVALID_HANDLE_VALUE, "Failure to open file %s\n", name);
56 WriteFile(file, name, strlen(name), &written, NULL);
57 WriteFile(file, "\n", strlen("\n"), &written, NULL);
58 CloseHandle(file);
61 static void test_info_size(void)
62 { DWORD hdl, retval;
63 char mypath[MAX_PATH] = "";
65 SetLastError(MY_LAST_ERROR);
66 retval = GetFileVersionInfoSizeA( NULL, NULL);
67 ok( !retval,
68 "GetFileVersionInfoSizeA result wrong! 0L expected, got 0x%08x\n",
69 retval);
70 EXPECT_INVALID__NOT_FOUND;
72 hdl = 0x55555555;
73 SetLastError(MY_LAST_ERROR);
74 retval = GetFileVersionInfoSizeA( NULL, &hdl);
75 ok( !retval,
76 "GetFileVersionInfoSizeA result wrong! 0L expected, got 0x%08x\n",
77 retval);
78 EXPECT_INVALID__NOT_FOUND;
79 ok( hdl == 0L,
80 "Handle wrong! 0L expected, got 0x%08x\n", hdl);
82 SetLastError(MY_LAST_ERROR);
83 retval = GetFileVersionInfoSizeA( "", NULL);
84 ok( !retval,
85 "GetFileVersionInfoSizeA result wrong! 0L expected, got 0x%08x\n",
86 retval);
87 EXPECT_BAD_PATH__NOT_FOUND;
89 hdl = 0x55555555;
90 SetLastError(MY_LAST_ERROR);
91 retval = GetFileVersionInfoSizeA( "", &hdl);
92 ok( !retval,
93 "GetFileVersionInfoSizeA result wrong! 0L expected, got 0x%08x\n",
94 retval);
95 EXPECT_BAD_PATH__NOT_FOUND;
96 ok( hdl == 0L,
97 "Handle wrong! 0L expected, got 0x%08x\n", hdl);
99 SetLastError(MY_LAST_ERROR);
100 retval = GetFileVersionInfoSizeA( "kernel32.dll", NULL);
101 ok( retval,
102 "GetFileVersionInfoSizeA result wrong! <> 0L expected, got 0x%08x\n",
103 retval);
104 ok((NO_ERROR == GetLastError()) || (MY_LAST_ERROR == GetLastError()),
105 "Last error wrong! NO_ERROR/0x%08x (NT4) expected, got %u\n",
106 MY_LAST_ERROR, GetLastError());
108 hdl = 0x55555555;
109 SetLastError(MY_LAST_ERROR);
110 retval = GetFileVersionInfoSizeA( "kernel32.dll", &hdl);
111 ok( retval,
112 "GetFileVersionInfoSizeA result wrong! <> 0L expected, got 0x%08x\n",
113 retval);
114 ok((NO_ERROR == GetLastError()) || (MY_LAST_ERROR == GetLastError()),
115 "Last error wrong! NO_ERROR/0x%08x (NT4) expected, got %u\n",
116 MY_LAST_ERROR, GetLastError());
117 ok( hdl == 0L,
118 "Handle wrong! 0L expected, got 0x%08x\n", hdl);
120 SetLastError(MY_LAST_ERROR);
121 retval = GetFileVersionInfoSizeA( "notexist.dll", NULL);
122 ok( !retval,
123 "GetFileVersionInfoSizeA result wrong! 0L expected, got 0x%08x\n",
124 retval);
125 ok( (ERROR_FILE_NOT_FOUND == GetLastError()) ||
126 (ERROR_RESOURCE_DATA_NOT_FOUND == GetLastError()) ||
127 (MY_LAST_ERROR == GetLastError()) ||
128 (ERROR_SUCCESS == GetLastError()), /* win2k */
129 "Last error wrong! ERROR_FILE_NOT_FOUND/ERROR_RESOURCE_DATA_NOT_FOUND "
130 "(XP)/0x%08x (NT4) expected, got %u\n", MY_LAST_ERROR, GetLastError());
132 /* test a currently loaded executable */
133 if(GetModuleFileNameA(NULL, mypath, MAX_PATH)) {
134 hdl = 0x55555555;
135 SetLastError(MY_LAST_ERROR);
136 retval = GetFileVersionInfoSizeA( mypath, &hdl);
137 ok( retval,
138 "GetFileVersionInfoSizeA result wrong! <> 0L expected, got 0x%08x\n",
139 retval);
140 ok((NO_ERROR == GetLastError()) || (MY_LAST_ERROR == GetLastError()),
141 "Last error wrong! NO_ERROR/0x%08x (NT4) expected, got %u\n",
142 MY_LAST_ERROR, GetLastError());
143 ok( hdl == 0L,
144 "Handle wrong! 0L expected, got 0x%08x\n", hdl);
146 else
147 trace("skipping GetModuleFileNameA(NULL,..) failed\n");
149 /* test a not loaded executable */
150 if(GetSystemDirectoryA(mypath, MAX_PATH)) {
151 lstrcatA(mypath, "\\regsvr32.exe");
153 if(INVALID_FILE_ATTRIBUTES == GetFileAttributesA(mypath))
154 trace("GetFileAttributesA(%s) failed\n", mypath);
155 else {
156 hdl = 0x55555555;
157 SetLastError(MY_LAST_ERROR);
158 retval = GetFileVersionInfoSizeA( mypath, &hdl);
159 ok( retval,
160 "GetFileVersionInfoSizeA result wrong! <> 0L expected, got 0x%08x\n",
161 retval);
162 ok((NO_ERROR == GetLastError()) || (MY_LAST_ERROR == GetLastError()),
163 "Last error wrong! NO_ERROR/0x%08x (NT4) expected, got %u\n",
164 MY_LAST_ERROR, GetLastError());
165 ok( hdl == 0L,
166 "Handle wrong! 0L expected, got 0x%08x\n", hdl);
169 else
170 trace("skipping GetSystemDirectoryA(mypath,..) failed\n");
172 create_file("test.txt");
174 /* no version info */
175 SetLastError(0xdeadbeef);
176 hdl = 0xcafe;
177 retval = GetFileVersionInfoSizeA("test.txt", &hdl);
178 ok(retval == 0, "Expected 0, got %d\n", retval);
179 ok(hdl == 0, "Expected 0, got %d\n", hdl);
180 ok(GetLastError() == ERROR_RESOURCE_DATA_NOT_FOUND ||
181 GetLastError() == ERROR_BAD_FORMAT || /* win9x */
182 GetLastError() == ERROR_SUCCESS, /* win2k */
183 "Expected ERROR_RESOURCE_DATA_NOT_FOUND, got %d\n", GetLastError());
185 DeleteFileA("test.txt");
188 static void VersionDwordLong2String(DWORDLONG Version, LPSTR lpszVerString)
190 WORD a, b, c, d;
192 a = (WORD)(Version >> 48);
193 b = (WORD)((Version >> 32) & 0xffff);
194 c = (WORD)((Version >> 16) & 0xffff);
195 d = (WORD)(Version & 0xffff);
197 sprintf(lpszVerString, "%d.%d.%d.%d", a, b, c, d);
199 return;
202 static void test_info(void)
204 DWORD hdl, retval;
205 PVOID pVersionInfo = NULL;
206 BOOL boolret;
207 VS_FIXEDFILEINFO *pFixedVersionInfo;
208 UINT uiLength;
209 char VersionString[MAX_PATH];
210 static CHAR backslash[] = "\\";
211 DWORDLONG dwlVersion;
213 hdl = 0x55555555;
214 SetLastError(MY_LAST_ERROR);
215 retval = GetFileVersionInfoSizeA( "kernel32.dll", &hdl);
216 ok( retval,
217 "GetFileVersionInfoSizeA result wrong! <> 0L expected, got 0x%08x\n",
218 retval);
219 ok((NO_ERROR == GetLastError()) || (MY_LAST_ERROR == GetLastError()),
220 "Last error wrong! NO_ERROR/0x%08x (NT4) expected, got %u\n",
221 MY_LAST_ERROR, GetLastError());
222 ok( hdl == 0L,
223 "Handle wrong! 0L expected, got 0x%08x\n", hdl);
225 if ( retval == 0 || hdl != 0)
226 return;
228 pVersionInfo = HeapAlloc( GetProcessHeap(), HEAP_ZERO_MEMORY, retval );
229 ok(pVersionInfo != 0, "HeapAlloc failed\n" );
230 if (pVersionInfo == 0)
231 return;
233 if (0)
235 /* this test crashes on WinNT4
237 boolret = GetFileVersionInfoA( "kernel32.dll", 0, retval, 0);
238 ok (!boolret, "GetFileVersionInfoA should have failed: GetLastError = %u\n", GetLastError());
239 ok ((GetLastError() == ERROR_INVALID_DATA) || (GetLastError() == ERROR_BAD_PATHNAME) ||
240 (GetLastError() == NO_ERROR),
241 "Last error wrong! ERROR_INVALID_DATA/ERROR_BAD_PATHNAME (ME)/"
242 "NO_ERROR (95) expected, got %u\n",
243 GetLastError());
246 boolret = GetFileVersionInfoA( "kernel32.dll", 0, retval, pVersionInfo );
247 ok (boolret, "GetFileVersionInfoA failed: GetLastError = %u\n", GetLastError());
248 if (!boolret)
249 goto cleanup;
251 boolret = VerQueryValueA( pVersionInfo, NULL, (LPVOID *)&pFixedVersionInfo, &uiLength );
252 ok (boolret || GetLastError() == NO_ERROR /* Win98 */,
253 "VerQueryValueA failed: GetLastError = %u\n", GetLastError());
255 boolret = VerQueryValueA( pVersionInfo, "", (LPVOID *)&pFixedVersionInfo, &uiLength );
256 ok (boolret, "VerQueryValueA failed: GetLastError = %u\n", GetLastError());
258 boolret = VerQueryValueA( pVersionInfo, backslash, (LPVOID *)&pFixedVersionInfo, &uiLength );
259 ok (boolret, "VerQueryValueA failed: GetLastError = %u\n", GetLastError());
260 if (!boolret)
261 goto cleanup;
263 dwlVersion = (((DWORDLONG)pFixedVersionInfo->dwFileVersionMS) << 32) +
264 pFixedVersionInfo->dwFileVersionLS;
266 VersionDwordLong2String(dwlVersion, VersionString);
268 trace("kernel32.dll version: %s\n", VersionString);
270 if (0)
272 /* this test crashes on WinNT4
274 boolret = VerQueryValueA( pVersionInfo, backslash, (LPVOID *)&pFixedVersionInfo, 0);
275 ok (boolret, "VerQueryValue failed: GetLastError = %u\n", GetLastError());
278 cleanup:
279 HeapFree( GetProcessHeap(), 0, pVersionInfo);
282 static void test_32bit_win(void)
284 DWORD hdlA, retvalA;
285 DWORD hdlW, retvalW = 0;
286 BOOL retA,retW;
287 PVOID pVersionInfoA = NULL;
288 PVOID pVersionInfoW = NULL;
289 char *pBufA;
290 WCHAR *pBufW;
291 UINT uiLengthA, uiLengthW;
292 char mypathA[MAX_PATH];
293 WCHAR mypathW[MAX_PATH];
294 char rootA[] = "\\";
295 WCHAR rootW[] = { '\\', 0 };
296 WCHAR emptyW[] = { 0 };
297 char varfileinfoA[] = "\\VarFileInfo\\Translation";
298 WCHAR varfileinfoW[] = { '\\','V','a','r','F','i','l','e','I','n','f','o',
299 '\\','T','r','a','n','s','l','a','t','i','o','n', 0 };
300 char WineVarFileInfoA[] = { 0x09, 0x04, 0xE4, 0x04 };
301 char FileDescriptionA[] = "\\StringFileInfo\\040904E4\\FileDescription";
302 WCHAR FileDescriptionW[] = { '\\','S','t','r','i','n','g','F','i','l','e','I','n','f','o',
303 '\\','0','4','0','9','0','4','E','4',
304 '\\','F','i','l','e','D','e','s','c','r','i','p','t','i','o','n', 0 };
305 char WineFileDescriptionA[] = "FileDescription";
306 WCHAR WineFileDescriptionW[] = { 'F','i','l','e','D','e','s','c','r','i','p','t','i','o','n', 0 };
307 BOOL is_unicode_enabled = TRUE;
309 /* A copy from dlls/version/info.c */
310 typedef struct
312 WORD wLength;
313 WORD wValueLength;
314 WORD wType;
315 WCHAR szKey[1];
316 #if 0 /* variable length structure */
317 /* DWORD aligned */
318 BYTE Value[];
319 /* DWORD aligned */
320 VS_VERSION_INFO_STRUCT32 Children[];
321 #endif
322 } VS_VERSION_INFO_STRUCT32;
324 /* If we call GetFileVersionInfoA on a system that supports Unicode, NT/W2K/XP/W2K3 (by default) and Wine,
325 * the versioninfo will contain Unicode strings.
326 * Part of the test is to call both the A and W versions, which should have the same Version Information
327 * for some requests, on systems that support both calls.
330 /* First get the versioninfo via the W versions */
331 SetLastError(0xdeadbeef);
332 GetModuleFileNameW(NULL, mypathW, MAX_PATH);
333 if (GetLastError() == ERROR_CALL_NOT_IMPLEMENTED)
335 win_skip("GetModuleFileNameW not existing on this platform, skipping comparison between A- and W-calls\n");
336 is_unicode_enabled = FALSE;
339 if (is_unicode_enabled)
341 retvalW = GetFileVersionInfoSizeW( mypathW, &hdlW);
342 pVersionInfoW = HeapAlloc( GetProcessHeap(), HEAP_ZERO_MEMORY, retvalW );
343 retW = GetFileVersionInfoW( mypathW, 0, retvalW, pVersionInfoW );
346 GetModuleFileNameA(NULL, mypathA, MAX_PATH);
347 retvalA = GetFileVersionInfoSizeA( mypathA, &hdlA);
348 pVersionInfoA = HeapAlloc( GetProcessHeap(), HEAP_ZERO_MEMORY, retvalA );
349 retA = GetFileVersionInfoA( mypathA, 0, retvalA, pVersionInfoA );
351 if (is_unicode_enabled)
353 ok( retvalA == retvalW, "The size of the struct should be the same for both A/W calls, it is (%d) vs. (%d)\n",
354 retvalA, retvalW);
355 ok( !memcmp(pVersionInfoA, pVersionInfoW, retvalA), "Both structs should be the same, they aren't\n");
358 /* The structs on Windows are bigger than just the struct for the basic information. The total struct
359 * contains also an empty part, which is used for converted strings. The converted strings are a result
360 * of calling VerQueryValueA on a 32bit resource and calling VerQueryValueW on a 16bit resource.
361 * The first WORD of the structure (wLength) shows the size of the base struct. The total struct size depends
362 * on the Windows version:
364 * 16bits resource (numbers are from a sample app):
366 * Windows Version Retrieved with A/W wLength StructSize
367 * ====================================================================================
368 * Win98 A 0x01B4 (436) 436
369 * NT4 A/W 0x01B4 (436) 2048 ???
370 * W2K/XP/W2K3 A/W 0x01B4 (436) 1536 which is (436 - sizeof(VS_FIXEDFILEINFO)) * 4
372 * 32bits resource (numbers are from this test executable version_crosstest.exe):
373 * Windows Version Retrieved with A/W wLength StructSize
374 * =============================================================
375 * Win98 A 0x01E0 (480) 848 (structure data doesn't seem correct)
376 * NT4 A/W 0x0350 (848) 1272 (848 * 1.5)
377 * W2K/XP/W2K3 A/W 0x0350 (848) 1700 which is (848 * 2) + 4
379 * Wine will follow the implementation (eventually) of W2K/XP/W2K3
382 /* Now some tests for the above (only if we are unicode enabled) */
384 if (is_unicode_enabled)
386 VS_VERSION_INFO_STRUCT32 *vvis = (VS_VERSION_INFO_STRUCT32 *)pVersionInfoW;
387 ok ( retvalW == ((vvis->wLength * 2) + 4) || retvalW == (vvis->wLength * 1.5),
388 "Structure is not of the correct size\n");
391 /* Although the 32bit resource structures contain Unicode strings, VerQueryValueA will always return normal strings,
392 * VerQueryValueW will always return Unicode ones. (That means everything returned for StringFileInfo requests).
395 /* Get the VS_FIXEDFILEINFO information, this must be the same for both A- and W-Calls */
397 retA = VerQueryValueA( pVersionInfoA, rootA, (LPVOID *)&pBufA, &uiLengthA );
398 ok (retA, "VerQueryValueA failed: GetLastError = %u\n", GetLastError());
399 ok ( uiLengthA == sizeof(VS_FIXEDFILEINFO), "Size (%d) doesn't match the size of the VS_FIXEDFILEINFO struct\n", uiLengthA);
401 if (is_unicode_enabled)
403 retW = VerQueryValueW( pVersionInfoW, NULL, (LPVOID *)&pBufW, &uiLengthW );
404 ok (retW, "VerQueryValueW failed: GetLastError = %u\n", GetLastError());
406 retW = VerQueryValueW( pVersionInfoW, emptyW, (LPVOID *)&pBufW, &uiLengthW );
407 ok (retW, "VerQueryValueW failed: GetLastError = %u\n", GetLastError());
409 retW = VerQueryValueW( pVersionInfoW, rootW, (LPVOID *)&pBufW, &uiLengthW );
410 ok (retW, "VerQueryValueW failed: GetLastError = %u\n", GetLastError());
411 ok ( uiLengthA == sizeof(VS_FIXEDFILEINFO), "Size (%d) doesn't match the size of the VS_FIXEDFILEINFO struct\n", uiLengthA);
413 ok( uiLengthA == uiLengthW, "The size of VS_FIXEDFILEINFO should be the same for both A/W calls, it is (%d) vs. (%d)\n",
414 uiLengthA, uiLengthW);
415 ok( !memcmp(pBufA, pBufW, uiLengthA), "Both values should be the same, they aren't\n");
418 /* Get some VarFileInfo information, this must be the same for both A- and W-Calls */
420 retA = VerQueryValueA( pVersionInfoA, varfileinfoA, (LPVOID *)&pBufA, &uiLengthA );
421 ok (retA, "VerQueryValueA failed: GetLastError = %u\n", GetLastError());
422 ok( !memcmp(pBufA, WineVarFileInfoA, uiLengthA), "The VarFileInfo should have matched 0904e404 (non case sensitive)\n");
424 if (is_unicode_enabled)
426 retW = VerQueryValueW( pVersionInfoW, varfileinfoW, (LPVOID *)&pBufW, &uiLengthW );
427 ok (retW, "VerQueryValueW failed: GetLastError = %u\n", GetLastError());
428 ok( uiLengthA == uiLengthW, "The size of the VarFileInfo information should be the same for both A/W calls, it is (%d) vs. (%d)\n",
429 uiLengthA, uiLengthW);
430 ok( !memcmp(pBufA, pBufW, uiLengthA), "Both values should be the same, they aren't\n");
433 /* Get some StringFileInfo information, this will be ANSI for A-Calls and Unicode for W-Calls */
435 retA = VerQueryValueA( pVersionInfoA, FileDescriptionA, (LPVOID *)&pBufA, &uiLengthA );
436 ok (retA, "VerQueryValueA failed: GetLastError = %u\n", GetLastError());
437 ok( !lstrcmpA(WineFileDescriptionA, pBufA), "expected '%s' got '%s'\n",
438 WineFileDescriptionA, pBufA);
440 /* Test a second time */
441 retA = VerQueryValueA( pVersionInfoA, FileDescriptionA, (LPVOID *)&pBufA, &uiLengthA );
442 ok (retA, "VerQueryValueA failed: GetLastError = %u\n", GetLastError());
443 ok( !lstrcmpA(WineFileDescriptionA, pBufA), "expected '%s' got '%s'\n",
444 WineFileDescriptionA, pBufA);
446 if (is_unicode_enabled)
448 retW = VerQueryValueW( pVersionInfoW, FileDescriptionW, (LPVOID *)&pBufW, &uiLengthW );
449 ok (retW, "VerQueryValueW failed: GetLastError = %u\n", GetLastError());
450 ok( !lstrcmpW(WineFileDescriptionW, pBufW), "FileDescription should have been '%s'\n", WineFileDescriptionA);
453 HeapFree( GetProcessHeap(), 0, pVersionInfoA);
454 if (is_unicode_enabled)
455 HeapFree( GetProcessHeap(), 0, pVersionInfoW);
458 static void test_VerQueryValue(void)
460 static const char * const value_name[] = {
461 "Product", "CompanyName", "FileDescription", "Internal",
462 "ProductVersion", "InternalName", "File", "LegalCopyright",
463 "FileVersion", "Legal", "OriginalFilename", "ProductName",
464 "Company", "Original" };
465 char *ver, *p;
466 UINT len, ret, translation, i;
467 char buf[MAX_PATH];
469 ret = GetModuleFileName(NULL, buf, sizeof(buf));
470 assert(ret);
472 SetLastError(0xdeadbeef);
473 len = GetFileVersionInfoSize(buf, NULL);
474 ok(len, "GetFileVersionInfoSize(%s) error %u\n", buf, GetLastError());
476 ver = HeapAlloc(GetProcessHeap(), 0, len);
477 assert(ver);
479 SetLastError(0xdeadbeef);
480 ret = GetFileVersionInfo(buf, 0, len, ver);
481 ok(ret, "GetFileVersionInfo error %u\n", GetLastError());
483 p = (char *)0xdeadbeef;
484 len = 0xdeadbeef;
485 SetLastError(0xdeadbeef);
486 ret = VerQueryValue(ver, "\\VarFileInfo\\Translation", (LPVOID*)&p, &len);
487 ok(ret, "VerQueryValue error %u\n", GetLastError());
488 ok(len == 4, "VerQueryValue returned %u, expected 4\n", len);
490 translation = *(UINT *)p;
491 translation = MAKELONG(HIWORD(translation), LOWORD(translation));
493 p = (char *)0xdeadbeef;
494 len = 0xdeadbeef;
495 SetLastError(0xdeadbeef);
496 ret = VerQueryValue(ver, "String", (LPVOID*)&p, &len);
497 ok(!ret, "VerQueryValue should fail\n");
498 ok(GetLastError() == ERROR_RESOURCE_TYPE_NOT_FOUND ||
499 GetLastError() == 0xdeadbeef /* Win9x, NT4, W2K */,
500 "VerQueryValue returned %u\n", GetLastError());
501 ok(p == (char *)0xdeadbeef, "expected 0xdeadbeef got %p\n", p);
502 ok(len == 0 ||
503 len == 0xbeef, /* win9x */
504 "expected 0 got %x\n", len);
506 p = (char *)0xdeadbeef;
507 len = 0xdeadbeef;
508 SetLastError(0xdeadbeef);
509 ret = VerQueryValue(ver, "StringFileInfo", (LPVOID*)&p, &len);
510 ok(ret, "VerQueryValue error %u\n", GetLastError());
511 todo_wine ok(len == 0, "VerQueryValue returned %u, expected 0\n", len);
512 ok(p != (char *)0xdeadbeef, "not expected 0xdeadbeef\n");
514 p = (char *)0xdeadbeef;
515 len = 0xdeadbeef;
516 SetLastError(0xdeadbeef);
517 ret = VerQueryValue(ver, "\\StringFileInfo", (LPVOID*)&p, &len);
518 ok(ret, "VerQueryValue error %u\n", GetLastError());
519 todo_wine ok(len == 0, "VerQueryValue returned %u, expected 0\n", len);
520 ok(p != (char *)0xdeadbeef, "not expected 0xdeadbeef\n");
522 p = (char *)0xdeadbeef;
523 len = 0xdeadbeef;
524 SetLastError(0xdeadbeef);
525 ret = VerQueryValue(ver, "\\\\StringFileInfo", (LPVOID*)&p, &len);
526 ok(ret, "VerQueryValue error %u\n", GetLastError());
527 todo_wine ok(len == 0, "VerQueryValue returned %u, expected 0\n", len);
528 ok(p != (char *)0xdeadbeef, "not expected 0xdeadbeef\n");
530 p = (char *)0xdeadbeef;
531 len = 0xdeadbeef;
532 SetLastError(0xdeadbeef);
533 ret = VerQueryValue(ver, "\\StringFileInfo\\\\", (LPVOID*)&p, &len);
534 ok(ret, "VerQueryValue error %u\n", GetLastError());
535 todo_wine ok(len == 0, "VerQueryValue returned %u, expected 0\n", len);
536 ok(p != (char *)0xdeadbeef, "not expected 0xdeadbeef\n");
538 sprintf(buf, "\\StringFileInfo\\%08x", translation);
539 p = (char *)0xdeadbeef;
540 len = 0xdeadbeef;
541 SetLastError(0xdeadbeef);
542 ret = VerQueryValue(ver, buf, (LPVOID*)&p, &len);
543 ok(ret, "VerQueryValue error %u\n", GetLastError());
544 todo_wine ok(len == 0, "VerQueryValue returned %u, expected 0\n", len);
545 ok(p != (char *)0xdeadbeef, "not expected 0xdeadbeef\n");
547 for (i = 0; i < sizeof(value_name)/sizeof(value_name[0]); i++)
549 sprintf(buf, "\\StringFileInfo\\%08x\\%s", translation, value_name[i]);
550 p = (char *)0xdeadbeef;
551 len = 0xdeadbeef;
552 SetLastError(0xdeadbeef);
553 ret = VerQueryValue(ver, buf, (LPVOID*)&p, &len);
554 ok(ret, "VerQueryValue(%s) error %u\n", buf, GetLastError());
555 ok(len == strlen(value_name[i]) + 1, "VerQueryValue returned %u\n", len);
556 ok(!strcmp(value_name[i], p), "expected \"%s\", got \"%s\"\n",
557 value_name[i], p);
559 /* test partial value names */
560 len = lstrlen(buf);
561 buf[len - 2] = 0;
562 p = (char *)0xdeadbeef;
563 len = 0xdeadbeef;
564 SetLastError(0xdeadbeef);
565 ret = VerQueryValue(ver, buf, (LPVOID*)&p, &len);
566 ok(!ret, "VerQueryValue(%s) succeeded\n", buf);
567 ok(GetLastError() == ERROR_RESOURCE_TYPE_NOT_FOUND ||
568 GetLastError() == 0xdeadbeef /* Win9x, NT4, W2K */,
569 "VerQueryValue returned %u\n", GetLastError());
570 ok(p == (char *)0xdeadbeef, "expected 0xdeadbeef got %p\n", p);
571 ok(len == 0 ||
572 len == 0xbeef, /* win9x */
573 "expected 0 or 0xbeef, got %x\n", len);
576 HeapFree(GetProcessHeap(), 0, ver);
579 START_TEST(info)
581 test_info_size();
582 test_info();
583 test_32bit_win();
584 test_VerQueryValue();