shell32/tests: Properly cleanup the created favorites shell folder.

This commit is contained in:
Alexandre Julliard 2008-11-14 11:18:34 +01:00
parent 43fae4e425
commit c22e49740a
1 changed files with 19 additions and 30 deletions

View File

@ -188,8 +188,7 @@ static void loadShell32(void)
{ {
shellVersion.cbSize = sizeof(shellVersion); shellVersion.cbSize = sizeof(shellVersion);
pDllGetVersion(&shellVersion); pDllGetVersion(&shellVersion);
if (winetest_interactive) trace("shell32 version is %d.%d\n",
printf("shell32 version is %d.%d\n",
shellVersion.dwMajorVersion, shellVersion.dwMinorVersion); shellVersion.dwMajorVersion, shellVersion.dwMinorVersion);
} }
#undef GET_PROC #undef GET_PROC
@ -730,7 +729,7 @@ static void testNonExistentPath1(void)
{ {
HRESULT hr; HRESULT hr;
LPITEMIDLIST pidl; LPITEMIDLIST pidl;
char path[MAX_PATH]; char *p, path[MAX_PATH];
/* test some failure cases first: */ /* test some failure cases first: */
hr = pSHGetFolderPathA(NULL, CSIDL_FAVORITES, NULL, hr = pSHGetFolderPathA(NULL, CSIDL_FAVORITES, NULL,
@ -740,16 +739,16 @@ static void testNonExistentPath1(void)
pidl = NULL; pidl = NULL;
hr = pSHGetFolderLocation(NULL, CSIDL_FAVORITES, NULL, 0, hr = pSHGetFolderLocation(NULL, CSIDL_FAVORITES, NULL, 0,
&pidl); &pidl);
ok(hr == E_FAIL, ok(hr == E_FAIL || hr == HRESULT_FROM_WIN32(ERROR_FILE_NOT_FOUND),
"SHGetFolderLocation returned 0x%08x, expected E_FAIL\n", hr); "SHGetFolderLocation returned 0x%08x\n", hr);
if (SUCCEEDED(hr) && pidl) if (SUCCEEDED(hr) && pidl)
IMalloc_Free(pMalloc, pidl); IMalloc_Free(pMalloc, pidl);
ok(!pSHGetSpecialFolderPathA(NULL, path, CSIDL_FAVORITES, FALSE), ok(!pSHGetSpecialFolderPathA(NULL, path, CSIDL_FAVORITES, FALSE),
"SHGetSpecialFolderPath succeeded, expected failure\n"); "SHGetSpecialFolderPath succeeded, expected failure\n");
pidl = NULL; pidl = NULL;
hr = pSHGetSpecialFolderLocation(NULL, CSIDL_FAVORITES, &pidl); hr = pSHGetSpecialFolderLocation(NULL, CSIDL_FAVORITES, &pidl);
ok(hr == E_FAIL, "SHGetFolderLocation returned 0x%08x, expected E_FAIL\n", ok(hr == E_FAIL || hr == HRESULT_FROM_WIN32(ERROR_FILE_NOT_FOUND),
hr); "SHGetFolderLocation returned 0x%08x\n", hr);
if (SUCCEEDED(hr) && pidl) if (SUCCEEDED(hr) && pidl)
IMalloc_Free(pMalloc, pidl); IMalloc_Free(pMalloc, pidl);
/* now test success: */ /* now test success: */
@ -759,8 +758,7 @@ static void testNonExistentPath1(void)
{ {
BOOL ret; BOOL ret;
if (winetest_interactive) trace("CSIDL_FAVORITES was changed to %s\n", path);
printf("CSIDL_FAVORITES was changed to %s\n", path);
ret = CreateDirectoryA(path, NULL); ret = CreateDirectoryA(path, NULL);
ok(!ret, ok(!ret,
"CreateDirectoryA succeeded but should have failed " "CreateDirectoryA succeeded but should have failed "
@ -770,6 +768,13 @@ static void testNonExistentPath1(void)
"CreateDirectoryA failed with %d, " "CreateDirectoryA failed with %d, "
"expected ERROR_ALREADY_EXISTS\n", "expected ERROR_ALREADY_EXISTS\n",
GetLastError()); GetLastError());
p = path + strlen(path);
strcpy(p, "\\desktop.ini");
DeleteFileA(path);
*p = 0;
SetFileAttributesA( path, FILE_ATTRIBUTE_NORMAL );
ret = RemoveDirectoryA(path);
ok( ret, "failed to remove %s error %u\n", path, GetLastError() );
} }
ok(SUCCEEDED(hr), ok(SUCCEEDED(hr),
"SHGetFolderPath(NULL, CSIDL_FAVORITES | CSIDL_FLAG_CREATE, " "SHGetFolderPath(NULL, CSIDL_FAVORITES | CSIDL_FLAG_CREATE, "
@ -838,15 +843,13 @@ static void testNonExistentPath(void)
memcpy(modifiedPath, originalPath, len); memcpy(modifiedPath, originalPath, len);
modifiedPath[len++] = '2'; modifiedPath[len++] = '2';
modifiedPath[len++] = '\0'; modifiedPath[len++] = '\0';
if (winetest_interactive) trace("Changing CSIDL_FAVORITES to %s\n", modifiedPath);
printf("Changing CSIDL_FAVORITES to %s\n", modifiedPath);
if (!RegSetValueExA(key, "Favorites", 0, type, if (!RegSetValueExA(key, "Favorites", 0, type,
(LPBYTE)modifiedPath, len)) (LPBYTE)modifiedPath, len))
{ {
char buffer[MAX_PATH+20]; char buffer[MAX_PATH+20];
STARTUPINFOA startup; STARTUPINFOA startup;
PROCESS_INFORMATION info; PROCESS_INFORMATION info;
HRESULT hr;
sprintf(buffer, "%s tests/shellpath.c 1", selfname); sprintf(buffer, "%s tests/shellpath.c 1", selfname);
memset(&startup, 0, sizeof(startup)); memset(&startup, 0, sizeof(startup));
@ -857,14 +860,8 @@ static void testNonExistentPath(void)
&startup, &info); &startup, &info);
winetest_wait_child_process( info.hProcess ); winetest_wait_child_process( info.hProcess );
/* Query the path to be able to delete it below */
hr = pSHGetFolderPathA(NULL, CSIDL_FAVORITES, NULL,
SHGFP_TYPE_CURRENT, modifiedPath);
ok(SUCCEEDED(hr), "SHGetFolderPathA failed: 0x%08x\n", hr);
/* restore original values: */ /* restore original values: */
if (winetest_interactive) trace("Restoring CSIDL_FAVORITES to %s\n", originalPath);
printf("Restoring CSIDL_FAVORITES to %s\n", originalPath);
RegSetValueExA(key, "Favorites", 0, type, (LPBYTE) originalPath, RegSetValueExA(key, "Favorites", 0, type, (LPBYTE) originalPath,
strlen(originalPath) + 1); strlen(originalPath) + 1);
RegFlushKey(key); RegFlushKey(key);
@ -878,21 +875,13 @@ static void testNonExistentPath(void)
&startup, &info); &startup, &info);
ok(WaitForSingleObject(info.hProcess, 30000) == WAIT_OBJECT_0, ok(WaitForSingleObject(info.hProcess, 30000) == WAIT_OBJECT_0,
"child process termination\n"); "child process termination\n");
strcpy(buffer, modifiedPath);
strcat(buffer, "\\desktop.ini");
DeleteFileA(buffer);
RemoveDirectoryA(modifiedPath);
} }
} }
else if (winetest_interactive) else skip("RegQueryValueExA(key, Favorites, ...) failed\n");
printf("RegQueryValueExA(key, Favorites, ...) failed\n");
if (key) if (key)
RegCloseKey(key); RegCloseKey(key);
} }
else if (winetest_interactive) else skip("RegOpenKeyExA(HKEY_CURRENT_USER, %s, ...) failed\n", userShellFolders);
printf("RegOpenKeyExA(HKEY_CURRENT_USER, %s, ...) failed\n",
userShellFolders);
} }
START_TEST(shellpath) START_TEST(shellpath)