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
89ed2d97
Commit
89ed2d97
authored
Jun 16, 2006
by
Detlef Riekenberg
Committed by
Alexandre Julliard
Jun 21, 2006
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
winspool/tests: Tests for EnumForms and set an error value in our stub.
parent
2132eb54
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
111 additions
and
1 deletion
+111
-1
info.c
dlls/winspool.drv/info.c
+2
-0
info.c
dlls/winspool.drv/tests/info.c
+109
-1
No files found.
dlls/winspool.drv/info.c
View file @
89ed2d97
...
@@ -5430,6 +5430,7 @@ BOOL WINAPI EnumFormsA( HANDLE hPrinter, DWORD Level, LPBYTE pForm,
...
@@ -5430,6 +5430,7 @@ BOOL WINAPI EnumFormsA( HANDLE hPrinter, DWORD Level, LPBYTE pForm,
DWORD
cbBuf
,
LPDWORD
pcbNeeded
,
LPDWORD
pcReturned
)
DWORD
cbBuf
,
LPDWORD
pcbNeeded
,
LPDWORD
pcReturned
)
{
{
FIXME
(
"%p %lx %p %lx %p %p
\n
"
,
hPrinter
,
Level
,
pForm
,
cbBuf
,
pcbNeeded
,
pcReturned
);
FIXME
(
"%p %lx %p %lx %p %p
\n
"
,
hPrinter
,
Level
,
pForm
,
cbBuf
,
pcbNeeded
,
pcReturned
);
SetLastError
(
ERROR_CALL_NOT_IMPLEMENTED
);
return
FALSE
;
return
FALSE
;
}
}
...
@@ -5440,6 +5441,7 @@ BOOL WINAPI EnumFormsW( HANDLE hPrinter, DWORD Level, LPBYTE pForm,
...
@@ -5440,6 +5441,7 @@ BOOL WINAPI EnumFormsW( HANDLE hPrinter, DWORD Level, LPBYTE pForm,
DWORD
cbBuf
,
LPDWORD
pcbNeeded
,
LPDWORD
pcReturned
)
DWORD
cbBuf
,
LPDWORD
pcbNeeded
,
LPDWORD
pcReturned
)
{
{
FIXME
(
"%p %lx %p %lx %p %p
\n
"
,
hPrinter
,
Level
,
pForm
,
cbBuf
,
pcbNeeded
,
pcReturned
);
FIXME
(
"%p %lx %p %lx %p %p
\n
"
,
hPrinter
,
Level
,
pForm
,
cbBuf
,
pcbNeeded
,
pcReturned
);
SetLastError
(
ERROR_CALL_NOT_IMPLEMENTED
);
return
FALSE
;
return
FALSE
;
}
}
...
...
dlls/winspool.drv/tests/info.c
View file @
89ed2d97
...
@@ -400,6 +400,110 @@ static void test_DeleteMonitor(void)
...
@@ -400,6 +400,110 @@ static void test_DeleteMonitor(void)
DeleteMonitorA
(
NULL
,
entry
->
env
,
winetest_monitor
);
DeleteMonitorA
(
NULL
,
entry
->
env
,
winetest_monitor
);
}
}
/* ######## */
static
void
test_EnumForms
(
LPSTR
pName
)
{
DWORD
res
;
HANDLE
hprinter
=
0
;
LPBYTE
buffer
;
DWORD
cbBuf
;
DWORD
pcbNeeded
;
DWORD
pcReturned
;
DWORD
level
;
res
=
OpenPrinter
(
pName
,
&
hprinter
,
NULL
);
RETURN_ON_DEACTIVATED_SPOOLER
(
res
)
if
(
!
res
||
!
hprinter
)
{
/* Open the local Prinserver is not supported on win9x */
if
(
pName
)
trace
(
"Failed to open '%s', skiping the test
\n
"
,
pName
);
return
;
}
/* valid levels are 1 and 2 */
for
(
level
=
0
;
level
<
4
;
level
++
)
{
cbBuf
=
0xdeadbeef
;
pcReturned
=
0xdeadbeef
;
SetLastError
(
0xdeadbeef
);
res
=
EnumFormsA
(
hprinter
,
level
,
NULL
,
0
,
&
cbBuf
,
&
pcReturned
);
/* EnumForms is not implemented in win9x */
if
(
!
res
&&
(
GetLastError
()
==
ERROR_CALL_NOT_IMPLEMENTED
))
continue
;
/* EnumForms for the Server not implemented on all NT-Versions */
if
(
!
res
&&
(
GetLastError
()
==
ERROR_INVALID_HANDLE
)
&&
!
pName
)
continue
;
/* Level 2 for EnumForms is not supported on all systems */
if
(
!
res
&&
(
GetLastError
()
==
ERROR_INVALID_LEVEL
)
&&
(
level
==
2
))
continue
;
/* use only a short test, when we test with an invalid level */
if
(
!
level
||
(
level
>
2
))
{
ok
(
(
!
res
&&
(
GetLastError
()
==
ERROR_INVALID_LEVEL
))
||
(
res
&&
(
pcReturned
==
0
)),
"(%ld) returned %ld with %ld and 0x%08lx (expected '0' with "
\
"ERROR_INVALID_LEVEL or '!=0' and 0x0)
\n
"
,
level
,
res
,
GetLastError
(),
pcReturned
);
continue
;
}
ok
((
!
res
)
&&
(
GetLastError
()
==
ERROR_INSUFFICIENT_BUFFER
),
"(%ld) returned %ld with %ld (expected '0' with "
\
"ERROR_INSUFFICIENT_BUFFER)
\n
"
,
level
,
res
,
GetLastError
());
buffer
=
HeapAlloc
(
GetProcessHeap
(),
0
,
cbBuf
*
2
);
if
(
buffer
==
NULL
)
continue
;
SetLastError
(
0xdeadbeef
);
res
=
EnumFormsA
(
hprinter
,
level
,
buffer
,
cbBuf
,
&
pcbNeeded
,
&
pcReturned
);
ok
(
res
,
"(%ld) returned %ld with %ld (expected '!=0')
\n
"
,
level
,
res
,
GetLastError
());
/* We can dump the returned Data here */
SetLastError
(
0xdeadbeef
);
res
=
EnumFormsA
(
hprinter
,
level
,
buffer
,
cbBuf
+
1
,
&
pcbNeeded
,
&
pcReturned
);
ok
(
res
,
"(%ld) returned %ld with %ld (expected '!=0')
\n
"
,
level
,
res
,
GetLastError
());
SetLastError
(
0xdeadbeef
);
res
=
EnumFormsA
(
hprinter
,
level
,
buffer
,
cbBuf
-
1
,
&
pcbNeeded
,
&
pcReturned
);
ok
(
!
res
&&
(
GetLastError
()
==
ERROR_INSUFFICIENT_BUFFER
),
"(%ld) returned %ld with %ld (expected '0' with "
\
"ERROR_INSUFFICIENT_BUFFER)
\n
"
,
level
,
res
,
GetLastError
());
SetLastError
(
0xdeadbeef
);
res
=
EnumFormsA
(
hprinter
,
level
,
NULL
,
cbBuf
,
&
pcbNeeded
,
&
pcReturned
);
ok
(
!
res
&&
(
GetLastError
()
==
ERROR_INVALID_USER_BUFFER
)
,
"(%ld) returned %ld with %ld (expected '0' with "
\
"ERROR_INVALID_USER_BUFFER)
\n
"
,
level
,
res
,
GetLastError
());
SetLastError
(
0xdeadbeef
);
res
=
EnumFormsA
(
hprinter
,
level
,
buffer
,
cbBuf
,
NULL
,
&
pcReturned
);
ok
(
!
res
&&
(
GetLastError
()
==
RPC_X_NULL_REF_POINTER
)
,
"(%ld) returned %ld with %ld (expected '0' with "
\
"RPC_X_NULL_REF_POINTER)
\n
"
,
level
,
res
,
GetLastError
());
SetLastError
(
0xdeadbeef
);
res
=
EnumFormsA
(
hprinter
,
level
,
buffer
,
cbBuf
,
&
pcbNeeded
,
NULL
);
ok
(
!
res
&&
(
GetLastError
()
==
RPC_X_NULL_REF_POINTER
)
,
"(%ld) returned %ld with %ld (expected '0' with "
\
"RPC_X_NULL_REF_POINTER)
\n
"
,
level
,
res
,
GetLastError
());
SetLastError
(
0xdeadbeef
);
res
=
EnumFormsA
(
0
,
level
,
buffer
,
cbBuf
,
&
pcbNeeded
,
&
pcReturned
);
ok
(
!
res
&&
(
GetLastError
()
==
ERROR_INVALID_HANDLE
)
,
"(%ld) returned %ld with %ld (expected '0' with "
\
"ERROR_INVALID_HANDLE)
\n
"
,
level
,
res
,
GetLastError
());
HeapFree
(
GetProcessHeap
(),
0
,
buffer
);
}
/* for(level ... */
ClosePrinter
(
hprinter
);
}
/* ########################### */
/* ########################### */
...
@@ -1288,15 +1392,19 @@ static void test_DocumentProperties(void)
...
@@ -1288,15 +1392,19 @@ static void test_DocumentProperties(void)
START_TEST
(
info
)
START_TEST
(
info
)
{
{
LPSTR
default_printer
;
hwinspool
=
GetModuleHandleA
(
"winspool.drv"
);
hwinspool
=
GetModuleHandleA
(
"winspool.drv"
);
pGetDefaultPrinterA
=
(
void
*
)
GetProcAddress
(
hwinspool
,
"GetDefaultPrinterA"
);
pGetDefaultPrinterA
=
(
void
*
)
GetProcAddress
(
hwinspool
,
"GetDefaultPrinterA"
);
pSetDefaultPrinterA
=
(
void
*
)
GetProcAddress
(
hwinspool
,
"SetDefaultPrinterA"
);
pSetDefaultPrinterA
=
(
void
*
)
GetProcAddress
(
hwinspool
,
"SetDefaultPrinterA"
);
find_default_printer
();
default_printer
=
find_default_printer
();
test_AddMonitor
();
test_AddMonitor
();
test_DeleteMonitor
();
test_DeleteMonitor
();
test_DocumentProperties
();
test_DocumentProperties
();
test_EnumForms
(
NULL
);
if
(
default_printer
)
test_EnumForms
(
default_printer
);
test_EnumMonitors
();
test_EnumMonitors
();
test_GetDefaultPrinter
();
test_GetDefaultPrinter
();
test_GetPrinterDriverDirectory
();
test_GetPrinterDriverDirectory
();
...
...
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