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
652863f4
Commit
652863f4
authored
Oct 29, 2012
by
Hans Leidekker
Committed by
Alexandre Julliard
Oct 29, 2012
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
msi: Add more tests for embedded nulls in string property values.
parent
a1c4d2c9
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
45 additions
and
9 deletions
+45
-9
package.c
dlls/msi/tests/package.c
+45
-9
No files found.
dlls/msi/tests/package.c
View file @
652863f4
...
@@ -593,6 +593,17 @@ static UINT create_inilocator_table( MSIHANDLE hdb )
...
@@ -593,6 +593,17 @@ static UINT create_inilocator_table( MSIHANDLE hdb )
"PRIMARY KEY `Signature_`)"
);
"PRIMARY KEY `Signature_`)"
);
}
}
static
UINT
create_custom_action_table
(
MSIHANDLE
hdb
)
{
return
run_query
(
hdb
,
"CREATE TABLE `CustomAction` ("
"`Action` CHAR(72) NOT NULL, "
"`Type` SHORT NOT NULL, "
"`Source` CHAR(75), "
"`Target` CHAR(255) "
"PRIMARY KEY `Action`)"
);
}
#define make_add_entry(type, qtext) \
#define make_add_entry(type, qtext) \
static UINT add##_##type##_##entry( MSIHANDLE hdb, const char *values ) \
static UINT add##_##type##_##entry( MSIHANDLE hdb, const char *values ) \
{ \
{ \
...
@@ -672,6 +683,10 @@ make_add_entry(inilocator,
...
@@ -672,6 +683,10 @@ make_add_entry(inilocator,
"(`Signature_`, `FileName`, `Section`, `Key`, `Field`, `Type`) "
"(`Signature_`, `FileName`, `Section`, `Key`, `Field`, `Type`) "
"VALUES( %s )"
)
"VALUES( %s )"
)
make_add_entry
(
custom_action
,
"INSERT INTO `CustomAction` "
"(`Action`, `Type`, `Source`, `Target`) VALUES( %s )"
)
static
UINT
add_reglocator_entry
(
MSIHANDLE
hdb
,
const
char
*
sig
,
UINT
root
,
const
char
*
path
,
static
UINT
add_reglocator_entry
(
MSIHANDLE
hdb
,
const
char
*
sig
,
UINT
root
,
const
char
*
path
,
const
char
*
name
,
UINT
type
)
const
char
*
name
,
UINT
type
)
{
{
...
@@ -2139,10 +2154,10 @@ static void test_props(void)
...
@@ -2139,10 +2154,10 @@ static void test_props(void)
DeleteFile
(
msifile
);
DeleteFile
(
msifile
);
}
}
static
BOOL
find_prop_in_property
(
MSIHANDLE
hdb
,
LPCSTR
prop
,
LPCSTR
val
)
static
BOOL
find_prop_in_property
(
MSIHANDLE
hdb
,
LPCSTR
prop
,
LPCSTR
val
,
int
len
)
{
{
MSIHANDLE
hview
,
hrec
;
MSIHANDLE
hview
,
hrec
;
BOOL
found
;
BOOL
found
=
FALSE
;
CHAR
buffer
[
MAX_PATH
];
CHAR
buffer
[
MAX_PATH
];
DWORD
sz
;
DWORD
sz
;
UINT
r
;
UINT
r
;
...
@@ -2152,7 +2167,8 @@ static BOOL find_prop_in_property(MSIHANDLE hdb, LPCSTR prop, LPCSTR val)
...
@@ -2152,7 +2167,8 @@ static BOOL find_prop_in_property(MSIHANDLE hdb, LPCSTR prop, LPCSTR val)
r
=
MsiViewExecute
(
hview
,
0
);
r
=
MsiViewExecute
(
hview
,
0
);
ok
(
r
==
ERROR_SUCCESS
,
"MsiViewExecute failed
\n
"
);
ok
(
r
==
ERROR_SUCCESS
,
"MsiViewExecute failed
\n
"
);
found
=
FALSE
;
if
(
len
<
0
)
len
=
lstrlenA
(
val
);
while
(
r
==
ERROR_SUCCESS
&&
!
found
)
while
(
r
==
ERROR_SUCCESS
&&
!
found
)
{
{
r
=
MsiViewFetch
(
hview
,
&
hrec
);
r
=
MsiViewFetch
(
hview
,
&
hrec
);
...
@@ -2164,16 +2180,17 @@ static BOOL find_prop_in_property(MSIHANDLE hdb, LPCSTR prop, LPCSTR val)
...
@@ -2164,16 +2180,17 @@ static BOOL find_prop_in_property(MSIHANDLE hdb, LPCSTR prop, LPCSTR val)
{
{
sz
=
MAX_PATH
;
sz
=
MAX_PATH
;
r
=
MsiRecordGetString
(
hrec
,
2
,
buffer
,
&
sz
);
r
=
MsiRecordGetString
(
hrec
,
2
,
buffer
,
&
sz
);
if
(
r
==
ERROR_SUCCESS
&&
!
lstrcmpA
(
buffer
,
val
))
if
(
r
==
ERROR_SUCCESS
&&
!
memcmp
(
buffer
,
val
,
len
)
&&
!
buffer
[
len
])
{
ok
(
sz
==
len
,
"wrong size %u
\n
"
,
sz
);
found
=
TRUE
;
found
=
TRUE
;
}
}
}
MsiCloseHandle
(
hrec
);
MsiCloseHandle
(
hrec
);
}
}
MsiViewClose
(
hview
);
MsiViewClose
(
hview
);
MsiCloseHandle
(
hview
);
MsiCloseHandle
(
hview
);
return
found
;
return
found
;
}
}
...
@@ -2249,6 +2266,12 @@ static void test_property_table(void)
...
@@ -2249,6 +2266,12 @@ static void test_property_table(void)
r
=
add_property_entry
(
hdb
,
"'prop', 'val'"
);
r
=
add_property_entry
(
hdb
,
"'prop', 'val'"
);
ok
(
r
==
ERROR_SUCCESS
,
"cannot add property: %d
\n
"
,
r
);
ok
(
r
==
ERROR_SUCCESS
,
"cannot add property: %d
\n
"
,
r
);
r
=
create_custom_action_table
(
hdb
);
ok
(
r
==
ERROR_SUCCESS
,
"cannot create CustomAction table: %d
\n
"
,
r
);
r
=
add_custom_action_entry
(
hdb
,
"'EmbedNull', 51, 'prop2', '[~]np'"
);
ok
(
r
==
ERROR_SUCCESS
,
"cannot add custom action: %d
\n
"
,
r
);
r
=
package_from_db
(
hdb
,
&
hpkg
);
r
=
package_from_db
(
hdb
,
&
hpkg
);
ok
(
r
==
ERROR_SUCCESS
,
"failed to create package %u
\n
"
,
r
);
ok
(
r
==
ERROR_SUCCESS
,
"failed to create package %u
\n
"
,
r
);
...
@@ -2261,7 +2284,7 @@ static void test_property_table(void)
...
@@ -2261,7 +2284,7 @@ static void test_property_table(void)
hdb
=
MsiGetActiveDatabase
(
hpkg
);
hdb
=
MsiGetActiveDatabase
(
hpkg
);
found
=
find_prop_in_property
(
hdb
,
"prop"
,
"val"
);
found
=
find_prop_in_property
(
hdb
,
"prop"
,
"val"
,
-
1
);
ok
(
found
,
"prop should be in the _Property table
\n
"
);
ok
(
found
,
"prop should be in the _Property table
\n
"
);
r
=
add_property_entry
(
hdb
,
"'dantes', 'mercedes'"
);
r
=
add_property_entry
(
hdb
,
"'dantes', 'mercedes'"
);
...
@@ -2271,7 +2294,7 @@ static void test_property_table(void)
...
@@ -2271,7 +2294,7 @@ static void test_property_table(void)
r
=
do_query
(
hdb
,
query
,
&
hrec
);
r
=
do_query
(
hdb
,
query
,
&
hrec
);
ok
(
r
==
ERROR_BAD_QUERY_SYNTAX
,
"Expected ERROR_BAD_QUERY_SYNTAX, got %d
\n
"
,
r
);
ok
(
r
==
ERROR_BAD_QUERY_SYNTAX
,
"Expected ERROR_BAD_QUERY_SYNTAX, got %d
\n
"
,
r
);
found
=
find_prop_in_property
(
hdb
,
"dantes"
,
"mercedes"
);
found
=
find_prop_in_property
(
hdb
,
"dantes"
,
"mercedes"
,
-
1
);
ok
(
found
==
FALSE
,
"dantes should not be in the _Property table
\n
"
);
ok
(
found
==
FALSE
,
"dantes should not be in the _Property table
\n
"
);
sz
=
MAX_PATH
;
sz
=
MAX_PATH
;
...
@@ -2283,9 +2306,22 @@ static void test_property_table(void)
...
@@ -2283,9 +2306,22 @@ static void test_property_table(void)
r
=
MsiSetProperty
(
hpkg
,
"dantes"
,
"mercedes"
);
r
=
MsiSetProperty
(
hpkg
,
"dantes"
,
"mercedes"
);
ok
(
r
==
ERROR_SUCCESS
,
"Expected ERROR_SUCCESS, got %d
\n
"
,
r
);
ok
(
r
==
ERROR_SUCCESS
,
"Expected ERROR_SUCCESS, got %d
\n
"
,
r
);
found
=
find_prop_in_property
(
hdb
,
"dantes"
,
"mercedes"
);
found
=
find_prop_in_property
(
hdb
,
"dantes"
,
"mercedes"
,
-
1
);
ok
(
found
==
TRUE
,
"dantes should be in the _Property table
\n
"
);
ok
(
found
==
TRUE
,
"dantes should be in the _Property table
\n
"
);
r
=
MsiDoAction
(
hpkg
,
"EmbedNull"
);
ok
(
r
==
ERROR_SUCCESS
,
"EmbedNull failed: %d
\n
"
,
r
);
sz
=
MAX_PATH
;
memset
(
buffer
,
'a'
,
sizeof
(
buffer
)
);
r
=
MsiGetProperty
(
hpkg
,
"prop2"
,
buffer
,
&
sz
);
ok
(
r
==
ERROR_SUCCESS
,
"get property failed: %d
\n
"
,
r
);
todo_wine
ok
(
!
memcmp
(
buffer
,
"
\0
np"
,
sizeof
(
"
\0
np"
)
),
"wrong value
\n
"
);
todo_wine
ok
(
sz
==
sizeof
(
"
\0
np"
)
-
1
,
"got %u
\n
"
,
sz
);
found
=
find_prop_in_property
(
hdb
,
"prop2"
,
"
\0
np"
,
3
);
todo_wine
ok
(
found
==
TRUE
,
"prop2 should be in the _Property table
\n
"
);
MsiCloseHandle
(
hdb
);
MsiCloseHandle
(
hdb
);
MsiCloseHandle
(
hpkg
);
MsiCloseHandle
(
hpkg
);
DeleteFile
(
msifile
);
DeleteFile
(
msifile
);
...
...
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