shell32/tests: Properly cleanup the created favorites shell folder.
This commit is contained in:
parent
43fae4e425
commit
c22e49740a
|
@ -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)
|
||||||
|
|
Loading…
Reference in New Issue