Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-cw
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-cw
Commits
9eaea34e
Commit
9eaea34e
authored
Mar 26, 2007
by
James Hawkins
Committed by
Alexandre Julliard
Mar 27, 2007
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
setupapi: Add several tests for SetupCopyOEMInf, with fixes so the tests don't crash.
parent
da85c090
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
276 additions
and
5 deletions
+276
-5
misc.c
dlls/setupapi/misc.c
+13
-5
Makefile.in
dlls/setupapi/tests/Makefile.in
+1
-0
misc.c
dlls/setupapi/tests/misc.c
+262
-0
No files found.
dlls/setupapi/misc.c
View file @
9eaea34e
...
...
@@ -886,13 +886,14 @@ BOOL WINAPI SetupCopyOEMInfA( PCSTR source, PCSTR location,
DWORD
buffer_size
,
PDWORD
required_size
,
PSTR
*
component
)
{
BOOL
ret
=
FALSE
;
WCHAR
destW
[
MAX_PATH
],
*
sourceW
=
NULL
,
*
locationW
=
NULL
;
INT
size
=
sizeof
(
destW
)
;
LPWSTR
destW
=
NULL
,
sourceW
=
NULL
,
locationW
=
NULL
;
INT
size
=
MAX_PATH
;
TRACE
(
"%s, %s, %d, %d, %p, %d, %p, %p
\n
"
,
debugstr_a
(
source
),
debugstr_a
(
location
),
media_type
,
style
,
dest
,
buffer_size
,
required_size
,
component
);
if
(
source
&&
!
(
sourceW
=
strdupAtoW
(
source
)))
return
FALSE
;
if
(
dest
&&
!
(
destW
=
MyMalloc
(
MAX_PATH
*
sizeof
(
WCHAR
)
)))
return
FALSE
;
if
(
source
&&
!
(
sourceW
=
strdupAtoW
(
source
)))
goto
done
;
if
(
location
&&
!
(
locationW
=
strdupAtoW
(
location
)))
goto
done
;
if
(
!
(
ret
=
SetupCopyOEMInfW
(
sourceW
,
locationW
,
media_type
,
style
,
destW
,
size
,
NULL
,
NULL
)))
...
...
@@ -916,6 +917,7 @@ BOOL WINAPI SetupCopyOEMInfA( PCSTR source, PCSTR location,
}
done:
MyFree
(
destW
);
HeapFree
(
GetProcessHeap
(),
0
,
sourceW
);
HeapFree
(
GetProcessHeap
(),
0
,
locationW
);
return
ret
;
...
...
@@ -936,11 +938,17 @@ BOOL WINAPI SetupCopyOEMInfW( PCWSTR source, PCWSTR location,
TRACE
(
"%s, %s, %d, %d, %p, %d, %p, %p
\n
"
,
debugstr_w
(
source
),
debugstr_w
(
location
),
media_type
,
style
,
dest
,
buffer_size
,
required_size
,
component
);
if
(
!
source
)
{
SetLastError
(
ERROR_INVALID_PARAMETER
);
return
FALSE
;
}
if
(
!
GetWindowsDirectoryW
(
target
,
sizeof
(
target
)
/
sizeof
(
WCHAR
)
))
return
FALSE
;
strcatW
(
target
,
inf_oem
);
p
=
strrchrW
(
source
,
'\\'
)
+
1
;
strcatW
(
target
,
p
);
if
((
p
=
strrchrW
(
source
,
'\\'
)))
strcatW
(
target
,
p
+
1
);
size
=
strlenW
(
target
)
+
1
;
if
(
dest
)
...
...
dlls/setupapi/tests/Makefile.in
View file @
9eaea34e
...
...
@@ -7,6 +7,7 @@ IMPORTS = setupapi advapi32 kernel32
CTESTS
=
\
devinst.c
\
misc.c
\
parser.c
\
query.c
\
stringtable.c
...
...
dlls/setupapi/tests/misc.c
0 → 100644
View file @
9eaea34e
/*
* Miscellaneous tests
*
* Copyright 2007 James Hawkins
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
*/
#include <stdarg.h>
#include <stdio.h>
#include <string.h>
#include "windef.h"
#include "winbase.h"
#include "winuser.h"
#include "winreg.h"
#include "setupapi.h"
#include "wine/test.h"
static
CHAR
CURR_DIR
[
MAX_PATH
];
/* test:
* - fails if not administrator
* - what if it's not a .inf file?
* - copied to %windir%/Inf
* - SourceInfFileName should be a full path
* - SourceInfFileName should be <= MAX_PATH
* - copy styles
*/
static
void
append_str
(
char
**
str
,
const
char
*
data
)
{
sprintf
(
*
str
,
data
);
*
str
+=
strlen
(
*
str
);
}
static
void
create_inf_file
(
LPCSTR
filename
)
{
char
data
[
1024
];
char
*
ptr
=
data
;
DWORD
dwNumberOfBytesWritten
;
HANDLE
hf
=
CreateFile
(
filename
,
GENERIC_WRITE
,
0
,
NULL
,
CREATE_ALWAYS
,
FILE_ATTRIBUTE_NORMAL
,
NULL
);
append_str
(
&
ptr
,
"[Version]
\n
"
);
append_str
(
&
ptr
,
"Signature=
\"
$Chicago$
\"\n
"
);
append_str
(
&
ptr
,
"AdvancedINF=2.5
\n
"
);
append_str
(
&
ptr
,
"[DefaultInstall]
\n
"
);
append_str
(
&
ptr
,
"RegisterOCXs=RegisterOCXsSection
\n
"
);
append_str
(
&
ptr
,
"[RegisterOCXsSection]
\n
"
);
append_str
(
&
ptr
,
"%%11%%
\\
ole32.dll
\n
"
);
WriteFile
(
hf
,
data
,
ptr
-
data
,
&
dwNumberOfBytesWritten
,
NULL
);
CloseHandle
(
hf
);
}
static
void
get_temp_filename
(
LPSTR
path
)
{
CHAR
temp
[
MAX_PATH
];
LPSTR
ptr
;
GetTempFileName
(
CURR_DIR
,
"set"
,
0
,
temp
);
ptr
=
strrchr
(
temp
,
'\\'
);
lstrcpy
(
path
,
ptr
+
1
);
}
static
BOOL
file_exists
(
LPSTR
path
)
{
return
GetFileAttributes
(
path
)
!=
INVALID_FILE_ATTRIBUTES
;
}
static
BOOL
check_format
(
LPSTR
path
,
LPSTR
inf
)
{
CHAR
check
[
MAX_PATH
];
BOOL
res
;
static
const
CHAR
format
[]
=
"
\\
INF
\\
oem"
;
GetWindowsDirectory
(
check
,
MAX_PATH
);
lstrcat
(
check
,
format
);
res
=
!
strncmp
(
check
,
path
,
lstrlen
(
check
))
&&
path
[
lstrlen
(
check
)]
!=
'\\'
;
return
(
!
inf
)
?
res
:
res
&&
(
inf
==
path
+
lstrlen
(
check
)
-
3
);
}
static
void
test_SetupCopyOEMInf
(
void
)
{
CHAR
toolong
[
MAX_PATH
*
2
];
CHAR
path
[
MAX_PATH
],
dest
[
MAX_PATH
];
CHAR
tmpfile
[
MAX_PATH
];
LPSTR
inf
;
DWORD
size
;
BOOL
res
;
/* try NULL SourceInfFileName */
SetLastError
(
0xdeadbeef
);
res
=
SetupCopyOEMInf
(
NULL
,
NULL
,
0
,
SP_COPY_NOOVERWRITE
,
NULL
,
0
,
NULL
,
NULL
);
ok
(
res
==
FALSE
,
"Expected FALSE, got %d
\n
"
,
res
);
ok
(
GetLastError
()
==
ERROR_INVALID_PARAMETER
,
"Expected ERROR_INVALID_PARAMETER, got %d
\n
"
,
GetLastError
());
/* try empty SourceInfFileName */
SetLastError
(
0xdeadbeef
);
res
=
SetupCopyOEMInf
(
""
,
NULL
,
0
,
SP_COPY_NOOVERWRITE
,
NULL
,
0
,
NULL
,
NULL
);
ok
(
res
==
FALSE
,
"Expected FALSE, got %d
\n
"
,
res
);
todo_wine
{
ok
(
GetLastError
()
==
ERROR_FILE_NOT_FOUND
,
"Expected ERROR_FILE_NOT_FOUND, got %d
\n
"
,
GetLastError
());
}
/* try nonexistent SourceInfFileName */
SetLastError
(
0xdeadbeef
);
res
=
SetupCopyOEMInf
(
"nonexistent"
,
NULL
,
0
,
SP_COPY_NOOVERWRITE
,
NULL
,
0
,
NULL
,
NULL
);
ok
(
res
==
FALSE
,
"Expected FALSE, got %d
\n
"
,
res
);
todo_wine
{
ok
(
GetLastError
()
==
ERROR_FILE_NOT_FOUND
,
"Expected ERROR_FILE_NOT_FOUND, got %d
\n
"
,
GetLastError
());
}
/* try a long SourceInfFileName */
memset
(
toolong
,
'a'
,
MAX_PATH
*
2
);
toolong
[
MAX_PATH
*
2
-
1
]
=
'\0'
;
SetLastError
(
0xdeadbeef
);
res
=
SetupCopyOEMInf
(
toolong
,
NULL
,
0
,
SP_COPY_NOOVERWRITE
,
NULL
,
0
,
NULL
,
NULL
);
ok
(
res
==
FALSE
,
"Expected FALSE, got %d
\n
"
,
res
);
todo_wine
{
ok
(
GetLastError
()
==
ERROR_FILE_NOT_FOUND
,
"Expected ERROR_FILE_NOT_FOUND, got %d
\n
"
,
GetLastError
());
}
get_temp_filename
(
tmpfile
);
create_inf_file
(
tmpfile
);
/* try a relative SourceInfFileName */
SetLastError
(
0xdeadbeef
);
res
=
SetupCopyOEMInf
(
tmpfile
,
NULL
,
0
,
SP_COPY_NOOVERWRITE
,
NULL
,
0
,
NULL
,
NULL
);
ok
(
res
==
FALSE
,
"Expected FALSE, got %d
\n
"
,
res
);
todo_wine
{
ok
(
GetLastError
()
==
ERROR_FILE_NOT_FOUND
,
"Expected ERROR_FILE_NOT_FOUND, got %d
\n
"
,
GetLastError
());
}
ok
(
file_exists
(
tmpfile
),
"Expected tmpfile to exist
\n
"
);
/* try SP_COPY_REPLACEONLY, dest does not exist */
SetLastError
(
0xdeadbeef
);
res
=
SetupCopyOEMInf
(
path
,
NULL
,
SPOST_NONE
,
SP_COPY_REPLACEONLY
,
NULL
,
0
,
NULL
,
NULL
);
ok
(
res
==
FALSE
,
"Expected FALSE, got %d
\n
"
,
res
);
todo_wine
{
ok
(
GetLastError
()
==
ERROR_FILE_NOT_FOUND
,
"Expected ERROR_FILE_NOT_FOUND, got %d
\n
"
,
GetLastError
());
}
ok
(
file_exists
(
tmpfile
),
"Expected source inf to exist
\n
"
);
/* try an absolute SourceInfFileName, without DestinationInfFileName */
lstrcpy
(
path
,
CURR_DIR
);
lstrcat
(
path
,
"
\\
"
);
lstrcat
(
path
,
tmpfile
);
SetLastError
(
0xdeadbeef
);
res
=
SetupCopyOEMInf
(
path
,
NULL
,
SPOST_NONE
,
0
,
NULL
,
0
,
NULL
,
NULL
);
todo_wine
{
ok
(
res
==
TRUE
,
"Expected TRUE, got %d
\n
"
,
res
);
ok
(
GetLastError
()
==
ERROR_SUCCESS
,
"Expected ERROR_SUCCESS, got %d
\n
"
,
GetLastError
());
}
ok
(
file_exists
(
path
),
"Expected source inf to exist
\n
"
);
/* try SP_COPY_REPLACEONLY, dest exists */
SetLastError
(
0xdeadbeef
);
res
=
SetupCopyOEMInf
(
path
,
NULL
,
SPOST_NONE
,
SP_COPY_REPLACEONLY
,
NULL
,
0
,
NULL
,
NULL
);
todo_wine
{
ok
(
res
==
TRUE
,
"Expected TRUE, got %d
\n
"
,
res
);
ok
(
GetLastError
()
==
ERROR_SUCCESS
,
"Expected ERROR_SUCCESS, got %d
\n
"
,
GetLastError
());
}
ok
(
file_exists
(
path
),
"Expected source inf to exist
\n
"
);
/* try SP_COPY_NOOVERWRITE */
SetLastError
(
0xdeadbeef
);
res
=
SetupCopyOEMInf
(
path
,
NULL
,
SPOST_NONE
,
SP_COPY_NOOVERWRITE
,
NULL
,
0
,
NULL
,
NULL
);
ok
(
res
==
FALSE
,
"Expected FALSE, got %d
\n
"
,
res
);
todo_wine
{
ok
(
GetLastError
()
==
ERROR_FILE_EXISTS
,
"Expected ERROR_FILE_EXISTS, got %d
\n
"
,
GetLastError
());
}
/* get the DestinationInfFileName */
SetLastError
(
0xdeadbeef
);
res
=
SetupCopyOEMInf
(
path
,
NULL
,
SPOST_NONE
,
0
,
dest
,
MAX_PATH
,
NULL
,
NULL
);
ok
(
res
==
TRUE
,
"Expected TRUE, got %d
\n
"
,
res
);
ok
(
GetLastError
()
==
ERROR_SUCCESS
,
"Expected ERROR_SUCCESS, got %d
\n
"
,
GetLastError
());
ok
(
lstrlen
(
dest
)
!=
0
,
"Expected a non-zero length string
\n
"
);
ok
(
file_exists
(
dest
),
"Expected destination inf to exist
\n
"
);
todo_wine
{
ok
(
check_format
(
dest
,
NULL
),
"Expected %%windir%%
\\
inf
\\
OEMx.inf, got %s
\n
"
,
dest
);
}
ok
(
file_exists
(
path
),
"Expected source inf to exist
\n
"
);
/* get the DestinationInfFileName and DestinationInfFileNameSize */
SetLastError
(
0xdeadbeef
);
res
=
SetupCopyOEMInf
(
path
,
NULL
,
SPOST_NONE
,
0
,
dest
,
MAX_PATH
,
&
size
,
NULL
);
ok
(
res
==
TRUE
,
"Expected TRUE, got %d
\n
"
,
res
);
ok
(
GetLastError
()
==
ERROR_SUCCESS
,
"Expected ERROR_SUCCESS, got %d
\n
"
,
GetLastError
());
ok
(
lstrlen
(
dest
)
+
1
==
size
,
"Expected sizes to match, got (%d, %d)
\n
"
,
lstrlen
(
dest
),
size
);
ok
(
file_exists
(
dest
),
"Expected destination inf to exist
\n
"
);
todo_wine
{
ok
(
check_format
(
dest
,
NULL
),
"Expected %%windir%%
\\
inf
\\
OEMx.inf, got %s
\n
"
,
dest
);
}
ok
(
file_exists
(
path
),
"Expected source inf to exist
\n
"
);
/* get the DestinationInfFileName, DestinationInfFileNameSize, and DestinationInfFileNameComponent */
SetLastError
(
0xdeadbeef
);
res
=
SetupCopyOEMInf
(
path
,
NULL
,
SPOST_NONE
,
0
,
dest
,
MAX_PATH
,
&
size
,
&
inf
);
ok
(
res
==
TRUE
,
"Expected TRUE, got %d
\n
"
,
res
);
ok
(
GetLastError
()
==
ERROR_SUCCESS
,
"Expected ERROR_SUCCESS, got %d
\n
"
,
GetLastError
());
ok
(
lstrlen
(
dest
)
+
1
==
size
,
"Expected sizes to match, got (%d, %d)
\n
"
,
lstrlen
(
dest
),
size
);
ok
(
file_exists
(
dest
),
"Expected destination inf to exist
\n
"
);
todo_wine
{
ok
(
check_format
(
dest
,
inf
),
"Expected %%windir%%
\\
inf
\\
OEMx.inf, got %s
\n
"
,
dest
);
}
ok
(
file_exists
(
path
),
"Expected source inf to exist
\n
"
);
/* try SP_COPY_DELETESOURCE */
SetLastError
(
0xdeadbeef
);
res
=
SetupCopyOEMInf
(
path
,
NULL
,
SPOST_NONE
,
SP_COPY_DELETESOURCE
,
NULL
,
0
,
NULL
,
NULL
);
todo_wine
{
ok
(
res
==
TRUE
,
"Expected TRUE, got %d
\n
"
,
res
);
ok
(
GetLastError
()
==
ERROR_SUCCESS
,
"Expected ERROR_SUCCESS, got %d
\n
"
,
GetLastError
());
ok
(
!
file_exists
(
path
),
"Expected source inf to not exist
\n
"
);
}
}
START_TEST
(
misc
)
{
GetCurrentDirectoryA
(
MAX_PATH
,
CURR_DIR
);
test_SetupCopyOEMInf
();
}
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