2 * Unit test suite for Background Copy Job Interface
4 * Copyright 2007 Google (Roy Shea)
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
25 #include "wine/test.h"
28 /* Globals used by many tests */
29 static const WCHAR test_displayName
[] = {'T', 'e', 's', 't', 0};
30 static const WCHAR test_remoteNameA
[] = {'r','e','m','o','t','e','A', 0};
31 static const WCHAR test_remoteNameB
[] = {'r','e','m','o','t','e','B', 0};
32 static const WCHAR test_localNameA
[] = {'l','o','c','a','l','A', 0};
33 static const WCHAR test_localNameB
[] = {'l','o','c','a','l','B', 0};
34 static WCHAR
*test_currentDir
;
35 static WCHAR
*test_remotePathA
;
36 static WCHAR
*test_remotePathB
;
37 static WCHAR
*test_localPathA
;
38 static WCHAR
*test_localPathB
;
39 static IBackgroundCopyManager
*test_manager
;
40 static IBackgroundCopyJob
*test_job
;
41 static GUID test_jobId
;
42 static BG_JOB_TYPE test_type
;
44 static BOOL
init_paths(void)
46 static const WCHAR format
[] = {'%','s','\\','%','s', 0};
49 n
= GetCurrentDirectoryW(0, NULL
);
52 skip("Couldn't get current directory size\n");
56 test_currentDir
= HeapAlloc(GetProcessHeap(), 0, n
* sizeof(WCHAR
));
58 = HeapAlloc(GetProcessHeap(), 0,
59 (n
+ 1 + lstrlenW(test_localNameA
)) * sizeof(WCHAR
));
61 = HeapAlloc(GetProcessHeap(), 0,
62 (n
+ 1 + lstrlenW(test_localNameB
)) * sizeof(WCHAR
));
64 = HeapAlloc(GetProcessHeap(), 0,
65 (n
+ 1 + lstrlenW(test_remoteNameA
)) * sizeof(WCHAR
));
67 = HeapAlloc(GetProcessHeap(), 0,
68 (n
+ 1 + lstrlenW(test_remoteNameB
)) * sizeof(WCHAR
));
70 if (!test_currentDir
|| !test_localPathA
|| !test_localPathB
71 || !test_remotePathA
|| !test_remotePathB
)
73 skip("Couldn't allocate memory for full paths\n");
77 if (GetCurrentDirectoryW(n
, test_currentDir
) != n
- 1)
79 skip("Couldn't get current directory\n");
83 wsprintfW(test_localPathA
, format
, test_currentDir
, test_localNameA
);
84 wsprintfW(test_localPathB
, format
, test_currentDir
, test_localNameB
);
85 wsprintfW(test_remotePathA
, format
, test_currentDir
, test_remoteNameA
);
86 wsprintfW(test_remotePathB
, format
, test_currentDir
, test_remoteNameB
);
91 /* Generic test setup */
92 static BOOL
setup(void)
98 memset(&test_jobId
, 0, sizeof test_jobId
);
99 test_type
= BG_JOB_TYPE_DOWNLOAD
;
101 hres
= CoCreateInstance(&CLSID_BackgroundCopyManager
, NULL
,
103 &IID_IBackgroundCopyManager
,
104 (void **) &test_manager
);
108 hres
= IBackgroundCopyManager_CreateJob(test_manager
, test_displayName
,
109 test_type
, &test_jobId
, &test_job
);
112 IBackgroundCopyManager_Release(test_manager
);
119 /* Generic test cleanup */
120 static void teardown(void)
122 IBackgroundCopyJob_Release(test_job
);
123 IBackgroundCopyManager_Release(test_manager
);
126 /* Test that the jobId is properly set */
127 static void test_GetId(void)
132 hres
= IBackgroundCopyJob_GetId(test_job
, &tmpId
);
133 ok(hres
== S_OK
, "GetId failed: %08x\n", hres
);
136 skip("Unable to get ID of test_job.\n");
139 ok(memcmp(&tmpId
, &test_jobId
, sizeof tmpId
) == 0, "Got incorrect GUID\n");
142 /* Test that the type is properly set */
143 static void test_GetType(void)
148 hres
= IBackgroundCopyJob_GetType(test_job
, &type
);
149 ok(hres
== S_OK
, "GetType failed: %08x\n", hres
);
152 skip("Unable to get type of test_job.\n");
155 ok(type
== test_type
, "Got incorrect type\n");
158 /* Test that the display name is properly set */
159 static void test_GetName(void)
164 hres
= IBackgroundCopyJob_GetDisplayName(test_job
, &displayName
);
165 ok(hres
== S_OK
, "GetName failed: %08x\n", hres
);
168 skip("Unable to get display name of test_job.\n");
171 ok(lstrcmpW(displayName
, test_displayName
) == 0, "Got incorrect type\n");
172 CoTaskMemFree(displayName
);
175 /* Test adding a file */
176 static void test_AddFile(void)
180 hres
= IBackgroundCopyJob_AddFile(test_job
, test_remotePathA
,
182 ok(hres
== S_OK
, "First call to AddFile failed: 0x%08x\n", hres
);
185 skip("Unable to add first file to job\n");
189 hres
= IBackgroundCopyJob_AddFile(test_job
, test_remotePathB
,
191 ok(hres
== S_OK
, "Second call to AddFile failed: 0x%08x\n", hres
);
194 /* Test adding a set of files */
195 static void test_AddFileSet(void)
198 BG_FILE_INFO files
[2] =
200 {test_remotePathA
, test_localPathA
},
201 {test_remotePathB
, test_localPathB
}
203 hres
= IBackgroundCopyJob_AddFileSet(test_job
, 2, files
);
204 ok(hres
== S_OK
, "AddFileSet failed: 0x%08x\n", hres
);
207 /* Test creation of a job enumerator */
208 static void test_EnumFiles(void)
211 IEnumBackgroundCopyFiles
*enumFiles
;
214 hres
= IBackgroundCopyJob_AddFile(test_job
, test_remotePathA
,
218 skip("Unable to add file to job\n");
222 hres
= IBackgroundCopyJob_EnumFiles(test_job
, &enumFiles
);
223 ok(hres
== S_OK
, "EnumFiles failed: 0x%08x\n", hres
);
226 skip("Unable to create file enumerator.\n");
230 res
= IEnumBackgroundCopyFiles_Release(enumFiles
);
231 ok(res
== 0, "Bad ref count on release: %u\n", res
);
234 /* Test getting job progress */
235 static void test_GetProgress_preTransfer(void)
238 BG_JOB_PROGRESS progress
;
240 hres
= IBackgroundCopyJob_GetProgress(test_job
, &progress
);
241 ok(hres
== S_OK
, "GetProgress failed: 0x%08x\n", hres
);
244 skip("Unable to get job progress\n");
249 ok(progress
.BytesTotal
== 0, "Incorrect BytesTotal: %x%08x\n",
250 (DWORD
)(progress
.BytesTotal
>> 32), (DWORD
)progress
.BytesTotal
);
251 ok(progress
.BytesTransferred
== 0, "Incorrect BytesTransferred: %x%08x\n",
252 (DWORD
)(progress
.BytesTransferred
>> 32), (DWORD
)progress
.BytesTransferred
);
253 ok(progress
.FilesTotal
== 0, "Incorrect FilesTotal: %u\n", progress
.FilesTotal
);
254 ok(progress
.FilesTransferred
== 0, "Incorrect FilesTransferred %u\n", progress
.FilesTransferred
);
257 /* Test getting job state */
258 static void test_GetState(void)
263 state
= BG_JOB_STATE_ERROR
;
264 hres
= IBackgroundCopyJob_GetState(test_job
, &state
);
265 ok(hres
== S_OK
, "GetState failed: 0x%08x\n", hres
);
268 skip("Unable to get job state\n");
271 ok(state
== BG_JOB_STATE_SUSPENDED
, "Incorrect job state: %d\n", state
);
274 /* Test resuming a job */
275 static void test_ResumeEmpty(void)
280 hres
= IBackgroundCopyJob_Resume(test_job
);
281 ok(hres
== BG_E_EMPTY
, "Resume failed to return BG_E_EMPTY error: 0x%08x\n", hres
);
282 if (hres
!= BG_E_EMPTY
)
284 skip("Failed calling resume job\n");
288 state
= BG_JOB_STATE_ERROR
;
289 hres
= IBackgroundCopyJob_GetState(test_job
, &state
);
292 skip("Unable to get job state\n");
295 ok(state
== BG_JOB_STATE_SUSPENDED
, "Incorrect job state: %d\n", state
);
298 static void makeFile(WCHAR
*name
, const char *contents
)
301 DWORD w
, len
= strlen(contents
);
304 file
= CreateFileW(name
, GENERIC_WRITE
, 0, NULL
, CREATE_ALWAYS
,
305 FILE_ATTRIBUTE_NORMAL
, NULL
);
306 ok(file
!= INVALID_HANDLE_VALUE
, "CreateFile\n");
307 ok(WriteFile(file
, contents
, len
, &w
, NULL
), "WriteFile\n");
311 static void compareFiles(WCHAR
*n1
, WCHAR
*n2
)
318 f1
= CreateFileW(n1
, GENERIC_READ
, FILE_SHARE_READ
, NULL
, OPEN_EXISTING
,
319 FILE_ATTRIBUTE_NORMAL
, NULL
);
320 ok(f1
!= INVALID_HANDLE_VALUE
, "CreateFile\n");
322 f2
= CreateFileW(n2
, GENERIC_READ
, FILE_SHARE_READ
, NULL
, OPEN_EXISTING
,
323 FILE_ATTRIBUTE_NORMAL
, NULL
);
324 ok(f2
!= INVALID_HANDLE_VALUE
, "CreateFile\n");
326 /* Neither of these files is very big */
327 ok(ReadFile(f1
, b1
, sizeof b1
, &s1
, NULL
), "ReadFile\n");
328 ok(ReadFile(f2
, b2
, sizeof b2
, &s2
, NULL
), "ReadFile\n");
333 ok(s1
== s2
, "Files differ in length\n");
334 ok(memcmp(b1
, b2
, s1
) == 0, "Files differ in contents\n");
337 /* Test a complete transfer for local files */
338 static void test_CompleteLocal(void)
340 static const int timeout_sec
= 30;
345 DeleteFileW(test_localPathA
);
346 DeleteFileW(test_localPathB
);
347 makeFile(test_remotePathA
, "This is a WINE test file for BITS\n");
348 makeFile(test_remotePathB
, "This is another WINE test file for BITS\n");
350 hres
= IBackgroundCopyJob_AddFile(test_job
, test_remotePathA
,
354 skip("Unable to add file to job\n");
358 hres
= IBackgroundCopyJob_AddFile(test_job
, test_remotePathB
,
362 skip("Unable to add file to job\n");
366 hres
= IBackgroundCopyJob_Resume(test_job
);
367 ok(hres
== S_OK
, "IBackgroundCopyJob_Resume\n");
369 for (i
= 0; i
< timeout_sec
; ++i
)
371 hres
= IBackgroundCopyJob_GetState(test_job
, &state
);
372 ok(hres
== S_OK
, "IBackgroundCopyJob_GetState\n");
373 ok(state
== BG_JOB_STATE_QUEUED
|| state
== BG_JOB_STATE_CONNECTING
374 || state
== BG_JOB_STATE_TRANSFERRING
|| state
== BG_JOB_STATE_TRANSFERRED
,
375 "Bad state: %d\n", state
);
376 if (state
== BG_JOB_STATE_TRANSFERRED
)
381 ok(i
< timeout_sec
, "BITS jobs timed out\n");
382 hres
= IBackgroundCopyJob_Complete(test_job
);
383 ok(hres
== S_OK
, "IBackgroundCopyJob_Complete\n");
384 hres
= IBackgroundCopyJob_GetState(test_job
, &state
);
385 ok(hres
== S_OK
, "IBackgroundCopyJob_GetState\n");
386 ok(state
== BG_JOB_STATE_ACKNOWLEDGED
, "Bad state: %d\n", state
);
388 compareFiles(test_remotePathA
, test_localPathA
);
389 compareFiles(test_remotePathB
, test_localPathB
);
391 ok(DeleteFileW(test_remotePathA
), "DeleteFile\n");
392 ok(DeleteFileW(test_remotePathB
), "DeleteFile\n");
393 DeleteFileW(test_localPathA
);
394 DeleteFileW(test_localPathB
);
397 /* Test a complete transfer for local files */
398 static void test_CompleteLocalURL(void)
400 static const WCHAR prot
[] = {'f','i','l','e',':','/','/', 0};
401 static const int timeout_sec
= 30;
407 DeleteFileW(test_localPathA
);
408 DeleteFileW(test_localPathB
);
409 makeFile(test_remotePathA
, "This is a WINE test file for BITS\n");
410 makeFile(test_remotePathB
, "This is another WINE test file for BITS\n");
412 urlA
= HeapAlloc(GetProcessHeap(), 0,
413 (7 + lstrlenW(test_remotePathA
) + 1) * sizeof urlA
[0]);
414 urlB
= HeapAlloc(GetProcessHeap(), 0,
415 (7 + lstrlenW(test_remotePathB
) + 1) * sizeof urlB
[0]);
418 skip("Unable to allocate memory for URLs\n");
419 HeapFree(GetProcessHeap(), 0, urlA
);
420 HeapFree(GetProcessHeap(), 0, urlB
);
424 lstrcpyW(urlA
, prot
);
425 lstrcatW(urlA
, test_remotePathA
);
426 lstrcpyW(urlB
, prot
);
427 lstrcatW(urlB
, test_remotePathB
);
429 hres
= IBackgroundCopyJob_AddFile(test_job
, urlA
, test_localPathA
);
432 skip("Unable to add file to job\n");
433 HeapFree(GetProcessHeap(), 0, urlA
);
434 HeapFree(GetProcessHeap(), 0, urlB
);
438 hres
= IBackgroundCopyJob_AddFile(test_job
, urlB
, test_localPathB
);
441 skip("Unable to add file to job\n");
442 HeapFree(GetProcessHeap(), 0, urlA
);
443 HeapFree(GetProcessHeap(), 0, urlB
);
447 hres
= IBackgroundCopyJob_Resume(test_job
);
448 ok(hres
== S_OK
, "IBackgroundCopyJob_Resume\n");
450 for (i
= 0; i
< timeout_sec
; ++i
)
452 hres
= IBackgroundCopyJob_GetState(test_job
, &state
);
453 ok(hres
== S_OK
, "IBackgroundCopyJob_GetState\n");
454 ok(state
== BG_JOB_STATE_QUEUED
|| state
== BG_JOB_STATE_CONNECTING
455 || state
== BG_JOB_STATE_TRANSFERRING
|| state
== BG_JOB_STATE_TRANSFERRED
,
456 "Bad state: %d\n", state
);
457 if (state
== BG_JOB_STATE_TRANSFERRED
)
462 ok(i
< timeout_sec
, "BITS jobs timed out\n");
463 hres
= IBackgroundCopyJob_Complete(test_job
);
464 ok(hres
== S_OK
, "IBackgroundCopyJob_Complete\n");
465 hres
= IBackgroundCopyJob_GetState(test_job
, &state
);
466 ok(hres
== S_OK
, "IBackgroundCopyJob_GetState\n");
467 ok(state
== BG_JOB_STATE_ACKNOWLEDGED
, "Bad state: %d\n", state
);
469 compareFiles(test_remotePathA
, test_localPathA
);
470 compareFiles(test_remotePathB
, test_localPathB
);
472 ok(DeleteFileW(test_remotePathA
), "DeleteFile\n");
473 ok(DeleteFileW(test_remotePathB
), "DeleteFile\n");
474 DeleteFileW(test_localPathA
);
475 DeleteFileW(test_localPathB
);
477 HeapFree(GetProcessHeap(), 0, urlA
);
478 HeapFree(GetProcessHeap(), 0, urlB
);
481 typedef void (*test_t
)(void);
485 static const test_t tests
[] = {
492 test_GetProgress_preTransfer
,
496 test_CompleteLocalURL
,
505 for (test
= tests
; *test
; ++test
)
507 /* Keep state separate between tests. */
510 skip("Unable to setup test\n");