Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-winehq
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-winehq
Commits
c22e4974
Commit
c22e4974
authored
Nov 14, 2008
by
Alexandre Julliard
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
shell32/tests: Properly cleanup the created favorites shell folder.
parent
43fae4e4
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
19 additions
and
30 deletions
+19
-30
shellpath.c
dlls/shell32/tests/shellpath.c
+19
-30
No files found.
dlls/shell32/tests/shellpath.c
View file @
c22e4974
...
@@ -188,9 +188,8 @@ static void loadShell32(void)
...
@@ -188,9 +188,8 @@ 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)
...
@@ -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)
...
@@ -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)
...
@@ -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)
...
@@ -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)
...
@@ -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)
...
@@ -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)
...
@@ -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
)
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment