Commit 7ea06b59 authored by Detlef Riekenberg's avatar Detlef Riekenberg Committed by Alexandre Julliard

localspl/tests: Extend test for XcvDataPort_MonitorUI.

parent 292cb4d2
...@@ -342,7 +342,7 @@ static void test_XcvClosePort(void) ...@@ -342,7 +342,7 @@ static void test_XcvClosePort(void)
/* ########################### */ /* ########################### */
static void test_XcvDataPort(void) static void test_XcvDataPort_MonitorUI(void)
{ {
DWORD res; DWORD res;
HANDLE hXcv; HANDLE hXcv;
...@@ -363,11 +363,20 @@ static void test_XcvDataPort(void) ...@@ -363,11 +363,20 @@ static void test_XcvDataPort(void)
needed = (DWORD) 0xdeadbeef; needed = (DWORD) 0xdeadbeef;
SetLastError(0xdeadbeef); SetLastError(0xdeadbeef);
res = pXcvDataPort(hXcv, cmd_MonitorUIW, NULL, 0, NULL, 0, &needed); res = pXcvDataPort(hXcv, cmd_MonitorUIW, NULL, 0, NULL, 0, &needed);
if (res == ERROR_INVALID_PARAMETER) {
pXcvClosePort(hXcv);
skip("'MonitorUI' nor supported\n");
return;
}
ok( (res == ERROR_INSUFFICIENT_BUFFER) && (needed <= MAX_PATH), ok( (res == ERROR_INSUFFICIENT_BUFFER) && (needed <= MAX_PATH),
"returned %d with %u and 0x%x (expected 'ERROR_INSUFFICIENT_BUFFER' " "returned %d with %u and 0x%x (expected 'ERROR_INSUFFICIENT_BUFFER' "
" and '<= MAX_PATH')\n", res, GetLastError(), needed); " and '<= MAX_PATH')\n", res, GetLastError(), needed);
if (needed > MAX_PATH) goto xcv_cleanup; if (needed > MAX_PATH) {
pXcvClosePort(hXcv);
skip("buffer overflow (%u)\n", needed);
return;
}
len = needed; len = needed;
/* the command is required */ /* the command is required */
...@@ -410,6 +419,7 @@ static void test_XcvDataPort(void) ...@@ -410,6 +419,7 @@ static void test_XcvDataPort(void)
/* off by one: smaller */ /* off by one: smaller */
/* the buffer is not modified for NT4, w2k, XP */
needed = (DWORD) 0xdeadbeef; needed = (DWORD) 0xdeadbeef;
SetLastError(0xdeadbeef); SetLastError(0xdeadbeef);
res = pXcvDataPort(hXcv, cmd_MonitorUIW, NULL, 0, buffer, len-1, &needed); res = pXcvDataPort(hXcv, cmd_MonitorUIW, NULL, 0, buffer, len-1, &needed);
...@@ -424,7 +434,25 @@ static void test_XcvDataPort(void) ...@@ -424,7 +434,25 @@ static void test_XcvDataPort(void)
ok( res == ERROR_SUCCESS, "returned %d with %u and 0x%x " ok( res == ERROR_SUCCESS, "returned %d with %u and 0x%x "
"(expected 'ERROR_SUCCESS')\n", res, GetLastError(), needed); "(expected 'ERROR_SUCCESS')\n", res, GetLastError(), needed);
xcv_cleanup:
pXcvClosePort(hXcv);
/* small check without access-rights: */
hXcv = (HANDLE) 0xdeadbeef;
SetLastError(0xdeadbeef);
res = pXcvOpenPort(emptyW, 0, &hXcv);
ok(res, "returned %d with %u and %p (expected '!= 0')\n", res, GetLastError(), hXcv);
if (!res) return;
/* The ACCESS_MASK is ignored for "MonitorUI" */
memset(buffer, 0, len);
needed = (DWORD) 0xdeadbeef;
SetLastError(0xdeadbeef);
res = pXcvDataPort(hXcv, cmd_MonitorUIW, NULL, 0, buffer, sizeof(buffer), &needed);
ok( res == ERROR_SUCCESS, "returned %d with %u and 0x%x "
"(expected 'ERROR_SUCCESS')\n", res, GetLastError(), needed);
pXcvClosePort(hXcv); pXcvClosePort(hXcv);
} }
...@@ -574,6 +602,6 @@ START_TEST(localmon) ...@@ -574,6 +602,6 @@ START_TEST(localmon)
test_DeletePort(); test_DeletePort();
test_EnumPorts(); test_EnumPorts();
test_XcvClosePort(); test_XcvClosePort();
test_XcvDataPort(); test_XcvDataPort_MonitorUI();
test_XcvOpenPort(); test_XcvOpenPort();
} }
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