Qian Hong : user32/tests: Added input desktop tests on different winstations.
Alexandre Julliard
julliard at winehq.org
Tue Oct 8 15:41:06 CDT 2013
Module: wine
Branch: master
Commit: 43e1df02d2fdb0f4a3aa3d273e9666dfe5f74b26
URL: http://source.winehq.org/git/wine.git/?a=commit;h=43e1df02d2fdb0f4a3aa3d273e9666dfe5f74b26
Author: Qian Hong <qhong at codeweavers.com>
Date: Tue Oct 8 11:40:13 2013 +0800
user32/tests: Added input desktop tests on different winstations.
---
dlls/user32/tests/winstation.c | 66 ++++++++++++++++++++++++++++++++++++++++
1 files changed, 66 insertions(+), 0 deletions(-)
diff --git a/dlls/user32/tests/winstation.c b/dlls/user32/tests/winstation.c
index 560b34f..d9b8a0e 100644
--- a/dlls/user32/tests/winstation.c
+++ b/dlls/user32/tests/winstation.c
@@ -652,6 +652,71 @@ todo_wine
ok(ret, "CloseDesktop failed!\n");
}
+static void test_inputdesktop2(void)
+{
+ HWINSTA w1, w2;
+ HDESK thread_desk, new_desk, input_desk, hdesk;
+ DWORD ret;
+
+ thread_desk = GetThreadDesktop(GetCurrentThreadId());
+ ok(thread_desk != NULL, "GetThreadDesktop failed!\n");
+ w1 = GetProcessWindowStation();
+ ok(w1 != NULL, "GetProcessWindowStation failed!\n");
+ w2 = CreateWindowStation("winsta_test", 0, WINSTA_ALL_ACCESS, NULL);
+ ok(w2 != NULL, "CreateWindowStation failed!\n");
+ ret = EnumDesktopsA(GetProcessWindowStation(), desktop_callbackA, 0);
+ ok(!ret, "EnumDesktopsA failed!\n");
+ input_desk = OpenInputDesktop(0, FALSE, DESKTOP_ALL_ACCESS);
+todo_wine
+ ok(input_desk != NULL, "OpenInputDesktop failed!\n");
+ ret = CloseDesktop(input_desk);
+todo_wine
+ ok(ret, "CloseDesktop failed!\n");
+
+ ret = SetProcessWindowStation(w2);
+ ok(ret, "SetProcessWindowStation failed!\n");
+ hdesk = GetThreadDesktop(GetCurrentThreadId());
+ ok(hdesk != NULL, "GetThreadDesktop failed!\n");
+ ok(hdesk == thread_desk, "thread desktop should not change after winstation changed!\n");
+ ret = EnumDesktopsA(GetProcessWindowStation(), desktop_callbackA, 0);
+
+ new_desk = CreateDesktop("desk_test", NULL, NULL, 0, DESKTOP_ALL_ACCESS, NULL);
+ ok(new_desk != NULL, "CreateDesktop failed!\n");
+ ret = EnumDesktopsA(GetProcessWindowStation(), desktop_callbackA, 0);
+ ok(!ret, "EnumDesktopsA failed!\n");
+ SetLastError(0xdeadbeef);
+ input_desk = OpenInputDesktop(0, FALSE, DESKTOP_ALL_ACCESS);
+ ok(input_desk == NULL, "OpenInputDesktop should fail on non default winstation!\n");
+todo_wine
+ ok(GetLastError() == ERROR_INVALID_FUNCTION || broken(GetLastError() == 0xdeadbeef), "last error %08x\n", GetLastError());
+
+ hdesk = OpenDesktop("desk_test", 0, TRUE, DESKTOP_ALL_ACCESS);
+ ok(hdesk != NULL, "OpenDesktop failed!\n");
+ SetLastError(0xdeadbeef);
+ ret = SwitchDesktop(hdesk);
+todo_wine
+ ok(!ret, "Switch to desktop belong to non default winstation should fail!\n");
+todo_wine
+ ok(GetLastError() == ERROR_ACCESS_DENIED || broken(GetLastError() == 0xdeadbeef), "last error %08x\n", GetLastError());
+ ret = SetThreadDesktop(hdesk);
+ ok(ret, "SetThreadDesktop failed!\n");
+
+ /* clean side effect */
+ ret = SetThreadDesktop(thread_desk);
+todo_wine
+ ok(ret, "SetThreadDesktop should success even desktop is not belong to process winstation!\n");
+ ret = SetProcessWindowStation(w1);
+ ok(ret, "SetProcessWindowStation failed!\n");
+ ret = SetThreadDesktop(thread_desk);
+ ok(ret, "SetThreadDesktop failed!\n");
+ ret = CloseWindowStation(w2);
+ ok(ret, "CloseWindowStation failed!\n");
+ ret = CloseDesktop(new_desk);
+ ok(ret, "CloseDesktop failed!\n");
+ ret = CloseDesktop(hdesk);
+ ok(ret, "CloseDesktop failed!\n");
+}
+
START_TEST(winstation)
{
/* Check whether this platform supports WindowStation calls */
@@ -665,6 +730,7 @@ START_TEST(winstation)
}
test_inputdesktop();
+ test_inputdesktop2();
test_enumstations();
test_enumdesktops();
test_handles();
More information about the wine-cvs
mailing list