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
85723b92
Commit
85723b92
authored
Oct 29, 2021
by
Nick Fox
Committed by
Alexandre Julliard
Nov 22, 2021
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
kernel32: Add tests for LdrGetDllPath with LOAD_WITH_ALTERED_SEARCH_PATH.
Signed-off-by:
Nick Fox
<
nick@foxsec.net
>
Signed-off-by:
Alexandre Julliard
<
julliard@winehq.org
>
parent
49d64194
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
59 additions
and
14 deletions
+59
-14
path.c
dlls/kernel32/tests/path.c
+59
-14
No files found.
dlls/kernel32/tests/path.c
View file @
85723b92
...
@@ -2409,10 +2409,12 @@ static void test_SetSearchPathMode(void)
...
@@ -2409,10 +2409,12 @@ static void test_SetSearchPathMode(void)
static
const
WCHAR
pathW
[]
=
{
'P'
,
'A'
,
'T'
,
'H'
,
0
};
static
const
WCHAR
pathW
[]
=
{
'P'
,
'A'
,
'T'
,
'H'
,
0
};
static
void
build_search_path
(
WCHAR
*
buffer
,
UINT
size
,
const
WCHAR
*
dlldir
,
BOOL
safe
)
static
void
build_search_path
(
WCHAR
*
buffer
,
UINT
size
,
const
WCHAR
*
module
,
const
WCHAR
*
dlldir
,
BOOL
safe
)
{
{
WCHAR
*
p
;
WCHAR
*
p
;
GetModuleFileNameW
(
NULL
,
buffer
,
size
);
if
(
module
)
lstrcpynW
(
buffer
,
module
,
size
);
else
GetModuleFileNameW
(
NULL
,
buffer
,
size
);
if
(
!
(
p
=
wcsrchr
(
buffer
,
'\\'
)))
return
;
if
(
!
(
p
=
wcsrchr
(
buffer
,
'\\'
)))
return
;
*
p
++
=
';'
;
*
p
++
=
';'
;
if
(
dlldir
)
if
(
dlldir
)
...
@@ -2471,7 +2473,7 @@ static void test_RtlGetSearchPath(void)
...
@@ -2471,7 +2473,7 @@ static void test_RtlGetSearchPath(void)
GetWindowsDirectoryW
(
buffer
,
ARRAY_SIZE
(
buffer
)
);
GetWindowsDirectoryW
(
buffer
,
ARRAY_SIZE
(
buffer
)
);
lstrcpynW
(
dlldir
,
buffer
,
ARRAY_SIZE
(
dlldir
)
);
lstrcpynW
(
dlldir
,
buffer
,
ARRAY_SIZE
(
dlldir
)
);
build_search_path
(
buffer
,
ARRAY_SIZE
(
buffer
),
NULL
,
TRUE
);
build_search_path
(
buffer
,
ARRAY_SIZE
(
buffer
),
NULL
,
NULL
,
TRUE
);
path
=
(
WCHAR
*
)
0xdeadbeef
;
path
=
(
WCHAR
*
)
0xdeadbeef
;
ret
=
pRtlGetSearchPath
(
&
path
);
ret
=
pRtlGetSearchPath
(
&
path
);
ok
(
!
ret
,
"RtlGetSearchPath failed %x
\n
"
,
ret
);
ok
(
!
ret
,
"RtlGetSearchPath failed %x
\n
"
,
ret
);
...
@@ -2479,7 +2481,7 @@ static void test_RtlGetSearchPath(void)
...
@@ -2479,7 +2481,7 @@ static void test_RtlGetSearchPath(void)
pRtlReleasePath
(
path
);
pRtlReleasePath
(
path
);
SetEnvironmentVariableA
(
"PATH"
,
"foo"
);
SetEnvironmentVariableA
(
"PATH"
,
"foo"
);
build_search_path
(
buffer
,
ARRAY_SIZE
(
buffer
),
NULL
,
TRUE
);
build_search_path
(
buffer
,
ARRAY_SIZE
(
buffer
),
NULL
,
NULL
,
TRUE
);
path
=
(
WCHAR
*
)
0xdeadbeef
;
path
=
(
WCHAR
*
)
0xdeadbeef
;
ret
=
pRtlGetSearchPath
(
&
path
);
ret
=
pRtlGetSearchPath
(
&
path
);
ok
(
!
ret
,
"RtlGetSearchPath failed %x
\n
"
,
ret
);
ok
(
!
ret
,
"RtlGetSearchPath failed %x
\n
"
,
ret
);
...
@@ -2489,7 +2491,7 @@ static void test_RtlGetSearchPath(void)
...
@@ -2489,7 +2491,7 @@ static void test_RtlGetSearchPath(void)
if
(
pSetDllDirectoryW
)
if
(
pSetDllDirectoryW
)
{
{
ok
(
pSetDllDirectoryW
(
dlldir
),
"SetDllDirectoryW failed
\n
"
);
ok
(
pSetDllDirectoryW
(
dlldir
),
"SetDllDirectoryW failed
\n
"
);
build_search_path
(
buffer
,
ARRAY_SIZE
(
buffer
),
NULL
,
TRUE
);
build_search_path
(
buffer
,
ARRAY_SIZE
(
buffer
),
NULL
,
NULL
,
TRUE
);
path
=
(
WCHAR
*
)
0xdeadbeef
;
path
=
(
WCHAR
*
)
0xdeadbeef
;
ret
=
pRtlGetSearchPath
(
&
path
);
ret
=
pRtlGetSearchPath
(
&
path
);
ok
(
!
ret
,
"RtlGetSearchPath failed %x
\n
"
,
ret
);
ok
(
!
ret
,
"RtlGetSearchPath failed %x
\n
"
,
ret
);
...
@@ -2520,14 +2522,14 @@ static void test_RtlGetExePath(void)
...
@@ -2520,14 +2522,14 @@ static void test_RtlGetExePath(void)
lstrcpynW
(
dlldir
,
buffer
,
ARRAY_SIZE
(
dlldir
)
);
lstrcpynW
(
dlldir
,
buffer
,
ARRAY_SIZE
(
dlldir
)
);
SetEnvironmentVariableA
(
"NoDefaultCurrentDirectoryInExePath"
,
NULL
);
SetEnvironmentVariableA
(
"NoDefaultCurrentDirectoryInExePath"
,
NULL
);
build_search_path
(
buffer
,
ARRAY_SIZE
(
buffer
),
NULL
,
FALSE
);
build_search_path
(
buffer
,
ARRAY_SIZE
(
buffer
),
NULL
,
NULL
,
FALSE
);
path
=
(
WCHAR
*
)
0xdeadbeef
;
path
=
(
WCHAR
*
)
0xdeadbeef
;
ret
=
pRtlGetExePath
(
fooW
,
&
path
);
ret
=
pRtlGetExePath
(
fooW
,
&
path
);
ok
(
!
ret
,
"RtlGetExePath failed %x
\n
"
,
ret
);
ok
(
!
ret
,
"RtlGetExePath failed %x
\n
"
,
ret
);
ok
(
path_equal
(
path
,
buffer
),
"got %s expected %s
\n
"
,
wine_dbgstr_w
(
path
),
wine_dbgstr_w
(
buffer
));
ok
(
path_equal
(
path
,
buffer
),
"got %s expected %s
\n
"
,
wine_dbgstr_w
(
path
),
wine_dbgstr_w
(
buffer
));
pRtlReleasePath
(
path
);
pRtlReleasePath
(
path
);
build_search_path
(
buffer
,
ARRAY_SIZE
(
buffer
),
NULL
,
FALSE
);
build_search_path
(
buffer
,
ARRAY_SIZE
(
buffer
),
NULL
,
NULL
,
FALSE
);
path
=
(
WCHAR
*
)
0xdeadbeef
;
path
=
(
WCHAR
*
)
0xdeadbeef
;
ret
=
pRtlGetExePath
(
fooW
+
1
,
&
path
);
ret
=
pRtlGetExePath
(
fooW
+
1
,
&
path
);
ok
(
!
ret
,
"RtlGetExePath failed %x
\n
"
,
ret
);
ok
(
!
ret
,
"RtlGetExePath failed %x
\n
"
,
ret
);
...
@@ -2536,14 +2538,14 @@ static void test_RtlGetExePath(void)
...
@@ -2536,14 +2538,14 @@ static void test_RtlGetExePath(void)
SetEnvironmentVariableA
(
"NoDefaultCurrentDirectoryInExePath"
,
"yes"
);
SetEnvironmentVariableA
(
"NoDefaultCurrentDirectoryInExePath"
,
"yes"
);
build_search_path
(
buffer
,
ARRAY_SIZE
(
buffer
),
NULL
,
FALSE
);
build_search_path
(
buffer
,
ARRAY_SIZE
(
buffer
),
NULL
,
NULL
,
FALSE
);
path
=
(
WCHAR
*
)
0xdeadbeef
;
path
=
(
WCHAR
*
)
0xdeadbeef
;
ret
=
pRtlGetExePath
(
fooW
,
&
path
);
ret
=
pRtlGetExePath
(
fooW
,
&
path
);
ok
(
!
ret
,
"RtlGetExePath failed %x
\n
"
,
ret
);
ok
(
!
ret
,
"RtlGetExePath failed %x
\n
"
,
ret
);
ok
(
path_equal
(
path
,
buffer
),
"got %s expected %s
\n
"
,
wine_dbgstr_w
(
path
),
wine_dbgstr_w
(
buffer
));
ok
(
path_equal
(
path
,
buffer
),
"got %s expected %s
\n
"
,
wine_dbgstr_w
(
path
),
wine_dbgstr_w
(
buffer
));
pRtlReleasePath
(
path
);
pRtlReleasePath
(
path
);
build_search_path
(
buffer
,
ARRAY_SIZE
(
buffer
),
emptyW
,
TRUE
);
build_search_path
(
buffer
,
ARRAY_SIZE
(
buffer
),
NULL
,
emptyW
,
TRUE
);
path
=
(
WCHAR
*
)
0xdeadbeef
;
path
=
(
WCHAR
*
)
0xdeadbeef
;
ret
=
pRtlGetExePath
(
fooW
+
1
,
&
path
);
ret
=
pRtlGetExePath
(
fooW
+
1
,
&
path
);
ok
(
!
ret
,
"RtlGetExePath failed %x
\n
"
,
ret
);
ok
(
!
ret
,
"RtlGetExePath failed %x
\n
"
,
ret
);
...
@@ -2551,7 +2553,7 @@ static void test_RtlGetExePath(void)
...
@@ -2551,7 +2553,7 @@ static void test_RtlGetExePath(void)
pRtlReleasePath
(
path
);
pRtlReleasePath
(
path
);
SetEnvironmentVariableA
(
"PATH"
,
"foo"
);
SetEnvironmentVariableA
(
"PATH"
,
"foo"
);
build_search_path
(
buffer
,
ARRAY_SIZE
(
buffer
),
NULL
,
FALSE
);
build_search_path
(
buffer
,
ARRAY_SIZE
(
buffer
),
NULL
,
NULL
,
FALSE
);
path
=
(
WCHAR
*
)
0xdeadbeef
;
path
=
(
WCHAR
*
)
0xdeadbeef
;
ret
=
pRtlGetExePath
(
fooW
,
&
path
);
ret
=
pRtlGetExePath
(
fooW
,
&
path
);
ok
(
!
ret
,
"RtlGetExePath failed %x
\n
"
,
ret
);
ok
(
!
ret
,
"RtlGetExePath failed %x
\n
"
,
ret
);
...
@@ -2561,7 +2563,7 @@ static void test_RtlGetExePath(void)
...
@@ -2561,7 +2563,7 @@ static void test_RtlGetExePath(void)
if
(
pSetDllDirectoryW
)
if
(
pSetDllDirectoryW
)
{
{
ok
(
pSetDllDirectoryW
(
dlldir
),
"SetDllDirectoryW failed
\n
"
);
ok
(
pSetDllDirectoryW
(
dlldir
),
"SetDllDirectoryW failed
\n
"
);
build_search_path
(
buffer
,
ARRAY_SIZE
(
buffer
),
NULL
,
FALSE
);
build_search_path
(
buffer
,
ARRAY_SIZE
(
buffer
),
NULL
,
NULL
,
FALSE
);
path
=
(
WCHAR
*
)
0xdeadbeef
;
path
=
(
WCHAR
*
)
0xdeadbeef
;
ret
=
pRtlGetExePath
(
fooW
,
&
path
);
ret
=
pRtlGetExePath
(
fooW
,
&
path
);
ok
(
!
ret
,
"RtlGetExePath failed %x
\n
"
,
ret
);
ok
(
!
ret
,
"RtlGetExePath failed %x
\n
"
,
ret
);
...
@@ -2589,7 +2591,7 @@ static void test_LdrGetDllPath(void)
...
@@ -2589,7 +2591,7 @@ static void test_LdrGetDllPath(void)
GetWindowsDirectoryW
(
buffer
,
ARRAY_SIZE
(
buffer
)
);
GetWindowsDirectoryW
(
buffer
,
ARRAY_SIZE
(
buffer
)
);
lstrcpynW
(
dlldir
,
buffer
,
ARRAY_SIZE
(
dlldir
)
);
lstrcpynW
(
dlldir
,
buffer
,
ARRAY_SIZE
(
dlldir
)
);
build_search_path
(
buffer
,
ARRAY_SIZE
(
buffer
),
NULL
,
TRUE
);
build_search_path
(
buffer
,
ARRAY_SIZE
(
buffer
),
NULL
,
NULL
,
TRUE
);
path
=
unknown_ptr
=
(
WCHAR
*
)
0xdeadbeef
;
path
=
unknown_ptr
=
(
WCHAR
*
)
0xdeadbeef
;
ret
=
pLdrGetDllPath
(
0
,
0
,
&
path
,
&
unknown_ptr
);
ret
=
pLdrGetDllPath
(
0
,
0
,
&
path
,
&
unknown_ptr
);
...
@@ -2599,7 +2601,7 @@ static void test_LdrGetDllPath(void)
...
@@ -2599,7 +2601,7 @@ static void test_LdrGetDllPath(void)
pRtlReleasePath
(
path
);
pRtlReleasePath
(
path
);
SetEnvironmentVariableA
(
"PATH"
,
"foo"
);
SetEnvironmentVariableA
(
"PATH"
,
"foo"
);
build_search_path
(
buffer
,
ARRAY_SIZE
(
buffer
),
NULL
,
TRUE
);
build_search_path
(
buffer
,
ARRAY_SIZE
(
buffer
),
NULL
,
NULL
,
TRUE
);
ret
=
pLdrGetDllPath
(
0
,
0
,
&
path
,
&
unknown_ptr
);
ret
=
pLdrGetDllPath
(
0
,
0
,
&
path
,
&
unknown_ptr
);
ok
(
!
ret
,
"LdrGetDllPath failed %x
\n
"
,
ret
);
ok
(
!
ret
,
"LdrGetDllPath failed %x
\n
"
,
ret
);
ok
(
!
unknown_ptr
,
"unknown ptr %p
\n
"
,
unknown_ptr
);
ok
(
!
unknown_ptr
,
"unknown ptr %p
\n
"
,
unknown_ptr
);
...
@@ -2609,7 +2611,7 @@ static void test_LdrGetDllPath(void)
...
@@ -2609,7 +2611,7 @@ static void test_LdrGetDllPath(void)
if
(
pSetDllDirectoryW
)
if
(
pSetDllDirectoryW
)
{
{
ok
(
pSetDllDirectoryW
(
dlldir
),
"SetDllDirectoryW failed
\n
"
);
ok
(
pSetDllDirectoryW
(
dlldir
),
"SetDllDirectoryW failed
\n
"
);
build_search_path
(
buffer
,
ARRAY_SIZE
(
buffer
),
dlldir
,
TRUE
);
build_search_path
(
buffer
,
ARRAY_SIZE
(
buffer
),
NULL
,
dlldir
,
TRUE
);
ret
=
pLdrGetDllPath
(
0
,
0
,
&
path
,
&
unknown_ptr
);
ret
=
pLdrGetDllPath
(
0
,
0
,
&
path
,
&
unknown_ptr
);
ok
(
!
ret
,
"LdrGetDllPath failed %x
\n
"
,
ret
);
ok
(
!
ret
,
"LdrGetDllPath failed %x
\n
"
,
ret
);
ok
(
!
unknown_ptr
,
"unknown ptr %p
\n
"
,
unknown_ptr
);
ok
(
!
unknown_ptr
,
"unknown ptr %p
\n
"
,
unknown_ptr
);
...
@@ -2654,6 +2656,49 @@ static void test_LdrGetDllPath(void)
...
@@ -2654,6 +2656,49 @@ static void test_LdrGetDllPath(void)
ok
(
!
lstrcmpW
(
path
,
L"
\\\\
?
\\
c:"
),
"got %s expected
\\\\
?
\\
c:
\n
"
,
wine_dbgstr_w
(
path
));
ok
(
!
lstrcmpW
(
path
,
L"
\\\\
?
\\
c:"
),
"got %s expected
\\\\
?
\\
c:
\n
"
,
wine_dbgstr_w
(
path
));
pRtlReleasePath
(
path
);
pRtlReleasePath
(
path
);
ret
=
pLdrGetDllPath
(
fooW
,
LOAD_WITH_ALTERED_SEARCH_PATH
,
&
path
,
&
unknown_ptr
);
ok
(
!
ret
,
"LdrGetDllPath failed %x
\n
"
,
ret
);
ok
(
!
unknown_ptr
,
"unknown ptr %p
\n
"
,
unknown_ptr
);
todo_wine
build_search_path
(
buffer
,
ARRAY_SIZE
(
buffer
),
NULL
,
NULL
,
TRUE
);
ok
(
path_equal
(
path
,
buffer
),
"got %s expected %s
\n
"
,
wine_dbgstr_w
(
path
),
wine_dbgstr_w
(
buffer
));
pRtlReleasePath
(
path
);
ret
=
pLdrGetDllPath
(
L"temp/foo"
,
LOAD_WITH_ALTERED_SEARCH_PATH
,
&
path
,
&
unknown_ptr
);
ok
(
!
ret
,
"LdrGetDllPath failed %x
\n
"
,
ret
);
ok
(
!
unknown_ptr
,
"unknown ptr %p
\n
"
,
unknown_ptr
);
todo_wine
build_search_path
(
buffer
,
ARRAY_SIZE
(
buffer
),
NULL
,
NULL
,
TRUE
);
ok
(
path_equal
(
path
,
buffer
),
"got %s expected %s
\n
"
,
wine_dbgstr_w
(
path
),
wine_dbgstr_w
(
buffer
));
pRtlReleasePath
(
path
);
ret
=
pLdrGetDllPath
(
L".
\\
foo
\\
foobar"
,
LOAD_WITH_ALTERED_SEARCH_PATH
,
&
path
,
&
unknown_ptr
);
ok
(
!
ret
,
"LdrGetDllPath failed %x
\n
"
,
ret
);
ok
(
!
unknown_ptr
,
"unknown ptr %p
\n
"
,
unknown_ptr
);
build_search_path
(
buffer
,
ARRAY_SIZE
(
buffer
),
L".
\\
foo
\\
foobar"
,
NULL
,
TRUE
);
ok
(
path_equal
(
path
,
buffer
),
"got %s expected %s
\n
"
,
wine_dbgstr_w
(
path
),
wine_dbgstr_w
(
buffer
));
pRtlReleasePath
(
path
);
ret
=
pLdrGetDllPath
(
L"temp
\\
foo"
,
LOAD_WITH_ALTERED_SEARCH_PATH
,
&
path
,
&
unknown_ptr
);
ok
(
!
ret
,
"LdrGetDllPath failed %x
\n
"
,
ret
);
ok
(
!
unknown_ptr
,
"unknown ptr %p
\n
"
,
unknown_ptr
);
build_search_path
(
buffer
,
ARRAY_SIZE
(
buffer
),
L"temp
\\
foo"
,
NULL
,
TRUE
);
ok
(
path_equal
(
path
,
buffer
),
"got %s expected %s
\n
"
,
wine_dbgstr_w
(
path
),
wine_dbgstr_w
(
buffer
));
pRtlReleasePath
(
path
);
ret
=
pLdrGetDllPath
(
L"c:
\\
temp
\\
foo"
,
LOAD_WITH_ALTERED_SEARCH_PATH
,
&
path
,
&
unknown_ptr
);
ok
(
!
ret
,
"LdrGetDllPath failed %x
\n
"
,
ret
);
ok
(
!
unknown_ptr
,
"unknown ptr %p
\n
"
,
unknown_ptr
);
build_search_path
(
buffer
,
ARRAY_SIZE
(
buffer
),
L"c:
\\
temp
\\
foo"
,
NULL
,
TRUE
);
ok
(
path_equal
(
path
,
buffer
),
"got %s expected %s
\n
"
,
wine_dbgstr_w
(
path
),
wine_dbgstr_w
(
buffer
));
pRtlReleasePath
(
path
);
lstrcpyW
(
buffer
,
fooW
);
ret
=
pLdrGetDllPath
(
buffer
,
LOAD_WITH_ALTERED_SEARCH_PATH
|
LOAD_LIBRARY_SEARCH_DLL_LOAD_DIR
,
&
path
,
&
unknown_ptr
);
ok
(
ret
==
STATUS_INVALID_PARAMETER
,
"got %x expected %x
\n
"
,
ret
,
STATUS_INVALID_PARAMETER
);
ok
(
!
unknown_ptr
,
"unknown ptr %p
\n
"
,
unknown_ptr
);
pRtlReleasePath
(
path
);
lstrcpyW
(
buffer
,
dlldir
);
lstrcpyW
(
buffer
,
dlldir
);
p
=
buffer
+
lstrlenW
(
buffer
);
p
=
buffer
+
lstrlenW
(
buffer
);
*
p
++
=
'\\'
;
*
p
++
=
'\\'
;
...
...
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