wined3d: texturefactor-> fragment states.
[wine] / dlls / setupapi / tests / query.c
1 /*
2  * Unit tests for setupapi.dll query functions
3  *
4  * Copyright (C) 2006 James Hawkins
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 <stdio.h>
22 #include <windows.h>
23 #include <setupapi.h>
24 #include "wine/test.h"
25
26 CHAR CURR_DIR[MAX_PATH];
27 CHAR WIN_DIR[MAX_PATH];
28
29 static void get_directories(void)
30 {
31     int len;
32
33     GetCurrentDirectoryA(MAX_PATH, CURR_DIR);
34     len = lstrlenA(CURR_DIR);
35
36     if(len && (CURR_DIR[len-1] == '\\'))
37         CURR_DIR[len-1] = 0;
38
39     GetWindowsDirectoryA(WIN_DIR, MAX_PATH);
40     len = lstrlenA(WIN_DIR);
41
42     if (len && (WIN_DIR[len-1] == '\\'))
43         WIN_DIR[len-1] = 0;
44 }
45
46 static void append_str(char **str, const char *data)
47 {
48     sprintf(*str, data);
49     *str += strlen(*str);
50 }
51
52 static void create_inf_file(LPSTR filename)
53 {
54     char data[1024];
55     char *ptr = data;
56     DWORD dwNumberOfBytesWritten;
57     HANDLE hf = CreateFile(filename, GENERIC_WRITE, 0, NULL,
58                            CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, NULL);
59
60     append_str(&ptr, "[Version]\n");
61     append_str(&ptr, "Signature=\"$Chicago$\"\n");
62     append_str(&ptr, "AdvancedINF=2.5\n");
63     append_str(&ptr, "[SourceDisksNames]\n");
64     append_str(&ptr, "2 = %%SrcDiskName%%, LANCOM\\LANtools\\lanconf.cab\n");
65     append_str(&ptr, "[SourceDisksFiles]\n");
66     append_str(&ptr, "lanconf.exe = 2\n");
67     append_str(&ptr, "[DestinationDirs]\n");
68     append_str(&ptr, "DefaultDestDir = 24, %%DefaultDest%%\n");
69     append_str(&ptr, "[Strings]\n");
70     append_str(&ptr, "LangDir = english\n");
71     append_str(&ptr, "DefaultDest = LANCOM\n");
72     append_str(&ptr, "SrcDiskName = \"LANCOM Software CD\"\n");
73
74     WriteFile(hf, data, ptr - data, &dwNumberOfBytesWritten, NULL);
75     CloseHandle(hf);
76 }
77
78 static void create_inf_file2(LPSTR filename)
79 {
80     char data[1024];
81     char *ptr = data;
82     DWORD dwNumberOfBytesWritten;
83     HANDLE hf = CreateFile(filename, GENERIC_WRITE, 0, NULL,
84                            CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, NULL);
85
86     append_str(&ptr, "[SourceFileInfo]\n");
87     append_str(&ptr, "sp1qfe\\bitsinst.exe=250B3702C7CCD7C2F9E4DAA1555C933E,000600060A28062C,27136,SP1QFE\n");
88     append_str(&ptr, "sp1qfe\\bitsprx2.dll=4EBEA67F4BB4EB402E725CA7CA2857AE,000600060A280621,7680,SP1QFE\n");
89     append_str(&ptr, "sp1qfe\\bitsprx3.dll=C788A1D9330DA011EF25E95D3BC7BDE5,000600060A280621,7168,SP1QFE\n");
90     append_str(&ptr, "sp1qfe\\qmgr.dll=696AC82FB290A03F205901442E0E9589,000600060A280621,361984,SP1QFE\n");
91     append_str(&ptr, "sp1qfe\\qmgrprxy.dll=8B5848144829E1BC985EA4C3D8CA7E3F,000600060A280621,17408,SP1QFE\n");
92     append_str(&ptr, "sp1qfe\\winhttp.dll=3EC6F518114606CA59D4160322077437,000500010A280615,331776,SP1QFE\n");
93     append_str(&ptr, "sp1qfe\\xpob2res.dll=DB83156B9F496F20D1EA70E4ABEC0166,000500010A280622,158720,SP1QFE\n");
94
95     WriteFile(hf, data, ptr - data, &dwNumberOfBytesWritten, NULL);
96     CloseHandle(hf);
97 }
98
99 static BOOL check_info_filename(PSP_INF_INFORMATION info, LPSTR test)
100 {
101     LPSTR filename;
102     DWORD size;
103     BOOL ret = FALSE;
104
105     if (!SetupQueryInfFileInformationA(info, 0, NULL, 0, &size))
106         return FALSE;
107
108     filename = HeapAlloc(GetProcessHeap(), 0, size);
109     if (!filename)
110         return FALSE;
111
112     SetupQueryInfFileInformationA(info, 0, filename, size, &size);
113
114     if (!lstrcmpiA(test, filename))
115         ret = TRUE;
116
117     HeapFree(GetProcessHeap(), 0, filename);
118     return ret;
119 }
120
121 static PSP_INF_INFORMATION alloc_inf_info(LPCSTR filename, DWORD search, PDWORD size)
122 {
123     PSP_INF_INFORMATION info;
124     BOOL ret;
125
126     ret = SetupGetInfInformationA(filename, search, NULL, 0, size);
127     if (!ret)
128         return NULL;
129
130     info = HeapAlloc(GetProcessHeap(), 0, *size);
131     return info;
132 }
133
134 static void test_SetupGetInfInformation(void)
135 {
136     PSP_INF_INFORMATION info;
137     CHAR inf_filename[MAX_PATH];
138     CHAR inf_one[MAX_PATH], inf_two[MAX_PATH];
139     DWORD size;
140     HINF hinf;
141     BOOL ret;
142
143     lstrcpyA(inf_filename, CURR_DIR);
144     lstrcatA(inf_filename, "\\");
145     lstrcatA(inf_filename, "test.inf");
146
147     /* try an invalid inf handle */
148     size = 0xdeadbeef;
149     SetLastError(0xbeefcafe);
150     ret = SetupGetInfInformationA(NULL, INFINFO_INF_SPEC_IS_HINF, NULL, 0, &size);
151     ok(ret == FALSE, "Expected SetupGetInfInformation to fail\n");
152     ok(GetLastError() == ERROR_INVALID_HANDLE ||
153        broken(GetLastError() == ERROR_BAD_PATHNAME) || /* win95 */
154        broken(GetLastError() == ERROR_FILE_NOT_FOUND) || /* win98 */
155        broken(GetLastError() == ERROR_PATH_NOT_FOUND) || /* NT4 */
156        broken(GetLastError() == ERROR_INVALID_NAME), /* win2k */
157        "Expected ERROR_INVALID_HANDLE, got %d\n", GetLastError());
158     ok(size == 0xdeadbeef, "Expected size to remain unchanged\n");
159
160     /* try an invalid inf filename */
161     size = 0xdeadbeef;
162     SetLastError(0xbeefcafe);
163     ret = SetupGetInfInformationA(NULL, INFINFO_INF_NAME_IS_ABSOLUTE, NULL, 0, &size);
164     ok(ret == FALSE, "Expected SetupGetInfInformation to fail\n");
165     ok(GetLastError() == ERROR_INVALID_PARAMETER,
166        "Expected ERROR_INVALID_PARAMETER, got %d\n", GetLastError());
167     ok(size == 0xdeadbeef, "Expected size to remain unchanged\n");
168
169     create_inf_file(inf_filename);
170
171     /* try an invalid search flag */
172     size = 0xdeadbeef;
173     SetLastError(0xbeefcafe);
174     ret = SetupGetInfInformationA(inf_filename, -1, NULL, 0, &size);
175     ok(ret == FALSE, "Expected SetupGetInfInformation to fail\n");
176     ok(GetLastError() == ERROR_INVALID_PARAMETER,
177        "Expected ERROR_INVALID_PARAMETER, got %d\n", GetLastError());
178     ok(size == 0xdeadbeef, "Expected size to remain unchanged\n");
179
180     /* try a nonexistent inf file */
181     size = 0xdeadbeef;
182     SetLastError(0xbeefcafe);
183     ret = SetupGetInfInformationA("idontexist", INFINFO_INF_NAME_IS_ABSOLUTE, NULL, 0, &size);
184     ok(ret == FALSE, "Expected SetupGetInfInformation to fail\n");
185     ok(GetLastError() == ERROR_FILE_NOT_FOUND,
186        "Expected ERROR_FILE_NOT_FOUND, got %d\n", GetLastError());
187     ok(size == 0xdeadbeef, "Expected size to remain unchanged\n");
188
189     /* successfully open the inf file */
190     size = 0xdeadbeef;
191     ret = SetupGetInfInformationA(inf_filename, INFINFO_INF_NAME_IS_ABSOLUTE, NULL, 0, &size);
192     ok(ret == TRUE, "Expected SetupGetInfInformation to succeed\n");
193     ok(size != 0xdeadbeef, "Expected a valid size on return\n");
194
195     /* set ReturnBuffer to NULL and ReturnBufferSize to non-zero value 'size' */
196     SetLastError(0xbeefcafe);
197     ret = SetupGetInfInformationA(inf_filename, INFINFO_INF_NAME_IS_ABSOLUTE, NULL, size, &size);
198     ok(ret == FALSE, "Expected SetupGetInfInformation to fail\n");
199     ok(GetLastError() == ERROR_INVALID_PARAMETER,
200        "Expected ERROR_INVALID_PARAMETER, got %d\n", GetLastError());
201
202     /* set ReturnBuffer to NULL and ReturnBufferSize to non-zero value 'size-1' */
203     ret = SetupGetInfInformationA(inf_filename, INFINFO_INF_NAME_IS_ABSOLUTE, NULL, size-1, &size);
204     ok(ret == TRUE, "Expected SetupGetInfInformation to succeed\n");
205
206     /* some tests for behaviour with a NULL RequiredSize pointer */
207     ret = SetupGetInfInformationA(inf_filename, INFINFO_INF_NAME_IS_ABSOLUTE, NULL, 0, NULL);
208     ok(ret == TRUE, "Expected SetupGetInfInformation to succeed\n");
209     ret = SetupGetInfInformationA(inf_filename, INFINFO_INF_NAME_IS_ABSOLUTE, NULL, size - 1, NULL);
210     ok(ret == TRUE, "Expected SetupGetInfInformation to succeed\n");
211     ret = SetupGetInfInformationA(inf_filename, INFINFO_INF_NAME_IS_ABSOLUTE, NULL, size, NULL);
212     ok(ret == FALSE, "Expected SetupGetInfInformation to fail\n");
213
214     info = HeapAlloc(GetProcessHeap(), 0, size);
215
216     /* try valid ReturnBuffer but too small size */
217     SetLastError(0xbeefcafe);
218     ret = SetupGetInfInformationA(inf_filename, INFINFO_INF_NAME_IS_ABSOLUTE, info, size - 1, &size);
219     ok(ret == FALSE, "Expected SetupGetInfInformation to fail\n");
220     ok(GetLastError() == ERROR_INSUFFICIENT_BUFFER,
221        "Expected ERROR_INSUFFICIENT_BUFFER, got %d\n", GetLastError());
222
223     /* successfully get the inf information */
224     ret = SetupGetInfInformationA(inf_filename, INFINFO_INF_NAME_IS_ABSOLUTE, info, size, &size);
225     ok(ret == TRUE, "Expected SetupGetInfInformation to succeed\n");
226     ok(check_info_filename(info, inf_filename), "Expected returned filename to be equal\n");
227
228     HeapFree(GetProcessHeap(), 0, info);
229
230     /* try the INFINFO_INF_SPEC_IS_HINF search flag */
231     hinf = SetupOpenInfFileA(inf_filename, NULL, INF_STYLE_WIN4, NULL);
232     info = alloc_inf_info(hinf, INFINFO_INF_SPEC_IS_HINF, &size);
233     ret = SetupGetInfInformationA(hinf, INFINFO_INF_SPEC_IS_HINF, info, size, &size);
234     ok(ret == TRUE, "Expected SetupGetInfInformation to succeed\n");
235     ok(check_info_filename(info, inf_filename), "Expected returned filename to be equal\n");
236     SetupCloseInfFile(hinf);
237
238     lstrcpyA(inf_one, WIN_DIR);
239     lstrcatA(inf_one, "\\inf\\");
240     lstrcatA(inf_one, "test.inf");
241     create_inf_file(inf_one);
242
243     lstrcpyA(inf_two, WIN_DIR);
244     lstrcatA(inf_two, "\\system32\\");
245     lstrcatA(inf_two, "test.inf");
246     create_inf_file(inf_two);
247
248     HeapFree(GetProcessHeap(), 0, info);
249     info = alloc_inf_info("test.inf", INFINFO_DEFAULT_SEARCH, &size);
250
251     /* test the INFINFO_DEFAULT_SEARCH search flag */
252     ret = SetupGetInfInformationA("test.inf", INFINFO_DEFAULT_SEARCH, info, size, &size);
253     ok(ret == TRUE, "Expected SetupGetInfInformation to succeed\n");
254     ok(check_info_filename(info, inf_one), "Expected returned filename to be equal\n");
255
256     HeapFree(GetProcessHeap(), 0, info);
257     info = alloc_inf_info("test.inf", INFINFO_REVERSE_DEFAULT_SEARCH, &size);
258
259     /* test the INFINFO_REVERSE_DEFAULT_SEARCH search flag */
260     ret = SetupGetInfInformationA("test.inf", INFINFO_REVERSE_DEFAULT_SEARCH, info, size, &size);
261     ok(ret == TRUE, "Expected SetupGetInfInformation to succeed\n");
262     ok(check_info_filename(info, inf_two), "Expected returned filename to be equal\n");
263
264     DeleteFileA(inf_filename);
265     DeleteFileA(inf_one);
266     DeleteFileA(inf_two);
267 }
268
269 static void test_SetupGetSourceFileLocation(void)
270 {
271     char buffer[MAX_PATH] = "not empty", inf_filename[MAX_PATH];
272     UINT source_id;
273     DWORD required, error;
274     HINF hinf;
275     BOOL ret;
276
277     lstrcpyA(inf_filename, CURR_DIR);
278     lstrcatA(inf_filename, "\\");
279     lstrcatA(inf_filename, "test.inf");
280
281     create_inf_file(inf_filename);
282
283     hinf = SetupOpenInfFileA(inf_filename, NULL, INF_STYLE_WIN4, NULL);
284     ok(hinf != INVALID_HANDLE_VALUE, "could not open inf file\n");
285
286     required = 0;
287     source_id = 0;
288
289     ret = SetupGetSourceFileLocationA(hinf, NULL, "lanconf.exe", &source_id, buffer, sizeof(buffer), &required);
290     ok(ret, "SetupGetSourceFileLocation failed\n");
291
292     ok(required == 1, "unexpected required size: %d\n", required);
293     ok(source_id == 2, "unexpected source id: %d\n", source_id);
294     ok(!lstrcmpA("", buffer), "unexpected result string: %s\n", buffer);
295
296     SetupCloseInfFile(hinf);
297     DeleteFileA(inf_filename);
298
299     create_inf_file2(inf_filename);
300
301     SetLastError(0xdeadbeef);
302     hinf = SetupOpenInfFileA(inf_filename, NULL, INF_STYLE_WIN4, NULL);
303     error = GetLastError();
304     ok(hinf == INVALID_HANDLE_VALUE, "could open inf file\n");
305     ok(error == ERROR_WRONG_INF_STYLE, "got wrong error: %d\n", error);
306
307     hinf = SetupOpenInfFileA(inf_filename, NULL, INF_STYLE_OLDNT, NULL);
308     ok(hinf != INVALID_HANDLE_VALUE, "could not open inf file\n");
309
310     ret = SetupGetSourceFileLocationA(hinf, NULL, "", &source_id, buffer, sizeof(buffer), &required);
311     ok(!ret, "SetupGetSourceFileLocation succeeded\n");
312
313     SetupCloseInfFile(hinf);
314     DeleteFileA(inf_filename);
315 }
316
317 static void test_SetupGetSourceInfo(void)
318 {
319     char buffer[MAX_PATH], inf_filename[MAX_PATH];
320     DWORD required;
321     HINF hinf;
322     BOOL ret;
323
324     lstrcpyA(inf_filename, CURR_DIR);
325     lstrcatA(inf_filename, "\\");
326     lstrcatA(inf_filename, "test.inf");
327
328     create_inf_file(inf_filename);
329
330     hinf = SetupOpenInfFileA(inf_filename, NULL, INF_STYLE_WIN4, NULL);
331     ok(hinf != INVALID_HANDLE_VALUE, "could not open inf file\n");
332
333     required = 0;
334
335     ret = SetupGetSourceInfoA(hinf, 2, SRCINFO_PATH, buffer, sizeof(buffer), &required);
336     ok(ret, "SetupGetSourceInfoA failed\n");
337
338     ok(required == 1, "unexpected required size: %d\n", required);
339     ok(!lstrcmpA("", buffer), "unexpected result string: %s\n", buffer);
340
341     required = 0;
342     buffer[0] = 0;
343
344     ret = SetupGetSourceInfoA(hinf, 2, SRCINFO_TAGFILE, buffer, sizeof(buffer), &required);
345     ok(ret, "SetupGetSourceInfoA failed\n");
346
347     ok(required == 28, "unexpected required size: %d\n", required);
348     ok(!lstrcmpA("LANCOM\\LANtools\\lanconf.cab", buffer), "unexpected result string: %s\n", buffer);
349
350     required = 0;
351     buffer[0] = 0;
352
353     ret = SetupGetSourceInfoA(hinf, 2, SRCINFO_DESCRIPTION, buffer, sizeof(buffer), &required);
354     ok(ret, "SetupGetSourceInfoA failed\n");
355
356     ok(required == 19, "unexpected required size: %d\n", required);
357     ok(!lstrcmpA("LANCOM Software CD", buffer), "unexpected result string: %s\n", buffer);
358
359     SetupCloseInfFile(hinf);
360     DeleteFileA(inf_filename);
361 }
362
363 static void test_SetupGetTargetPath(void)
364 {
365     char buffer[MAX_PATH], inf_filename[MAX_PATH];
366     DWORD required;
367     HINF hinf;
368     INFCONTEXT ctx;
369     BOOL ret;
370
371     lstrcpyA(inf_filename, CURR_DIR);
372     lstrcatA(inf_filename, "\\");
373     lstrcatA(inf_filename, "test.inf");
374
375     create_inf_file(inf_filename);
376
377     hinf = SetupOpenInfFileA(inf_filename, NULL, INF_STYLE_WIN4, NULL);
378     ok(hinf != INVALID_HANDLE_VALUE, "could not open inf file\n");
379
380     ctx.Inf = hinf;
381     ctx.CurrentInf = hinf;
382     ctx.Section = 7;
383     ctx.Line = 0;
384
385     required = 0;
386
387     ret = SetupGetTargetPathA(hinf, &ctx, NULL, buffer, sizeof(buffer), &required);
388     ok(ret, "SetupGetTargetPathA failed\n");
389
390     ok(required == 10, "unexpected required size: %d\n", required);
391     ok(!lstrcmpiA("C:\\LANCOM", buffer), "unexpected result string: %s\n", buffer);
392
393     SetupCloseInfFile(hinf);
394     DeleteFileA(inf_filename);
395 }
396
397 START_TEST(query)
398 {
399     get_directories();
400
401     test_SetupGetInfInformation();
402     test_SetupGetSourceFileLocation();
403     test_SetupGetSourceInfo();
404     test_SetupGetTargetPath();
405 }