On 2/18/19 6:49 AM, Isira Seneviratne wrote:
> From 462243a2e8860ebbac2bedb90fa6cb97050a6080 Mon Sep 17 00:00:00 2001
> From: Isira Seneviratne <isirasen96@gmail.com>
> Date: Sun, 16 Dec 2018 14:59:20 +0530
> Subject: [PATCH v5] winetest: Add GUI to display results of individual tests.
>
> This patch adds a listview control displaying the results of each
> test, together with the component being tested.
>
> Advancing the file pointer of the log file by 1 eliminates most of the
> duplicate test entries displayed with the previous revision, except for
> advapi32:security tests, which has two entries due to those tests using
> two threads.
What you want to do about this is to loop until you find the last line
matching
that process, and then add it to the listview. That's what the
test.winehq.org
dissect script does.
Is there a way for me to see how this script works?
>
> Signed-off-by: Isira Seneviratne <isirasen96@gmail.com>
> ---
> programs/winetest/gui.c | 25 +++++++++++++--
> programs/winetest/main.c | 60 +++++++++++++++++++++++++++++++++--
> programs/winetest/resource.h | 2 ++
> programs/winetest/winetest.h | 4 +++
> programs/winetest/winetest.rc | 20 +++++++-----
> 5 files changed, 99 insertions(+), 12 deletions(-)
>
> diff --git a/programs/winetest/gui.c b/programs/winetest/gui.c
> index bda00f3707..607918bb08 100644
> --- a/programs/winetest/gui.c
> +++ b/programs/winetest/gui.c
> @@ -2,6 +2,7 @@
> * GUI support
> *
> * Copyright 2004 Ferenc Wagner
> + * Copyright 2018-2019 Isira Seneviratne
> *
> * This library is free software; you can redistribute it and/or
> * modify it under the terms of the GNU Lesser General Public
> @@ -43,6 +44,9 @@ static int progressGroup;
>
> static WNDPROC DefEditProc;
>
> +/* List view handle */
> +HWND res_list_view;
> +
> static int
> MBdefault (int uType)
> {
> @@ -130,7 +134,7 @@ guiStep (va_list ap)
> {
> const int pgID = IDC_ST0 + progressGroup * 2;
> char *str = vstrmake (NULL, ap);
> -
> +
> progressCurr++;
> SetDlgItemTextA (dialog, pgID, str);
> SendDlgItemMessageA(dialog, pgID+1, PBM_SETPOS,
> @@ -421,6 +425,8 @@ AboutProc (HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam)
> static INT_PTR CALLBACK
> DlgProc (HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam)
> {
> + LVCOLUMNA lvCol;
> +
> switch (msg) {
> case WM_INITDIALOG:
> SendMessageA(hwnd, WM_SETICON, ICON_SMALL,
> @@ -430,6 +436,21 @@ DlgProc (HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam)
> SendMessageA(hwnd, WM_SETICON, ICON_BIG,
> (LPARAM)LoadIconA( GetModuleHandleA(NULL), MAKEINTRESOURCEA(IDI_WINE)));
> dialog = hwnd;
> +
> + /* Initializes the list view control that the main dialog window contains */
> + res_list_view = GetDlgItem(dialog, IDD_RES_LIST);
> +
> + lvCol.mask = LVCF_FMT | LVCF_WIDTH | LVCF_TEXT | LVCF_SUBITEM;
> + lvCol.cx = 130;
> + lvCol.fmt = LVCFMT_LEFT;
> +
> + lvCol.pszText = (char *) "Component";
> + ListView_InsertColumnA(res_list_view, 0, &lvCol);
> +
> + lvCol.pszText = (char *) "No. of failures";
> + lvCol.cx = 90;
> + ListView_InsertColumnA(res_list_view, 1, &lvCol);
> +
> if (!SetEvent (initEvent)) {
> report (R_STATUS, "Can't signal main thread: %d",
> GetLastError ());
> @@ -545,7 +566,7 @@ report (enum report_type t, ...)
> }
> }
> }
> -
> +
> va_start (ap, t);
> if (t < ARRAY_SIZE(text_funcs)) ret = funcs[t](ap);
> else report (R_WARNING, "unimplemented report type: %d", t);
> diff --git a/programs/winetest/main.c b/programs/winetest/main.c
> index 3d6cc660ec..8c841ab08e 100644
> --- a/programs/winetest/main.c
> +++ b/programs/winetest/main.c
> @@ -4,6 +4,7 @@
> * Copyright 2003, 2004 Jakob Eriksson (for Solid Form Sweden AB)
> * Copyright 2003 Dimitrie O. Paun
> * Copyright 2003 Ferenc Wagner
> + * Copyright 2018-2019 Isira Seneviratne
> *
> * This library is free software; you can redistribute it and/or
> * modify it under the terms of the GNU Lesser General Public
> @@ -30,10 +31,12 @@
>
> #define COBJMACROS
> #include <stdio.h>
> +#include <string.h>
> #include <assert.h>
> #include <windows.h>
> #include <winternl.h>
> #include <mshtml.h>
> +#include <commctrl.h>
>
> #include "winetest.h"
> #include "resource.h"
> @@ -85,6 +88,9 @@ static void (WINAPI *pReleaseActCtx)(HANDLE);
> /* To store the current PATH setting (related to .NET only provided dlls) */
> static char *curpath;
>
> +/* To display the test results in a listview control */
> +static int cur_row = 0;
> +
> /* check if test is being filtered out */
> static BOOL test_filtered_out( LPCSTR module, LPCSTR testname )
> {
> @@ -533,7 +539,7 @@ static void* extract_rcdata (LPCSTR name, LPCSTR type, DWORD* size)
> HRSRC rsrc;
> HGLOBAL hdl;
> LPVOID addr;
> -
> +
> if (!(rsrc = FindResourceA(NULL, name, type)) ||
> !(*size = SizeofResource (0, rsrc)) ||
> !(hdl = LoadResource (0, rsrc)) ||
> @@ -788,12 +794,62 @@ run_test (struct wine_test* test, const char* subtest, HANDLE out_file, const ch
> }
> else
> {
> - int status;
> + int status, test_fail_count, test_count, test_todo_count, test_skipped_count;
> + int match_count;
> + char test_fail_count_str[10];
> + char buffer[1000];
> + char subtest_name[20];
> + char test_subtest_name[50];
> + char *cur_line = buffer, *next_line;
> DWORD pid, start = GetTickCount();
> + DWORD read_count;
> + LVITEMA lv_item;
> char *cmd = strmake (NULL, "%s %s", test->exename, subtest);
> +
> report (R_STEP, "Running: %s:%s", test->name, subtest);
> xprintf ("%s:%s start %s -\n", test->name, subtest, file);
> status = run_ex (cmd, out_file, tempdir, 120000, &pid);
> +
> + lv_item.mask = LVIF_TEXT;
> + lv_item.state = 0;
> + lv_item.stateMask = 0;
> +
> + SetFilePointer (out_file, -sizeof(buffer), NULL, FILE_CURRENT);
> + ReadFile (out_file, buffer, sizeof(buffer), &read_count, NULL);
> + SetFilePointer (out_file, 1, NULL, FILE_CURRENT);
This doesn't work. You're extending the file pointer 1 past the file's
actual
length, so a '\0' byte will be written. The reason this only prints out one
line of output is because the strchr() call below will break out of the
loop
after [at most] the first output report in the buffer. But that won't
necessarily be the right one. For example, if I add an artificial
failure into
advapi32:lsa, that doesn't show up in the failures column.
I think what you want to do instead is essentially the same thing as I
recommend to take care of tests that print subprocess reports: just loop
over
all report lines in the log, discarding any but the last. While you're
at it,
you should probably validate the test name from the output report
against the
name of the test you're running, in case the test crashes or hangs.
> +
> + /*
> + * Traverses the buffer line by line, reading the lines of the test output
> + * where the test results are saved.
> + */
> + while (1)
> + {
> + match_count = sscanf (cur_line, "%*x:%s %d tests executed (%d marked as todo, %d failures), %d skipped.",
> + subtest_name, &test_count, &test_todo_count, &test_fail_count, &test_skipped_count);
> +
> + if (match_count == 5)
> + {
> + sprintf (test_subtest_name, "%s:%s", test->name, subtest);
> + sprintf (test_fail_count_str, "%d", test_fail_count);
> +
> + /* Adds a single row to the list view control (component name and no. of failed tests). */
> + lv_item.iSubItem = 0;
> + lv_item.iItem = cur_row;
> + lv_item.pszText = test_subtest_name;
> + ListView_InsertItemA (res_list_view, &lv_item);
> +
> + lv_item.iSubItem = 1;
> + lv_item.pszText = test_fail_count_str;
> + ListView_SetItemA (res_list_view, &lv_item);
> +
> + cur_row++;
> + }
> + next_line = strchr (cur_line, '\n');
> + if (!next_line)
> + break;
> + cur_line = next_line+1;
> + }
> +
> heap_free (cmd);
> xprintf ("%s:%s:%04x done (%d) in %ds\n", test->name, subtest, pid, status, (GetTickCount()-start)/1000);
> if (status) failures++;
> diff --git a/programs/winetest/resource.h b/programs/winetest/resource.h
> index be71274f58..90c684e130 100644
> --- a/programs/winetest/resource.h
> +++ b/programs/winetest/resource.h
> @@ -2,6 +2,7 @@
> * Resource definitions
> *
> * Copyright 2004 Ferenc Wagner
> + * Copyright 2018-2019 Isira Seneviratne
> *
> * This library is free software; you can redistribute it and/or
> * modify it under the terms of the GNU Lesser General Public
> @@ -24,6 +25,7 @@
> #define IDD_ABOUT 101
> #define IDD_TAG 102
> #define IDD_EMAIL 103
> +#define IDD_RES_LIST 105
>
> #define IDC_STATIC -1
>
> diff --git a/programs/winetest/winetest.h b/programs/winetest/winetest.h
> index 0446ad5bdc..342e25b506 100644
> --- a/programs/winetest/winetest.h
> +++ b/programs/winetest/winetest.h
> @@ -3,6 +3,7 @@
> *
> * Copyright 2003 Dimitrie O. Paun
> * Copyright 2003 Ferenc Wagner
> + * Copyright 2018-2019 Isira Seneviratne
> *
> * This library is free software; you can redistribute it and/or
> * modify it under the terms of the GNU Lesser General Public
> @@ -74,4 +75,7 @@ int guiAskTag (void);
> int guiAskEmail (void);
> int report (enum report_type t, ...);
>
> +/* Listview handle */
> +extern HWND res_list_view;
> +
> #endif /* __WINETESTS_H */
> diff --git a/programs/winetest/winetest.rc b/programs/winetest/winetest.rc
> index a3898b6ce0..25d10505c6 100644
> --- a/programs/winetest/winetest.rc
> +++ b/programs/winetest/winetest.rc
> @@ -2,6 +2,7 @@
> * Winetest resources
> *
> * Copyright 2004 Ferenc Wagner
> + * Copyright 2018-2019 Isira Seneviratne
> *
> * This library is free software; you can redistribute it and/or
> * modify it under the terms of the GNU Lesser General Public
> @@ -48,7 +49,7 @@ BEGIN
> PUSHBUTTON "Abort", IDABORT, 85, 45, 40, 14
> END
>
> -IDD_STATUS DIALOG 0, 0, 160, 150
> +IDD_STATUS DIALOG 0, 0, 160, 275
> STYLE WS_OVERLAPPED | WS_CAPTION | WS_SYSMENU | WS_MINIMIZEBOX
> CAPTION "Wine Test Shell"
> FONT 8, "MS Shell Dlg"
> @@ -59,21 +60,24 @@ BEGIN
> CONTROL "PB1", IDC_PB1, PROGRESS_CLASSA, 0, 5, 40, 150, 10
> LTEXT "Network transfer:", IDC_ST2, 5, 55, 140, 10
> CONTROL "PB2", IDC_PB2, PROGRESS_CLASSA, 0, 5, 65, 150, 10
> -
> +
> LTEXT "Tag:", IDC_STATIC, 5, 89, 100, 10
> - EDITTEXT IDC_TAG, 25, 88, 125, 10,
> + EDITTEXT IDC_TAG, 25, 88, 130, 10,
> ES_READONLY
> LTEXT "Working directory:", IDC_STATIC, 5, 100, 100, 10
> - EDITTEXT IDC_DIR, 71, 99, 79, 10,
> + EDITTEXT IDC_DIR, 71, 99, 84, 10,
> ES_READONLY | ES_AUTOHSCROLL
> LTEXT "Output file:", IDC_STATIC, 5, 111, 100, 10
> - EDITTEXT IDC_OUT, 46, 110, 104, 10,
> + EDITTEXT IDC_OUT, 46, 110, 109, 10,
> ES_READONLY | ES_AUTOHSCROLL
>
> - DEFPUSHBUTTON "About", IDHELP, 20, 123, 30, 14
> - PUSHBUTTON "Edit", IDCANCEL, 65, 123, 30, 14,
> + CONTROL "", IDD_RES_LIST, "SysListView32", WS_CHILD | WS_VISIBLE | WS_BORDER | LVS_REPORT,
> + 5, 130, 150, 100
> +
> + DEFPUSHBUTTON "About", IDHELP, 20, 243, 30, 14
> + PUSHBUTTON "Edit", IDCANCEL, 65, 243, 30, 14,
> WS_DISABLED
> - PUSHBUTTON "Stop", IDABORT, 110, 123, 30, 14
> + PUSHBUTTON "Stop", IDABORT, 110, 243, 30, 14
>
> CONTROL "Created", IDC_SB, STATUSCLASSNAMEA, 0, 0,0,0,0
> END
> --
> 2.20.1