2 * Unit tests for Event Logging functions
4 * Copyright (c) 2009 Paul Vriens
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
30 #include "wine/test.h"
32 static BOOL (WINAPI
*pCreateWellKnownSid
)(WELL_KNOWN_SID_TYPE
,PSID
,PSID
,DWORD
*);
33 static BOOL (WINAPI
*pGetEventLogInformation
)(HANDLE
,DWORD
,LPVOID
,DWORD
,LPDWORD
);
35 static BOOL (WINAPI
*pGetComputerNameExA
)(COMPUTER_NAME_FORMAT
,LPSTR
,LPDWORD
);
36 static BOOL (WINAPI
*pWow64DisableWow64FsRedirection
)(PVOID
*);
37 static BOOL (WINAPI
*pWow64RevertWow64FsRedirection
)(PVOID
);
39 static void init_function_pointers(void)
41 HMODULE hadvapi32
= GetModuleHandleA("advapi32.dll");
42 HMODULE hkernel32
= GetModuleHandleA("kernel32.dll");
44 pCreateWellKnownSid
= (void*)GetProcAddress(hadvapi32
, "CreateWellKnownSid");
45 pGetEventLogInformation
= (void*)GetProcAddress(hadvapi32
, "GetEventLogInformation");
47 pGetComputerNameExA
= (void*)GetProcAddress(hkernel32
, "GetComputerNameExA");
48 pWow64DisableWow64FsRedirection
= (void*)GetProcAddress(hkernel32
, "Wow64DisableWow64FsRedirection");
49 pWow64RevertWow64FsRedirection
= (void*)GetProcAddress(hkernel32
, "Wow64RevertWow64FsRedirection");
52 static void create_backup(const char *filename
)
56 DeleteFileA(filename
);
57 handle
= OpenEventLogA(NULL
, "Application");
58 BackupEventLogA(handle
, filename
);
59 CloseEventLog(handle
);
62 ok(GetFileAttributesA(filename
) != INVALID_FILE_ATTRIBUTES
, "Expected a backup file\n");
65 static void test_open_close(void)
70 SetLastError(0xdeadbeef);
71 ret
= CloseEventLog(NULL
);
72 ok(!ret
, "Expected failure\n");
73 ok(GetLastError() == ERROR_INVALID_HANDLE
||
74 GetLastError() == ERROR_NOACCESS
, /* W2K */
75 "Expected ERROR_INVALID_HANDLE, got %d\n", GetLastError());
77 SetLastError(0xdeadbeef);
78 handle
= OpenEventLogA(NULL
, NULL
);
79 ok(handle
== NULL
, "Didn't expect a handle\n");
80 ok(GetLastError() == ERROR_INVALID_PARAMETER
, "Expected ERROR_INVALID_PARAMETER, got %d\n", GetLastError());
82 SetLastError(0xdeadbeef);
83 handle
= OpenEventLogA("IDontExist", NULL
);
84 ok(handle
== NULL
, "Didn't expect a handle\n");
85 ok(GetLastError() == ERROR_INVALID_PARAMETER
, "Expected ERROR_INVALID_PARAMETER, got %d\n", GetLastError());
87 SetLastError(0xdeadbeef);
88 handle
= OpenEventLogA("IDontExist", "deadbeef");
89 ok(handle
== NULL
, "Didn't expect a handle\n");
90 ok(GetLastError() == RPC_S_SERVER_UNAVAILABLE
||
91 GetLastError() == RPC_S_INVALID_NET_ADDR
, /* Some Vista and Win7 */
92 "Expected RPC_S_SERVER_UNAVAILABLE, got %d\n", GetLastError());
94 /* This one opens the Application log */
95 handle
= OpenEventLogA(NULL
, "deadbeef");
96 ok(handle
!= NULL
, "Expected a handle\n");
97 ret
= CloseEventLog(handle
);
98 ok(ret
, "Expected success\n");
99 /* Close a second time */
100 SetLastError(0xdeadbeef);
101 ret
= CloseEventLog(handle
);
104 ok(!ret
, "Expected failure\n");
105 ok(GetLastError() == ERROR_INVALID_HANDLE
, "Expected ERROR_INVALID_HANDLE, got %d\n", GetLastError());
108 /* Empty servername should be read as local server */
109 handle
= OpenEventLogA("", "Application");
110 ok(handle
!= NULL
, "Expected a handle\n");
111 CloseEventLog(handle
);
113 handle
= OpenEventLogA(NULL
, "Application");
114 ok(handle
!= NULL
, "Expected a handle\n");
115 CloseEventLog(handle
);
118 static void test_info(void)
123 EVENTLOG_FULL_INFORMATION efi
;
125 if (!pGetEventLogInformation
)
128 win_skip("GetEventLogInformation is not available\n");
131 SetLastError(0xdeadbeef);
132 ret
= pGetEventLogInformation(NULL
, 1, NULL
, 0, NULL
);
133 ok(!ret
, "Expected failure\n");
134 ok(GetLastError() == ERROR_INVALID_LEVEL
, "Expected ERROR_INVALID_LEVEL, got %d\n", GetLastError());
136 SetLastError(0xdeadbeef);
137 ret
= pGetEventLogInformation(NULL
, EVENTLOG_FULL_INFO
, NULL
, 0, NULL
);
138 ok(!ret
, "Expected failure\n");
139 ok(GetLastError() == ERROR_INVALID_HANDLE
, "Expected ERROR_INVALID_HANDLE, got %d\n", GetLastError());
141 handle
= OpenEventLogA(NULL
, "Application");
143 SetLastError(0xdeadbeef);
144 ret
= pGetEventLogInformation(handle
, EVENTLOG_FULL_INFO
, NULL
, 0, NULL
);
145 ok(!ret
, "Expected failure\n");
146 ok(GetLastError() == RPC_X_NULL_REF_POINTER
, "Expected RPC_X_NULL_REF_POINTER, got %d\n", GetLastError());
148 SetLastError(0xdeadbeef);
149 ret
= pGetEventLogInformation(handle
, EVENTLOG_FULL_INFO
, NULL
, 0, &needed
);
150 ok(!ret
, "Expected failure\n");
151 ok(GetLastError() == RPC_X_NULL_REF_POINTER
, "Expected RPC_X_NULL_REF_POINTER, got %d\n", GetLastError());
153 SetLastError(0xdeadbeef);
154 ret
= pGetEventLogInformation(handle
, EVENTLOG_FULL_INFO
, (LPVOID
)&efi
, 0, NULL
);
155 ok(!ret
, "Expected failure\n");
156 ok(GetLastError() == RPC_X_NULL_REF_POINTER
, "Expected RPC_X_NULL_REF_POINTER, got %d\n", GetLastError());
158 SetLastError(0xdeadbeef);
160 efi
.dwFull
= 0xdeadbeef;
161 ret
= pGetEventLogInformation(handle
, EVENTLOG_FULL_INFO
, (LPVOID
)&efi
, 0, &needed
);
162 ok(!ret
, "Expected failure\n");
163 ok(GetLastError() == ERROR_INSUFFICIENT_BUFFER
, "Expected ERROR_INSUFFICIENT_BUFFER, got %d\n", GetLastError());
164 ok(needed
== sizeof(EVENTLOG_FULL_INFORMATION
), "Expected sizeof(EVENTLOG_FULL_INFORMATION), got %d\n", needed
);
165 ok(efi
.dwFull
== 0xdeadbeef, "Expected no change to the dwFull member\n");
167 /* Not that we care, but on success last error is set to ERROR_IO_PENDING */
168 efi
.dwFull
= 0xdeadbeef;
170 ret
= pGetEventLogInformation(handle
, EVENTLOG_FULL_INFO
, (LPVOID
)&efi
, needed
, &needed
);
171 ok(ret
, "Expected success\n");
172 ok(needed
== sizeof(EVENTLOG_FULL_INFORMATION
), "Expected sizeof(EVENTLOG_FULL_INFORMATION), got %d\n", needed
);
173 ok(efi
.dwFull
== 0 || efi
.dwFull
== 1, "Expected 0 (not full) or 1 (full), got %d\n", efi
.dwFull
);
175 CloseEventLog(handle
);
178 static void test_count(void)
183 const char backup
[] = "backup.evt";
185 SetLastError(0xdeadbeef);
186 ret
= GetNumberOfEventLogRecords(NULL
, NULL
);
187 ok(!ret
, "Expected failure\n");
188 ok(GetLastError() == ERROR_INVALID_PARAMETER
, "Expected ERROR_INVALID_PARAMETER, got %d\n", GetLastError());
190 SetLastError(0xdeadbeef);
192 ret
= GetNumberOfEventLogRecords(NULL
, &count
);
193 ok(!ret
, "Expected failure\n");
194 ok(GetLastError() == ERROR_INVALID_HANDLE
, "Expected ERROR_INVALID_HANDLE, got %d\n", GetLastError());
195 ok(count
== 0xdeadbeef, "Expected count to stay unchanged\n");
197 handle
= OpenEventLogA(NULL
, "Application");
199 SetLastError(0xdeadbeef);
200 ret
= GetNumberOfEventLogRecords(handle
, NULL
);
201 ok(!ret
, "Expected failure\n");
202 ok(GetLastError() == ERROR_INVALID_PARAMETER
, "Expected ERROR_INVALID_PARAMETER, got %d\n", GetLastError());
205 ret
= GetNumberOfEventLogRecords(handle
, &count
);
206 ok(ret
, "Expected success\n");
207 ok(count
!= 0xdeadbeef, "Expected the number of records\n");
209 CloseEventLog(handle
);
211 /* Make a backup eventlog to work with */
212 create_backup(backup
);
214 handle
= OpenBackupEventLogA(NULL
, backup
);
216 ok(handle
!= NULL
, "Expected a handle\n");
218 /* Does GetNumberOfEventLogRecords work with backup eventlogs? */
220 ret
= GetNumberOfEventLogRecords(handle
, &count
);
223 ok(ret
, "Expected success\n");
224 ok(count
!= 0xdeadbeef, "Expected the number of records\n");
227 CloseEventLog(handle
);
231 static void test_oldest(void)
236 const char backup
[] = "backup.evt";
238 SetLastError(0xdeadbeef);
239 ret
= GetOldestEventLogRecord(NULL
, NULL
);
240 ok(!ret
, "Expected failure\n");
241 ok(GetLastError() == ERROR_INVALID_PARAMETER
, "Expected ERROR_INVALID_PARAMETER, got %d\n", GetLastError());
243 SetLastError(0xdeadbeef);
245 ret
= GetOldestEventLogRecord(NULL
, &oldest
);
246 ok(!ret
, "Expected failure\n");
247 ok(GetLastError() == ERROR_INVALID_HANDLE
, "Expected ERROR_INVALID_HANDLE, got %d\n", GetLastError());
248 ok(oldest
== 0xdeadbeef, "Expected oldest to stay unchanged\n");
250 handle
= OpenEventLogA(NULL
, "Application");
252 SetLastError(0xdeadbeef);
253 ret
= GetOldestEventLogRecord(handle
, NULL
);
254 ok(!ret
, "Expected failure\n");
255 ok(GetLastError() == ERROR_INVALID_PARAMETER
, "Expected ERROR_INVALID_PARAMETER, got %d\n", GetLastError());
258 ret
= GetOldestEventLogRecord(handle
, &oldest
);
259 ok(ret
, "Expected success\n");
260 ok(oldest
!= 0xdeadbeef, "Expected the number of the oldest record\n");
262 CloseEventLog(handle
);
264 /* Make a backup eventlog to work with */
265 create_backup(backup
);
267 handle
= OpenBackupEventLogA(NULL
, backup
);
269 ok(handle
!= NULL
, "Expected a handle\n");
271 /* Does GetOldestEventLogRecord work with backup eventlogs? */
273 ret
= GetOldestEventLogRecord(handle
, &oldest
);
276 ok(ret
, "Expected success\n");
277 ok(oldest
!= 0xdeadbeef, "Expected the number of the oldest record\n");
280 CloseEventLog(handle
);
284 static void test_backup(void)
288 const char backup
[] = "backup.evt";
289 const char backup2
[] = "backup2.evt";
291 SetLastError(0xdeadbeef);
292 ret
= BackupEventLogA(NULL
, NULL
);
293 ok(!ret
, "Expected failure\n");
294 ok(GetLastError() == ERROR_INVALID_PARAMETER
, "Expected ERROR_INVALID_PARAMETER, got %d\n", GetLastError());
296 SetLastError(0xdeadbeef);
297 ret
= BackupEventLogA(NULL
, backup
);
298 ok(!ret
, "Expected failure\n");
299 ok(GetFileAttributesA(backup
) == INVALID_FILE_ATTRIBUTES
, "Expected no backup file\n");
301 handle
= OpenEventLogA(NULL
, "Application");
303 SetLastError(0xdeadbeef);
304 ret
= BackupEventLogA(handle
, NULL
);
305 ok(!ret
, "Expected failure\n");
306 ok(GetLastError() == ERROR_INVALID_PARAMETER
, "Expected ERROR_INVALID_PARAMETER, got %d\n", GetLastError());
308 ret
= BackupEventLogA(handle
, backup
);
309 ok(ret
, "Expected success\n");
311 ok(GetFileAttributesA(backup
) != INVALID_FILE_ATTRIBUTES
, "Expected a backup file\n");
313 /* Try to overwrite */
314 SetLastError(0xdeadbeef);
315 ret
= BackupEventLogA(handle
, backup
);
318 ok(!ret
, "Expected failure\n");
319 ok(GetLastError() == ERROR_ALREADY_EXISTS
, "Expected ERROR_ALREADY_EXISTS, got %d\n", GetLastError());
322 CloseEventLog(handle
);
324 /* Can we make a backup of a backup? */
325 handle
= OpenBackupEventLogA(NULL
, backup
);
327 ok(handle
!= NULL
, "Expected a handle\n");
329 ret
= BackupEventLogA(handle
, backup2
);
332 ok(ret
, "Expected success\n");
333 ok(GetFileAttributesA(backup2
) != INVALID_FILE_ATTRIBUTES
, "Expected a backup file\n");
336 CloseEventLog(handle
);
338 DeleteFileA(backup2
);
341 static void test_read(void)
345 DWORD count
, toread
, read
, needed
;
348 SetLastError(0xdeadbeef);
349 ret
= ReadEventLogA(NULL
, 0, 0, NULL
, 0, NULL
, NULL
);
350 ok(!ret
, "Expected failure\n");
352 ok(GetLastError() == ERROR_INVALID_PARAMETER
, "Expected ERROR_INVALID_PARAMETER, got %d\n", GetLastError());
355 SetLastError(0xdeadbeef);
356 ret
= ReadEventLogA(NULL
, 0, 0, NULL
, 0, &read
, NULL
);
357 ok(!ret
, "Expected failure\n");
358 ok(read
== 0xdeadbeef, "Expected 'read' parameter to remain unchanged\n");
360 ok(GetLastError() == ERROR_INVALID_PARAMETER
, "Expected ERROR_INVALID_PARAMETER, got %d\n", GetLastError());
363 SetLastError(0xdeadbeef);
364 ret
= ReadEventLogA(NULL
, 0, 0, NULL
, 0, NULL
, &needed
);
365 ok(!ret
, "Expected failure\n");
366 ok(needed
== 0xdeadbeef, "Expected 'needed' parameter to remain unchanged\n");
368 ok(GetLastError() == ERROR_INVALID_PARAMETER
, "Expected ERROR_INVALID_PARAMETER, got %d\n", GetLastError());
370 /* 'read' and 'needed' are only filled when the needed buffer size is passed back or when the call succeeds */
371 SetLastError(0xdeadbeef);
372 ret
= ReadEventLogA(NULL
, 0, 0, NULL
, 0, &read
, &needed
);
373 ok(!ret
, "Expected failure\n");
375 ok(GetLastError() == ERROR_INVALID_PARAMETER
, "Expected ERROR_INVALID_PARAMETER, got %d\n", GetLastError());
377 SetLastError(0xdeadbeef);
378 ret
= ReadEventLogA(NULL
, EVENTLOG_SEQUENTIAL_READ
| EVENTLOG_FORWARDS_READ
, 0, NULL
, 0, NULL
, NULL
);
379 ok(!ret
, "Expected failure\n");
381 ok(GetLastError() == ERROR_INVALID_PARAMETER
, "Expected ERROR_INVALID_PARAMETER, got %d\n", GetLastError());
383 SetLastError(0xdeadbeef);
384 ret
= ReadEventLogA(NULL
, EVENTLOG_SEQUENTIAL_READ
| EVENTLOG_FORWARDS_READ
, 0, NULL
, 0, &read
, &needed
);
385 ok(!ret
, "Expected failure\n");
387 ok(GetLastError() == ERROR_INVALID_PARAMETER
, "Expected ERROR_INVALID_PARAMETER, got %d\n", GetLastError());
390 SetLastError(0xdeadbeef);
391 ret
= ReadEventLogA(NULL
, EVENTLOG_SEQUENTIAL_READ
| EVENTLOG_FORWARDS_READ
,
392 0, buf
, sizeof(EVENTLOGRECORD
), &read
, &needed
);
393 ok(!ret
, "Expected failure\n");
395 ok(GetLastError() == ERROR_INVALID_PARAMETER
, "Expected ERROR_INVALID_PARAMETER, got %d\n", GetLastError());
397 buf
= HeapAlloc(GetProcessHeap(), 0, sizeof(EVENTLOGRECORD
));
398 SetLastError(0xdeadbeef);
399 ret
= ReadEventLogA(NULL
, EVENTLOG_SEQUENTIAL_READ
| EVENTLOG_FORWARDS_READ
,
400 0, buf
, sizeof(EVENTLOGRECORD
), &read
, &needed
);
401 ok(!ret
, "Expected failure\n");
403 ok(GetLastError() == ERROR_INVALID_HANDLE
, "Expected ERROR_INVALID_HANDLE, got %d\n", GetLastError());
404 HeapFree(GetProcessHeap(), 0, buf
);
406 handle
= OpenEventLogA(NULL
, "Application");
408 /* Show that we need the proper dwFlags with a (for the rest) proper call */
409 buf
= HeapAlloc(GetProcessHeap(), 0, sizeof(EVENTLOGRECORD
));
411 SetLastError(0xdeadbeef);
412 ret
= ReadEventLogA(handle
, 0, 0, buf
, sizeof(EVENTLOGRECORD
), &read
, &needed
);
413 ok(!ret
, "Expected failure\n");
415 ok(GetLastError() == ERROR_INVALID_PARAMETER
, "Expected ERROR_INVALID_PARAMETER, got %d\n", GetLastError());
417 SetLastError(0xdeadbeef);
418 ret
= ReadEventLogA(handle
, EVENTLOG_SEQUENTIAL_READ
, 0, buf
, sizeof(EVENTLOGRECORD
), &read
, &needed
);
419 ok(!ret
, "Expected failure\n");
421 ok(GetLastError() == ERROR_INVALID_PARAMETER
, "Expected ERROR_INVALID_PARAMETER, got %d\n", GetLastError());
423 SetLastError(0xdeadbeef);
424 ret
= ReadEventLogA(handle
, EVENTLOG_SEEK_READ
, 0, buf
, sizeof(EVENTLOGRECORD
), &read
, &needed
);
425 ok(!ret
, "Expected failure\n");
427 ok(GetLastError() == ERROR_INVALID_PARAMETER
, "Expected ERROR_INVALID_PARAMETER, got %d\n", GetLastError());
429 SetLastError(0xdeadbeef);
430 ret
= ReadEventLogA(handle
, EVENTLOG_SEQUENTIAL_READ
| EVENTLOG_FORWARDS_READ
| EVENTLOG_BACKWARDS_READ
,
431 0, buf
, sizeof(EVENTLOGRECORD
), &read
, &needed
);
432 ok(!ret
, "Expected failure\n");
434 ok(GetLastError() == ERROR_INVALID_PARAMETER
, "Expected ERROR_INVALID_PARAMETER, got %d\n", GetLastError());
436 SetLastError(0xdeadbeef);
437 ret
= ReadEventLogA(handle
, EVENTLOG_SEEK_READ
| EVENTLOG_FORWARDS_READ
| EVENTLOG_BACKWARDS_READ
,
438 0, buf
, sizeof(EVENTLOGRECORD
), &read
, &needed
);
439 ok(!ret
, "Expected failure\n");
441 ok(GetLastError() == ERROR_INVALID_PARAMETER
, "Expected ERROR_INVALID_PARAMETER, got %d\n", GetLastError());
443 SetLastError(0xdeadbeef);
444 ret
= ReadEventLogA(handle
, EVENTLOG_SEEK_READ
| EVENTLOG_SEQUENTIAL_READ
| EVENTLOG_FORWARDS_READ
,
445 0, buf
, sizeof(EVENTLOGRECORD
), &read
, &needed
);
446 ok(!ret
, "Expected failure\n");
448 ok(GetLastError() == ERROR_INVALID_PARAMETER
, "Expected ERROR_INVALID_PARAMETER, got %d\n", GetLastError());
450 HeapFree(GetProcessHeap(), 0, buf
);
452 /* First check if there are any records (in practice only on Wine: FIXME) */
454 GetNumberOfEventLogRecords(handle
, &count
);
457 skip("No records in the 'Application' log\n");
458 CloseEventLog(handle
);
462 /* Get the buffer size for the first record */
463 buf
= HeapAlloc(GetProcessHeap(), 0, sizeof(EVENTLOGRECORD
));
464 read
= needed
= 0xdeadbeef;
465 SetLastError(0xdeadbeef);
466 ret
= ReadEventLogA(handle
, EVENTLOG_SEQUENTIAL_READ
| EVENTLOG_FORWARDS_READ
,
467 0, buf
, sizeof(EVENTLOGRECORD
), &read
, &needed
);
468 ok(!ret
, "Expected failure\n");
469 ok(read
== 0, "Expected no bytes read\n");
470 ok(needed
> sizeof(EVENTLOGRECORD
), "Expected the needed buffersize to be bigger than sizeof(EVENTLOGRECORD)\n");
471 ok(GetLastError() == ERROR_INSUFFICIENT_BUFFER
, "Expected ERROR_INVALID_PARAMETER, got %d\n", GetLastError());
473 /* Read the first record */
475 buf
= HeapReAlloc(GetProcessHeap(), 0, buf
, toread
);
476 read
= needed
= 0xdeadbeef;
477 SetLastError(0xdeadbeef);
478 ret
= ReadEventLogA(handle
, EVENTLOG_SEQUENTIAL_READ
| EVENTLOG_FORWARDS_READ
, 0, buf
, toread
, &read
, &needed
);
479 ok(ret
, "Expected success\n");
481 broken(read
< toread
), /* NT4 wants a buffer size way bigger than just 1 record */
482 "Expected the requested size to be read\n");
483 ok(needed
== 0, "Expected no extra bytes to be read\n");
484 HeapFree(GetProcessHeap(), 0, buf
);
486 CloseEventLog(handle
);
489 static void test_openbackup(void)
491 HANDLE handle
, handle2
, file
;
493 const char backup
[] = "backup.evt";
494 const char text
[] = "Just some text";
496 SetLastError(0xdeadbeef);
497 handle
= OpenBackupEventLogA(NULL
, NULL
);
498 ok(handle
== NULL
, "Didn't expect a handle\n");
499 ok(GetLastError() == ERROR_INVALID_PARAMETER
, "Expected ERROR_INVALID_PARAMETER, got %d\n", GetLastError());
501 SetLastError(0xdeadbeef);
502 handle
= OpenBackupEventLogA(NULL
, "idontexist.evt");
503 ok(handle
== NULL
, "Didn't expect a handle\n");
504 ok(GetLastError() == ERROR_FILE_NOT_FOUND
, "Expected ERROR_FILE_NOT_FOUND, got %d\n", GetLastError());
506 SetLastError(0xdeadbeef);
507 handle
= OpenBackupEventLogA("IDontExist", NULL
);
508 ok(handle
== NULL
, "Didn't expect a handle\n");
509 ok(GetLastError() == ERROR_INVALID_PARAMETER
, "Expected ERROR_INVALID_PARAMETER, got %d\n", GetLastError());
511 SetLastError(0xdeadbeef);
512 handle
= OpenBackupEventLogA("IDontExist", "idontexist.evt");
513 ok(handle
== NULL
, "Didn't expect a handle\n");
514 ok(GetLastError() == RPC_S_SERVER_UNAVAILABLE
||
515 GetLastError() == RPC_S_INVALID_NET_ADDR
, /* Some Vista and Win7 */
516 "Expected RPC_S_SERVER_UNAVAILABLE, got %d\n", GetLastError());
518 /* Make a backup eventlog to work with */
519 create_backup(backup
);
521 /* FIXME: Wine stops here */
522 if (GetFileAttributesA(backup
) == INVALID_FILE_ATTRIBUTES
)
524 skip("We don't have a backup eventlog to work with\n");
528 SetLastError(0xdeadbeef);
529 handle
= OpenBackupEventLogA("IDontExist", backup
);
530 ok(handle
== NULL
, "Didn't expect a handle\n");
531 ok(GetLastError() == RPC_S_SERVER_UNAVAILABLE
||
532 GetLastError() == RPC_S_INVALID_NET_ADDR
, /* Some Vista and Win7 */
533 "Expected RPC_S_SERVER_UNAVAILABLE, got %d\n", GetLastError());
535 /* Empty servername should be read as local server */
536 handle
= OpenBackupEventLogA("", backup
);
537 ok(handle
!= NULL
, "Expected a handle\n");
538 CloseEventLog(handle
);
540 handle
= OpenBackupEventLogA(NULL
, backup
);
541 ok(handle
!= NULL
, "Expected a handle\n");
543 /* Can we open that same backup eventlog more than once? */
544 handle2
= OpenBackupEventLogA(NULL
, backup
);
545 ok(handle2
!= NULL
, "Expected a handle\n");
546 ok(handle2
!= handle
, "Didn't expect the same handle\n");
547 CloseEventLog(handle2
);
549 CloseEventLog(handle
);
552 /* Is there any content checking done? */
553 file
= CreateFileA(backup
, GENERIC_WRITE
, 0, NULL
, CREATE_NEW
, 0, NULL
);
555 SetLastError(0xdeadbeef);
556 handle
= OpenBackupEventLogA(NULL
, backup
);
557 ok(handle
== NULL
, "Didn't expect a handle\n");
558 ok(GetLastError() == ERROR_NOT_ENOUGH_MEMORY
||
559 GetLastError() == ERROR_EVENTLOG_FILE_CORRUPT
, /* Vista and Win7 */
560 "Expected ERROR_NOT_ENOUGH_MEMORY, got %d\n", GetLastError());
561 CloseEventLog(handle
);
564 file
= CreateFileA(backup
, GENERIC_WRITE
, 0, NULL
, CREATE_NEW
, 0, NULL
);
565 WriteFile(file
, text
, sizeof(text
), &written
, NULL
);
567 SetLastError(0xdeadbeef);
568 handle
= OpenBackupEventLogA(NULL
, backup
);
569 ok(handle
== NULL
, "Didn't expect a handle\n");
570 ok(GetLastError() == ERROR_EVENTLOG_FILE_CORRUPT
, "Expected ERROR_EVENTLOG_FILE_CORRUPT, got %d\n", GetLastError());
571 CloseEventLog(handle
);
575 static void test_clear(void)
579 const char backup
[] = "backup.evt";
580 const char backup2
[] = "backup2.evt";
582 SetLastError(0xdeadbeef);
583 ret
= ClearEventLogA(NULL
, NULL
);
584 ok(!ret
, "Expected failure\n");
585 ok(GetLastError() == ERROR_INVALID_HANDLE
, "Expected ERROR_INVALID_HANDLE, got %d\n", GetLastError());
587 /* Make a backup eventlog to work with */
588 create_backup(backup
);
590 SetLastError(0xdeadbeef);
591 ret
= ClearEventLogA(NULL
, backup
);
592 ok(!ret
, "Expected failure\n");
593 ok(GetLastError() == ERROR_INVALID_HANDLE
, "Expected ERROR_INVALID_HANDLE, got %d\n", GetLastError());
595 handle
= OpenBackupEventLogA(NULL
, backup
);
597 ok(handle
!= NULL
, "Expected a handle\n");
599 /* A real eventlog would fail with ERROR_ALREADY_EXISTS */
600 SetLastError(0xdeadbeef);
601 ret
= ClearEventLogA(handle
, backup
);
602 ok(!ret
, "Expected failure\n");
603 /* The eventlog service runs under an account that doesn't have the necessary
604 * permissions on the users home directory on a default Vista+ system.
606 ok(GetLastError() == ERROR_INVALID_HANDLE
||
607 GetLastError() == ERROR_ACCESS_DENIED
, /* Vista+ */
608 "Expected ERROR_INVALID_HANDLE, got %d\n", GetLastError());
610 /* Show that ClearEventLog only works for real eventlogs. */
611 SetLastError(0xdeadbeef);
612 ret
= ClearEventLogA(handle
, backup2
);
613 ok(!ret
, "Expected failure\n");
614 ok(GetLastError() == ERROR_INVALID_HANDLE
, "Expected ERROR_INVALID_HANDLE, got %d\n", GetLastError());
615 ok(GetFileAttributesA(backup2
) == INVALID_FILE_ATTRIBUTES
, "Expected no backup file\n");
617 SetLastError(0xdeadbeef);
618 ret
= ClearEventLogA(handle
, NULL
);
619 ok(!ret
, "Expected failure\n");
620 ok(GetLastError() == ERROR_INVALID_HANDLE
, "Expected ERROR_INVALID_HANDLE, got %d\n", GetLastError());
622 CloseEventLog(handle
);
624 ok(DeleteFileA(backup
), "Could not delete the backup file\n");
627 static const char eventlogsvc
[] = "SYSTEM\\CurrentControlSet\\Services\\Eventlog";
628 static const char eventlogname
[] = "Wine";
629 static const char eventsources
[][11] = { "WineSrc", "WineSrc1", "WineSrc20", "WineSrc300" };
631 static BOOL
create_new_eventlog(void)
638 /* First create our eventlog */
639 lret
= RegOpenKeyA(HKEY_LOCAL_MACHINE
, eventlogsvc
, &key
);
640 if (lret
!= ERROR_SUCCESS
)
642 skip("Could not open the EventLog service registry key\n");
645 lret
= RegCreateKeyA(key
, eventlogname
, &eventkey
);
646 if (lret
!= ERROR_SUCCESS
)
648 skip("Could not create the eventlog '%s' registry key\n", eventlogname
);
652 /* Create some event sources, the registry value 'Sources' is updated automatically */
653 for (i
= 0; i
< sizeof(eventsources
)/sizeof(eventsources
[0]); i
++)
657 lret
= RegCreateKeyA(eventkey
, eventsources
[i
], &srckey
);
658 if (lret
!= ERROR_SUCCESS
)
660 skip("Could not create the eventsource '%s' registry key\n", eventsources
[i
]);
669 /* The flushing of the registry (here and above) gives us some assurance
670 * that we are not to quickly writing events as 'Sources' could still be
673 RegFlushKey(eventkey
);
675 RegCloseKey(eventkey
);
681 static const char *one_string
[] = { "First string" };
682 static const char *two_strings
[] = { "First string", "Second string" };
691 const char **evt_strings
;
694 { eventlogname
, EVENTLOG_INFORMATION_TYPE
, 1, 1, FALSE
, 1, one_string
},
695 { eventsources
[0], EVENTLOG_WARNING_TYPE
, 1, 2, FALSE
, 0, NULL
},
696 { eventsources
[1], EVENTLOG_AUDIT_FAILURE
, 1, 3, FALSE
, 2, two_strings
},
697 { eventsources
[2], EVENTLOG_ERROR_TYPE
, 1, 4, FALSE
, 0, NULL
},
698 { eventsources
[3], EVENTLOG_WARNING_TYPE
, 1, 5, FALSE
, 1, one_string
},
699 { eventlogname
, EVENTLOG_SUCCESS
, 2, 6, TRUE
, 2, two_strings
},
700 { eventsources
[0], EVENTLOG_AUDIT_FAILURE
, 2, 7, TRUE
, 0, NULL
},
701 { eventsources
[1], EVENTLOG_AUDIT_SUCCESS
, 2, 8, TRUE
, 2, two_strings
},
702 { eventsources
[2], EVENTLOG_WARNING_TYPE
, 2, 9, TRUE
, 0, NULL
},
703 { eventsources
[3], EVENTLOG_ERROR_TYPE
, 2, 10, TRUE
, 1, one_string
}
706 static void test_readwrite(void)
710 DWORD sidsize
, count
;
711 BOOL ret
, sidavailable
;
712 BOOL on_vista
= FALSE
; /* Used to indicate Vista, W2K8 or Win7 */
714 char *localcomputer
= NULL
;
717 if (pCreateWellKnownSid
)
719 sidsize
= SECURITY_MAX_SID_SIZE
;
720 user
= HeapAlloc(GetProcessHeap(), 0, sidsize
);
721 SetLastError(0xdeadbeef);
722 pCreateWellKnownSid(WinInteractiveSid
, NULL
, user
, &sidsize
);
727 win_skip("Skipping some SID related tests\n");
728 sidavailable
= FALSE
;
732 /* Write an event with an incorrect event type. This will fail on Windows 7
733 * but succeed on all others, hence it's not part of the struct.
735 handle
= OpenEventLogA(NULL
, eventlogname
);
738 /* Intermittently seen on NT4 when tests are run immediately after boot */
739 win_skip("Could not get a handle to the eventlog\n");
744 GetNumberOfEventLogRecords(handle
, &count
);
747 /* Needed for W2K3 without a service pack */
748 win_skip("We most likely opened the Application eventlog\n");
749 CloseEventLog(handle
);
752 handle
= OpenEventLogA(NULL
, eventlogname
);
754 GetNumberOfEventLogRecords(handle
, &count
);
757 win_skip("We didn't open our new eventlog\n");
758 CloseEventLog(handle
);
763 SetLastError(0xdeadbeef);
764 ret
= ReportEvent(handle
, 0x20, 0, 0, NULL
, 0, 0, NULL
, NULL
);
765 if (!ret
&& GetLastError() == ERROR_CRC
)
767 win_skip("Win7 fails when using incorrect event types\n");
768 ret
= ReportEvent(handle
, 0, 0, 0, NULL
, 0, 0, NULL
, NULL
);
769 ok(ret
, "Expected success : %d\n", GetLastError());
774 DWORD read
, needed
= 0;
775 EVENTLOGRECORD
*record
;
777 ok(ret
, "Expected success : %d\n", GetLastError());
779 /* Needed to catch earlier Vista (with no ServicePack for example) */
780 buf
= HeapAlloc(GetProcessHeap(), 0, sizeof(EVENTLOGRECORD
));
781 if (!(ret
= ReadEventLogA(handle
, EVENTLOG_SEQUENTIAL_READ
| EVENTLOG_FORWARDS_READ
,
782 0, buf
, sizeof(EVENTLOGRECORD
), &read
, &needed
)) &&
783 GetLastError() == ERROR_INSUFFICIENT_BUFFER
)
785 buf
= HeapReAlloc(GetProcessHeap(), 0, buf
, needed
);
786 ret
= ReadEventLogA(handle
, EVENTLOG_SEQUENTIAL_READ
| EVENTLOG_FORWARDS_READ
,
787 0, buf
, needed
, &read
, &needed
);
791 record
= (EVENTLOGRECORD
*)buf
;
793 /* Vista and W2K8 return EVENTLOG_SUCCESS, Windows versions before return
794 * the written eventtype (0x20 in this case).
796 if (record
->EventType
== EVENTLOG_SUCCESS
)
799 HeapFree(GetProcessHeap(), 0, buf
);
802 /* This will clear the eventlog. The record numbering for new
803 * events however differs on Vista SP1+. Before Vista the first
804 * event would be numbered 1, on Vista SP1+ it's higher as we already
805 * had at least one event (more in case of multiple test runs without
808 ClearEventLogA(handle
, NULL
);
809 CloseEventLog(handle
);
811 /* Write a bunch of events while using different event sources */
812 for (i
= 0; i
< sizeof(read_write
)/sizeof(read_write
[0]); i
++)
815 BOOL run_sidtests
= read_write
[i
].evt_sid
& sidavailable
;
817 /* We don't need to use RegisterEventSource to report events */
819 handle
= OpenEventLogA(NULL
, read_write
[i
].evt_src
);
821 handle
= RegisterEventSourceA(NULL
, read_write
[i
].evt_src
);
822 ok(handle
!= NULL
, "Expected a handle\n");
824 SetLastError(0xdeadbeef);
825 ret
= ReportEvent(handle
, read_write
[i
].evt_type
, read_write
[i
].evt_cat
,
826 read_write
[i
].evt_id
, run_sidtests
? user
: NULL
,
827 read_write
[i
].evt_numstrings
, 0, read_write
[i
].evt_strings
, NULL
);
828 ok(ret
, "Expected ReportEvent success : %d\n", GetLastError());
831 SetLastError(0xdeadbeef);
832 ret
= GetNumberOfEventLogRecords(handle
, &count
);
833 ok(ret
, "Expected GetNumberOfEventLogRecords success : %d\n", GetLastError());
835 ok(count
== (i
+ 1), "Expected %d records, got %d\n", i
+ 1, count
);
838 ret
= GetOldestEventLogRecord(handle
, &oldest
);
839 ok(ret
, "Expected GetOldestEventLogRecord success : %d\n", GetLastError());
842 (oldest
> 1 && oldest
!= 0xdeadbeef), /* Vista SP1+, W2K8 and Win7 */
843 "Expected oldest to be 1 or higher, got %d\n", oldest
);
844 if (oldest
> 1 && oldest
!= 0xdeadbeef)
847 SetLastError(0xdeadbeef);
849 ret
= CloseEventLog(handle
);
851 ret
= DeregisterEventSource(handle
);
852 ok(ret
, "Expected success : %d\n", GetLastError());
855 handle
= OpenEventLogA(NULL
, eventlogname
);
857 ret
= GetNumberOfEventLogRecords(handle
, &count
);
858 ok(ret
, "Expected success\n");
860 ok(count
== i
, "Expected %d records, got %d\n", i
, count
);
861 CloseEventLog(handle
);
865 skip("No events were written to the eventlog\n");
869 /* Report only once */
871 skip("There is no DWORD alignment enforced for UserSid on Vista, W2K8 or Win7\n");
873 if (on_vista
&& pGetComputerNameExA
)
875 /* New Vista+ behavior */
877 SetLastError(0xdeadbeef);
878 pGetComputerNameExA(ComputerNameDnsFullyQualified
, NULL
, &size
);
879 localcomputer
= HeapAlloc(GetProcessHeap(), 0, size
);
880 pGetComputerNameExA(ComputerNameDnsFullyQualified
, localcomputer
, &size
);
884 size
= MAX_COMPUTERNAME_LENGTH
+ 1;
885 localcomputer
= HeapAlloc(GetProcessHeap(), 0, size
);
886 GetComputerNameA(localcomputer
, &size
);
889 /* Read all events from our created eventlog, one by one */
890 handle
= OpenEventLogA(NULL
, eventlogname
);
896 EVENTLOGRECORD
*record
;
897 char *sourcename
, *computername
;
900 BOOL run_sidtests
= read_write
[i
].evt_sid
& sidavailable
;
902 buf
= HeapAlloc(GetProcessHeap(), 0, sizeof(EVENTLOGRECORD
));
903 SetLastError(0xdeadbeef);
904 ret
= ReadEventLogA(handle
, EVENTLOG_SEQUENTIAL_READ
| EVENTLOG_FORWARDS_READ
,
905 0, buf
, sizeof(EVENTLOGRECORD
), &read
, &needed
);
906 if (!ret
&& GetLastError() == ERROR_HANDLE_EOF
)
908 HeapFree(GetProcessHeap(), 0, buf
);
911 ok(!ret
, "Expected failure\n");
912 ok(GetLastError() == ERROR_INSUFFICIENT_BUFFER
,
913 "Expected ERROR_INVALID_PARAMETER, got %d\n",GetLastError());
915 buf
= HeapReAlloc(GetProcessHeap(), 0, buf
, needed
);
916 ret
= ReadEventLogA(handle
, EVENTLOG_SEQUENTIAL_READ
| EVENTLOG_FORWARDS_READ
,
917 0, buf
, needed
, &read
, &needed
);
918 ok(ret
, "Expected success: %d\n", GetLastError());
920 record
= (EVENTLOGRECORD
*)buf
;
922 ok(record
->Length
== read
,
923 "Expected %d, got %d\n", read
, record
->Length
);
924 ok(record
->Reserved
== 0x654c664c,
925 "Expected 0x654c664c, got %d\n", record
->Reserved
);
926 ok(record
->RecordNumber
== i
+ 1 ||
927 (on_vista
&& (record
->RecordNumber
> i
+ 1)),
928 "Expected %d or higher, got %d\n", i
+ 1, record
->RecordNumber
);
929 ok(record
->EventID
== read_write
[i
].evt_id
,
930 "Expected %d, got %d\n", read_write
[i
].evt_id
, record
->EventID
);
931 ok(record
->EventType
== read_write
[i
].evt_type
,
932 "Expected %d, got %d\n", read_write
[i
].evt_type
, record
->EventType
);
933 ok(record
->NumStrings
== read_write
[i
].evt_numstrings
,
934 "Expected %d, got %d\n", read_write
[i
].evt_numstrings
, record
->NumStrings
);
935 ok(record
->EventCategory
== read_write
[i
].evt_cat
,
936 "Expected %d, got %d\n", read_write
[i
].evt_cat
, record
->EventCategory
);
938 sourcename
= (char *)((BYTE
*)buf
+ sizeof(EVENTLOGRECORD
));
939 ok(!lstrcmpA(sourcename
, read_write
[i
].evt_src
), "Expected '%s', got '%s'\n",
940 read_write
[i
].evt_src
, sourcename
);
942 computername
= (char *)((BYTE
*)buf
+ sizeof(EVENTLOGRECORD
) + lstrlenA(sourcename
) + 1);
943 ok(!lstrcmpiA(computername
, localcomputer
), "Expected '%s', got '%s'\n",
944 localcomputer
, computername
);
946 /* Before Vista, UserSid was aligned on a DWORD boundary. Next to that if
947 * no padding was actually required a 0 DWORD was still used for padding. No
948 * application should be relying on the padding as we are working with offsets
954 DWORD calculated_sidoffset
= sizeof(EVENTLOGRECORD
) + lstrlenA(sourcename
) + 1 + lstrlenA(computername
) + 1;
956 /* We are already DWORD aligned, there should still be some padding */
957 if ((((UINT_PTR
)buf
+ calculated_sidoffset
) % sizeof(DWORD
)) == 0)
958 ok(*(DWORD
*)((BYTE
*)buf
+ calculated_sidoffset
) == 0, "Expected 0\n");
960 ok((((UINT_PTR
)buf
+ record
->UserSidOffset
) % sizeof(DWORD
)) == 0, "Expected DWORD alignment\n");
965 ok(record
->UserSidLength
== sidsize
, "Expected %d, got %d\n", sidsize
, record
->UserSidLength
);
969 ok(record
->StringOffset
== record
->UserSidOffset
, "Expected offsets to be the same\n");
970 ok(record
->UserSidLength
== 0, "Expected 0, got %d\n", record
->UserSidLength
);
973 ok(record
->DataLength
== 0, "Expected 0, got %d\n", record
->DataLength
);
975 ptr
= (char *)((BYTE
*)buf
+ record
->StringOffset
);
976 for (k
= 0; k
< record
->NumStrings
; k
++)
978 ok(!lstrcmpA(ptr
, two_strings
[k
]), "Expected '%s', got '%s'\n", two_strings
[k
], ptr
);
979 ptr
+= lstrlenA(ptr
) + 1;
982 ok(record
->Length
== *(DWORD
*)((BYTE
*)buf
+ record
->Length
- sizeof(DWORD
)),
983 "Expected the closing DWORD to contain the length of the record\n");
985 HeapFree(GetProcessHeap(), 0, buf
);
988 CloseEventLog(handle
);
990 /* Test clearing a real eventlog */
991 handle
= OpenEventLogA(NULL
, eventlogname
);
993 SetLastError(0xdeadbeef);
994 ret
= ClearEventLogA(handle
, NULL
);
995 ok(ret
, "Expected success\n");
998 ret
= GetNumberOfEventLogRecords(handle
, &count
);
999 ok(ret
, "Expected success\n");
1000 ok(count
== 0, "Expected an empty eventlog, got %d records\n", count
);
1002 CloseEventLog(handle
);
1005 HeapFree(GetProcessHeap(), 0, localcomputer
);
1006 HeapFree(GetProcessHeap(), 0, user
);
1011 * Creating an eventlog on Windows (via the registry) automatically leads
1012 * to creation of a REG_MULTI_SZ named 'Sources'. This value lists all the
1013 * potential event sources for this eventlog. 'Sources' is automatically
1014 * updated when a new key (aka event source) is created.
1016 * Although the updating of registry keys is almost instantaneously, we
1017 * check it after some other tests to assure we are not querying the
1018 * registry or file system to quickly.
1022 * The eventlog file itself is also automatically created, even before we
1023 * start writing events.
1025 static char eventlogfile
[MAX_PATH
];
1026 static void test_autocreation(void)
1033 char sources
[sizeof(eventsources
)];
1034 char sysdir
[MAX_PATH
];
1037 RegOpenKeyA(HKEY_LOCAL_MACHINE
, eventlogsvc
, &key
);
1038 RegOpenKeyA(key
, eventlogname
, &eventkey
);
1040 size
= sizeof(sources
);
1042 ret
= RegQueryValueExA(eventkey
, "Sources", NULL
, &type
, (LPBYTE
)sources
, &size
);
1043 if (ret
== ERROR_SUCCESS
)
1045 char sources_verify
[sizeof(eventsources
)];
1047 ok(type
== REG_MULTI_SZ
, "Expected a REG_MULTI_SZ, got %d\n", type
);
1049 /* Build the expected string */
1050 memset(sources_verify
, 0, sizeof(sources_verify
));
1052 for (i
= sizeof(eventsources
)/sizeof(eventsources
[0]); i
> 0; i
--)
1054 lstrcpyA(p
, eventsources
[i
- 1]);
1055 p
+= (lstrlenA(eventsources
[i
- 1]) + 1);
1057 lstrcpyA(p
, eventlogname
);
1059 ok(!memcmp(sources
, sources_verify
, size
),
1060 "Expected a correct 'Sources' value (size : %d)\n", size
);
1063 RegCloseKey(eventkey
);
1066 /* The directory that holds the eventlog files could be redirected */
1067 if (pWow64DisableWow64FsRedirection
)
1068 pWow64DisableWow64FsRedirection(&redir
);
1070 /* On Windows we also automatically get an eventlog file */
1071 GetSystemDirectoryA(sysdir
, sizeof(sysdir
));
1074 lstrcpyA(eventlogfile
, sysdir
);
1075 lstrcatA(eventlogfile
, "\\config\\");
1076 lstrcatA(eventlogfile
, eventlogname
);
1077 lstrcatA(eventlogfile
, ".evt");
1079 if (GetFileAttributesA(eventlogfile
) == INVALID_FILE_ATTRIBUTES
)
1082 lstrcpyA(eventlogfile
, sysdir
);
1083 lstrcatA(eventlogfile
, "\\winevt\\Logs\\");
1084 lstrcatA(eventlogfile
, eventlogname
);
1085 lstrcatA(eventlogfile
, ".evtx");
1089 ok(GetFileAttributesA(eventlogfile
) != INVALID_FILE_ATTRIBUTES
,
1090 "Expected an eventlog file\n");
1092 if (pWow64RevertWow64FsRedirection
)
1093 pWow64RevertWow64FsRedirection(redir
);
1096 static void cleanup_eventlog(void)
1102 char winesvc
[MAX_PATH
];
1104 /* Delete the registry tree */
1105 lstrcpyA(winesvc
, eventlogsvc
);
1106 lstrcatA(winesvc
, "\\");
1107 lstrcatA(winesvc
, eventlogname
);
1109 RegOpenKeyA(HKEY_LOCAL_MACHINE
, winesvc
, &key
);
1110 for (i
= 0; i
< sizeof(eventsources
)/sizeof(eventsources
[0]); i
++)
1111 RegDeleteKeyA(key
, eventsources
[i
]);
1112 RegDeleteValueA(key
, "Sources");
1114 lret
= RegDeleteKeyA(HKEY_LOCAL_MACHINE
, winesvc
);
1115 ok(lret
== ERROR_SUCCESS
, "Could not delete the registry tree : %d\n", lret
);
1117 /* A handle to the eventlog is locked by services.exe. We can only
1118 * delete the eventlog file after reboot.
1120 bret
= MoveFileExA(eventlogfile
, NULL
, MOVEFILE_DELAY_UNTIL_REBOOT
);
1121 ok(bret
, "Expected MoveFileEx to succeed: %d\n", GetLastError());
1124 START_TEST(eventlog
)
1126 SetLastError(0xdeadbeef);
1127 CloseEventLog(NULL
);
1128 if (GetLastError() == ERROR_CALL_NOT_IMPLEMENTED
)
1130 win_skip("Event log functions are not implemented\n");
1134 init_function_pointers();
1136 /* Parameters only */
1146 /* Functional tests */
1147 if (create_new_eventlog())
1150 test_autocreation();