Commit 461b2a75 authored by Detlef Riekenberg's avatar Detlef Riekenberg Committed by Alexandre Julliard

winspool/tests: More tests for OpenPrinter.

parent 351106f5
...@@ -792,9 +792,11 @@ static void test_OpenPrinter(void) ...@@ -792,9 +792,11 @@ static void test_OpenPrinter(void)
hprinter = (HANDLE) MAGIC_DEAD; hprinter = (HANDLE) MAGIC_DEAD;
SetLastError(MAGIC_DEAD); SetLastError(MAGIC_DEAD);
res = OpenPrinter(NULL, &hprinter, &defaults); res = OpenPrinter(NULL, &hprinter, &defaults);
todo_wine {
ok(!res && GetLastError() == ERROR_ACCESS_DENIED, ok(!res && GetLastError() == ERROR_ACCESS_DENIED,
"returned %ld with %ld (expected '0' with ERROR_ACCESS_DENIED)\n", "returned %ld with %ld (expected '0' with ERROR_ACCESS_DENIED)\n",
res, GetLastError()); res, GetLastError());
}
if (res) ClosePrinter(hprinter); if (res) ClosePrinter(hprinter);
} }
...@@ -828,6 +830,17 @@ static void test_OpenPrinter(void) ...@@ -828,6 +830,17 @@ static void test_OpenPrinter(void)
"ERROR_INVALID_PRINTER_NAME)\n", res, GetLastError()); "ERROR_INVALID_PRINTER_NAME)\n", res, GetLastError());
if(res) ClosePrinter(hprinter); if(res) ClosePrinter(hprinter);
hprinter = (HANDLE) MAGIC_DEAD;
SetLastError(MAGIC_DEAD);
res = OpenPrinter("", &hprinter, NULL);
/* NT: ERROR_INVALID_PRINTER_NAME, 9x: ERROR_INVALID_PARAMETER */
ok( !res &&
((GetLastError() == ERROR_INVALID_PRINTER_NAME) ||
(GetLastError() == ERROR_INVALID_PARAMETER) ),
"returned %ld with %ld (expected '0' with: ERROR_INVALID_PRINTER_NAME" \
" or ERROR_INVALID_PARAMETER)\n", res, GetLastError());
if(res) ClosePrinter(hprinter);
/* Get Handle for the default Printer */ /* Get Handle for the default Printer */
if ((default_printer = find_default_printer())) if ((default_printer = find_default_printer()))
...@@ -837,12 +850,19 @@ static void test_OpenPrinter(void) ...@@ -837,12 +850,19 @@ static void test_OpenPrinter(void)
res = OpenPrinter(default_printer, &hprinter, NULL); res = OpenPrinter(default_printer, &hprinter, NULL);
if((!res) && (GetLastError() == RPC_S_SERVER_UNAVAILABLE)) if((!res) && (GetLastError() == RPC_S_SERVER_UNAVAILABLE))
{ {
trace("The Service 'Spooler' is required for '%s'\n", default_printer); trace("The Service 'Spooler' is required for '%s'\n", default_printer);
return; return;
} }
ok(res, "returned %ld with %ld (expected '!=0')\n", res, GetLastError()); ok(res, "returned %ld with %ld (expected '!=0')\n", res, GetLastError());
if(res) ClosePrinter(hprinter); if(res) ClosePrinter(hprinter);
SetLastError(MAGIC_DEAD);
res = OpenPrinter(default_printer, NULL, NULL);
/* NT: FALSE with ERROR_INVALID_PARAMETER, 9x: TRUE */
ok(res || (GetLastError() == ERROR_INVALID_PARAMETER),
"returned %ld with %ld (expected '!=0' or '0' with " \
"ERROR_INVALID_PARAMETER)\n", res, GetLastError());
defaults.pDatatype=NULL; defaults.pDatatype=NULL;
defaults.pDevMode=NULL; defaults.pDevMode=NULL;
defaults.DesiredAccess=0; defaults.DesiredAccess=0;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment