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
03a9bf4f
Commit
03a9bf4f
authored
Sep 25, 2017
by
Hugh McMaster
Committed by
Alexandre Julliard
Sep 25, 2017
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
regedit/tests: Test registry export against order of data creation.
Signed-off-by:
Hugh McMaster
<
hugh.mcmaster@outlook.com
>
Signed-off-by:
Alexandre Julliard
<
julliard@winehq.org
>
parent
73bb1f66
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
52 additions
and
6 deletions
+52
-6
regedit.c
programs/regedit/tests/regedit.c
+52
-6
No files found.
programs/regedit/tests/regedit.c
View file @
03a9bf4f
...
@@ -104,6 +104,7 @@ static BOOL import_reg(unsigned line, const char *contents, BOOL unicode)
...
@@ -104,6 +104,7 @@ static BOOL import_reg(unsigned line, const char *contents, BOOL unicode)
#define TODO_REG_TYPE (0x0001u)
#define TODO_REG_TYPE (0x0001u)
#define TODO_REG_SIZE (0x0002u)
#define TODO_REG_SIZE (0x0002u)
#define TODO_REG_DATA (0x0004u)
#define TODO_REG_DATA (0x0004u)
#define TODO_REG_COMPARE (0x0008u)
/* verify_reg() adapted from programs/reg/tests/reg.c */
/* verify_reg() adapted from programs/reg/tests/reg.c */
#define verify_reg(k,v,t,d,s,todo) verify_reg_(__LINE__,k,v,t,d,s,todo)
#define verify_reg(k,v,t,d,s,todo) verify_reg_(__LINE__,k,v,t,d,s,todo)
...
@@ -3326,8 +3327,8 @@ static void test_value_deletion_unicode(void)
...
@@ -3326,8 +3327,8 @@ static void test_value_deletion_unicode(void)
delete_key
(
HKEY_CURRENT_USER
,
KEY_BASE
);
delete_key
(
HKEY_CURRENT_USER
,
KEY_BASE
);
}
}
#define compare_export(f,e
) compare_export_(__LINE__,f,e
)
#define compare_export(f,e
,todo) compare_export_(__LINE__,f,e,todo
)
static
BOOL
compare_export_
(
unsigned
line
,
const
char
*
filename
,
const
char
*
expected
)
static
BOOL
compare_export_
(
unsigned
line
,
const
char
*
filename
,
const
char
*
expected
,
DWORD
todo
)
{
{
FILE
*
fp
;
FILE
*
fp
;
long
file_size
;
long
file_size
;
...
@@ -3355,7 +3356,8 @@ static BOOL compare_export_(unsigned line, const char *filename, const char *exp
...
@@ -3355,7 +3356,8 @@ static BOOL compare_export_(unsigned line, const char *filename, const char *exp
if
(
!
wstr
)
goto
exit
;
if
(
!
wstr
)
goto
exit
;
MultiByteToWideChar
(
CP_UTF8
,
0
,
expected
,
-
1
,
wstr
,
len
);
MultiByteToWideChar
(
CP_UTF8
,
0
,
expected
,
-
1
,
wstr
,
len
);
lok
(
!
lstrcmpW
(
fbuf
,
wstr
),
"export data does not match expected data
\n
"
);
todo_wine_if
(
todo
&
TODO_REG_COMPARE
)
lok
(
!
lstrcmpW
(
fbuf
,
wstr
),
"export data does not match expected data
\n
"
);
ret
=
TRUE
;
ret
=
TRUE
;
exit:
exit:
...
@@ -3410,6 +3412,18 @@ static void test_export(void)
...
@@ -3410,6 +3412,18 @@ static void test_export(void)
"@=dword:12345678
\r\n
"
"@=dword:12345678
\r\n
"
"
\"
43981
\"
=hex(abcd):56,61,6c,75,65,00
\r\n\r\n
"
;
"
\"
43981
\"
=hex(abcd):56,61,6c,75,65,00
\r\n\r\n
"
;
const
char
*
key_order_test
=
"
\xef\xbb\xbf
Windows Registry Editor Version 5.00
\r\n\r\n
"
"[HKEY_CURRENT_USER
\\
"
KEY_BASE
"]
\r\n\r\n
"
"[HKEY_CURRENT_USER
\\
"
KEY_BASE
"
\\
Subkey1]
\r\n\r\n
"
"[HKEY_CURRENT_USER
\\
"
KEY_BASE
"
\\
Subkey2]
\r\n\r\n
"
;
const
char
*
value_order_test
=
"
\xef\xbb\xbf
Windows Registry Editor Version 5.00
\r\n\r\n
"
"[HKEY_CURRENT_USER
\\
"
KEY_BASE
"]
\r\n
"
"
\"
Value 2
\"
=
\"
I was added first!
\"\r\n
"
"
\"
Value 1
\"
=
\"
I was added second!
\"\r\n\r\n
"
;
lr
=
RegDeleteKeyA
(
HKEY_CURRENT_USER
,
KEY_BASE
);
lr
=
RegDeleteKeyA
(
HKEY_CURRENT_USER
,
KEY_BASE
);
ok
(
lr
==
ERROR_SUCCESS
||
lr
==
ERROR_FILE_NOT_FOUND
,
"RegDeleteKeyA failed: %d
\n
"
,
lr
);
ok
(
lr
==
ERROR_SUCCESS
||
lr
==
ERROR_FILE_NOT_FOUND
,
"RegDeleteKeyA failed: %d
\n
"
,
lr
);
...
@@ -3417,7 +3431,7 @@ static void test_export(void)
...
@@ -3417,7 +3431,7 @@ static void test_export(void)
add_key
(
HKEY_CURRENT_USER
,
KEY_BASE
,
&
hkey
);
add_key
(
HKEY_CURRENT_USER
,
KEY_BASE
,
&
hkey
);
run_regedit_exe
(
"regedit.exe /e file.reg HKEY_CURRENT_USER
\\
"
KEY_BASE
);
run_regedit_exe
(
"regedit.exe /e file.reg HKEY_CURRENT_USER
\\
"
KEY_BASE
);
ok
(
compare_export
(
"file.reg"
,
empty_key_test
),
"compare_export() failed
\n
"
);
ok
(
compare_export
(
"file.reg"
,
empty_key_test
,
0
),
"compare_export() failed
\n
"
);
lr
=
DeleteFileA
(
"file.reg"
);
lr
=
DeleteFileA
(
"file.reg"
);
ok
(
lr
,
"DeleteFile failed: %u
\n
"
,
GetLastError
());
ok
(
lr
,
"DeleteFile failed: %u
\n
"
,
GetLastError
());
...
@@ -3428,7 +3442,7 @@ static void test_export(void)
...
@@ -3428,7 +3442,7 @@ static void test_export(void)
add_value
(
hkey
,
"String"
,
REG_SZ
,
"Your text here..."
,
18
);
add_value
(
hkey
,
"String"
,
REG_SZ
,
"Your text here..."
,
18
);
run_regedit_exe
(
"regedit.exe /e file.reg HKEY_CURRENT_USER
\\
"
KEY_BASE
);
run_regedit_exe
(
"regedit.exe /e file.reg HKEY_CURRENT_USER
\\
"
KEY_BASE
);
ok
(
compare_export
(
"file.reg"
,
simple_test
),
"compare_export() failed
\n
"
);
ok
(
compare_export
(
"file.reg"
,
simple_test
,
0
),
"compare_export() failed
\n
"
);
lr
=
DeleteFileA
(
"file.reg"
);
lr
=
DeleteFileA
(
"file.reg"
);
ok
(
lr
,
"DeleteFile failed: %u
\n
"
,
GetLastError
());
ok
(
lr
,
"DeleteFile failed: %u
\n
"
,
GetLastError
());
...
@@ -3468,13 +3482,45 @@ static void test_export(void)
...
@@ -3468,13 +3482,45 @@ static void test_export(void)
RegCloseKey
(
hkey
);
RegCloseKey
(
hkey
);
run_regedit_exe
(
"regedit.exe /e file.reg HKEY_CURRENT_USER
\\
"
KEY_BASE
);
run_regedit_exe
(
"regedit.exe /e file.reg HKEY_CURRENT_USER
\\
"
KEY_BASE
);
ok
(
compare_export
(
"file.reg"
,
complex_test
),
"compare_export() failed
\n
"
);
ok
(
compare_export
(
"file.reg"
,
complex_test
,
0
),
"compare_export() failed
\n
"
);
lr
=
DeleteFileA
(
"file.reg"
);
lr
=
DeleteFileA
(
"file.reg"
);
ok
(
lr
,
"DeleteFile failed: %u
\n
"
,
GetLastError
());
ok
(
lr
,
"DeleteFile failed: %u
\n
"
,
GetLastError
());
lr
=
delete_tree
(
HKEY_CURRENT_USER
,
KEY_BASE
);
lr
=
delete_tree
(
HKEY_CURRENT_USER
,
KEY_BASE
);
ok
(
lr
==
ERROR_SUCCESS
,
"delete_tree() failed: %d
\n
"
,
lr
);
ok
(
lr
==
ERROR_SUCCESS
,
"delete_tree() failed: %d
\n
"
,
lr
);
/* Test the export order of registry keys */
add_key
(
HKEY_CURRENT_USER
,
KEY_BASE
,
&
hkey
);
add_key
(
hkey
,
"Subkey2"
,
&
subkey
);
RegCloseKey
(
subkey
);
add_key
(
hkey
,
"Subkey1"
,
&
subkey
);
RegCloseKey
(
subkey
);
run_regedit_exe
(
"regedit.exe /e file.reg HKEY_CURRENT_USER
\\
"
KEY_BASE
);
ok
(
compare_export
(
"file.reg"
,
key_order_test
,
0
),
"compare_export() failed
\n
"
);
lr
=
DeleteFileA
(
"file.reg"
);
ok
(
lr
,
"DeleteFile failed: %u
\n
"
,
GetLastError
());
delete_key
(
hkey
,
"Subkey1"
);
delete_key
(
hkey
,
"Subkey2"
);
/* Test the export order of registry values. Windows exports registry values
* in order of creation; Wine uses alphabetical order.
*/
add_value
(
hkey
,
"Value 2"
,
REG_SZ
,
"I was added first!"
,
19
);
add_value
(
hkey
,
"Value 1"
,
REG_SZ
,
"I was added second!"
,
20
);
RegCloseKey
(
hkey
);
run_regedit_exe
(
"regedit.exe /e file.reg HKEY_CURRENT_USER
\\
"
KEY_BASE
);
ok
(
compare_export
(
"file.reg"
,
value_order_test
,
TODO_REG_COMPARE
),
"compare_export() failed
\n
"
);
lr
=
DeleteFileA
(
"file.reg"
);
ok
(
lr
,
"DeleteFile failed: %u
\n
"
,
GetLastError
());
delete_key
(
HKEY_CURRENT_USER
,
KEY_BASE
);
}
}
START_TEST
(
regedit
)
START_TEST
(
regedit
)
...
...
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