Line data Source code
1 : /*
2 : Unix SMB/CIFS implementation.
3 : Samba utility functions
4 : Copyright (C) Jelmer Vernooij <jelmer@samba.org> 2008
5 :
6 : This program is free software; you can redistribute it and/or modify
7 : it under the terms of the GNU General Public License as published by
8 : the Free Software Foundation; either version 3 of the License, or
9 : (at your option) any later version.
10 :
11 : This program is distributed in the hope that it will be useful,
12 : but WITHOUT ANY WARRANTY; without even the implied warranty of
13 : MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 : GNU General Public License for more details.
15 :
16 : You should have received a copy of the GNU General Public License
17 : along with this program. If not, see <http://www.gnu.org/licenses/>.
18 : */
19 :
20 : #include "includes.h"
21 : #include "lib/torture/torture.h"
22 :
23 38246 : static void subunit_send_event(char const * const event,
24 : char const * const name,
25 : char const * const details)
26 : {
27 38246 : if (NULL == details) {
28 32559 : printf("%s: %s\n", event, name);
29 : } else {
30 5687 : printf("%s: %s [\n", event, name);
31 5687 : printf("%s", details);
32 5687 : if (details[strlen(details) - 1] != '\n')
33 4557 : puts("");
34 5687 : puts("]");
35 : }
36 38246 : fflush(stdout);
37 38246 : }
38 :
39 5579 : static void torture_subunit_suite_start(struct torture_context *ctx,
40 : struct torture_suite *suite)
41 : {
42 5579 : }
43 :
44 40512 : static void torture_subunit_report_time(struct torture_context *tctx)
45 : {
46 3031 : struct timespec tp;
47 3031 : struct tm *tmp;
48 3031 : char timestr[200];
49 40512 : if (clock_gettime(CLOCK_REALTIME, &tp) != 0) {
50 0 : perror("clock_gettime");
51 0 : return;
52 : }
53 :
54 40512 : tmp = gmtime(&tp.tv_sec);
55 40512 : if (!tmp) {
56 0 : perror("gmtime");
57 0 : return;
58 : }
59 :
60 40512 : if (strftime(timestr, sizeof(timestr), "%Y-%m-%d %H:%M:%S", tmp) <= 0) {
61 0 : perror("strftime");
62 0 : return;
63 : }
64 :
65 40512 : printf("time: %s.%06ld\n", timestr, tp.tv_nsec / 1000);
66 : }
67 :
68 19123 : static void torture_subunit_test_start(struct torture_context *context,
69 : struct torture_tcase *tcase,
70 : struct torture_test *test)
71 : {
72 19123 : char *fullname = torture_subunit_test_name(context, context->active_tcase, context->active_test);
73 19123 : subunit_send_event("test", fullname, NULL);
74 19123 : torture_subunit_report_time(context);
75 19123 : talloc_free(fullname);
76 19123 : }
77 :
78 19123 : static void torture_subunit_test_result(struct torture_context *context,
79 : enum torture_result res, const char *reason)
80 : {
81 19123 : char *fullname = torture_subunit_test_name(context, context->active_tcase, context->active_test);
82 19123 : const char *result_str = "unknown";
83 19123 : torture_subunit_report_time(context);
84 19123 : switch (res) {
85 13436 : case TORTURE_OK:
86 13436 : result_str = "success";
87 13436 : break;
88 1751 : case TORTURE_FAIL:
89 1751 : result_str = "failure";
90 1751 : break;
91 0 : case TORTURE_ERROR:
92 0 : result_str = "error";
93 0 : break;
94 3936 : case TORTURE_SKIP:
95 3936 : result_str = "skip";
96 3936 : break;
97 : }
98 19123 : subunit_send_event(result_str, fullname, reason);
99 19123 : talloc_free(fullname);
100 19123 : }
101 :
102 191060 : static void torture_subunit_comment(struct torture_context *test,
103 : const char *comment)
104 : {
105 191060 : fprintf(stderr, "%s", comment);
106 191060 : }
107 :
108 8937 : static void torture_subunit_warning(struct torture_context *test,
109 : const char *comment)
110 : {
111 8937 : fprintf(stderr, "WARNING!: %s\n", comment);
112 8937 : }
113 :
114 14009 : static void torture_subunit_progress(struct torture_context *tctx, int offset, enum torture_progress_whence whence)
115 : {
116 14009 : switch (whence) {
117 5413 : case TORTURE_PROGRESS_SET:
118 5579 : printf("progress: %d\n", offset);
119 5413 : break;
120 0 : case TORTURE_PROGRESS_CUR:
121 0 : printf("progress: %+-d\n", offset);
122 0 : break;
123 4129 : case TORTURE_PROGRESS_POP:
124 4215 : printf("progress: pop\n");
125 4129 : break;
126 4129 : case TORTURE_PROGRESS_PUSH:
127 4215 : printf("progress: push\n");
128 4129 : break;
129 0 : default:
130 0 : fprintf(stderr, "Invalid call to progress()\n");
131 0 : break;
132 : }
133 14009 : }
134 :
135 : const struct torture_ui_ops torture_subunit_ui_ops = {
136 : .comment = torture_subunit_comment,
137 : .warning = torture_subunit_warning,
138 : .test_start = torture_subunit_test_start,
139 : .test_result = torture_subunit_test_result,
140 : .suite_start = torture_subunit_suite_start,
141 : .progress = torture_subunit_progress,
142 : .report_time = torture_subunit_report_time,
143 : };
|