=?UTF-8?Q?Bernhard=20=C3=9Cbelacker=20?=: services/tests: Retrieve monitor information when executed as service.
Alexandre Julliard
julliard at winehq.org
Thu Oct 4 17:14:44 CDT 2018
Module: wine
Branch: master
Commit: a8a2c0b9c5873e73949b9003480258b0766f4f75
URL: https://source.winehq.org/git/wine.git/?a=commit;h=a8a2c0b9c5873e73949b9003480258b0766f4f75
Author: Bernhard Übelacker <bernhardu at mailbox.org>
Date: Tue Oct 2 16:27:42 2018 +0200
services/tests: Retrieve monitor information when executed as service.
Wine-Bug: https://bugs.winehq.org/show_bug.cgi?id=43187
Signed-off-by: Bernhard Übelacker <bernhardu at mailbox.org>
Signed-off-by: Jacek Caban <jacek at codeweavers.com>
Signed-off-by: Alexandre Julliard <julliard at winehq.org>
---
programs/services/tests/service.c | 48 +++++++++++++++++++++++++++++++++++++++
1 file changed, 48 insertions(+)
diff --git a/programs/services/tests/service.c b/programs/services/tests/service.c
index 728d515..c68d37a 100644
--- a/programs/services/tests/service.c
+++ b/programs/services/tests/service.c
@@ -35,6 +35,8 @@ static SERVICE_STATUS_HANDLE service_handle;
/* Service process global variables */
static HANDLE service_stop_event;
+static int monitor_count;
+
static void send_msg(const char *type, const char *msg)
{
DWORD written = 0;
@@ -127,6 +129,51 @@ static void test_create_window(void)
service_ok(r, "DestroyWindow failed: %08x\n", GetLastError());
}
+static BOOL CALLBACK monitor_enum_proc(HMONITOR hmon, HDC hdc, LPRECT lprc, LPARAM lparam)
+{
+ BOOL r;
+ MONITORINFOEXA mi;
+
+ service_ok(hmon != NULL, "Unexpected hmon=%#x\n", hmon);
+
+ monitor_count++;
+
+ mi.cbSize = sizeof(mi);
+
+ SetLastError(0xdeadbeef);
+ r = GetMonitorInfoA(NULL, (MONITORINFO*)&mi);
+ service_ok(GetLastError() == ERROR_INVALID_MONITOR_HANDLE, "Unexpected GetLastError: %#x.\n", GetLastError());
+ service_ok(!r, "GetMonitorInfo with NULL HMONITOR succeeded.\n");
+
+ r = GetMonitorInfoA(hmon, (MONITORINFO*)&mi);
+ service_ok(r, "GetMonitorInfo failed.\n");
+
+ service_ok(mi.rcMonitor.left == 0 && mi.rcMonitor.top == 0 && mi.rcMonitor.right >= 640 && mi.rcMonitor.bottom >= 480,
+ "Unexepected monitor rcMonitor values: {%d,%d,%d,%d}\n",
+ mi.rcMonitor.left, mi.rcMonitor.top, mi.rcMonitor.right, mi.rcMonitor.bottom);
+
+ service_ok(mi.rcWork.left == 0 && mi.rcWork.top == 0 && mi.rcWork.right >= 640 && mi.rcWork.bottom >= 480,
+ "Unexepected monitor rcWork values: {%d,%d,%d,%d}\n",
+ mi.rcWork.left, mi.rcWork.top, mi.rcWork.right, mi.rcWork.bottom);
+
+ service_ok(!strcmp(mi.szDevice, "WinDisc") || !strcmp(mi.szDevice, "\\\\.\\DISPLAY1"),
+ "Unexpected szDevice received: %s\n", mi.szDevice);
+
+ service_ok(mi.dwFlags == MONITORINFOF_PRIMARY, "Unexpected secondary monitor info.\n");
+
+ return TRUE;
+}
+
+/* query informations monitor information, even in non-interactive services */
+static void test_monitors(void)
+{
+ BOOL r;
+
+ r = EnumDisplayMonitors(0, 0, monitor_enum_proc, 0);
+ service_ok(r, "EnumDisplayMonitors failed.\n");
+ service_ok(monitor_count == 1, "Callback got called less or more than once. %d\n", monitor_count);
+}
+
static DWORD WINAPI service_handler(DWORD ctrl, DWORD event_type, void *event_data, void *context)
{
SERVICE_STATUS status;
@@ -151,6 +198,7 @@ static DWORD WINAPI service_handler(DWORD ctrl, DWORD event_type, void *event_da
case 128:
test_winstation();
test_create_window();
+ test_monitors();
service_event("CUSTOM");
return 0xdeadbeef;
default:
More information about the wine-cvs
mailing list