2 * EGLib Unit Group/Test Runners
5 * Aaron Bockover (abockover@novell.com)
7 * (C) 2006 Novell, Inc.
9 * Permission is hereby granted, free of charge, to any person obtaining
10 * a copy of this software and associated documentation files (the
11 * "Software"), to deal in the Software without restriction, including
12 * without limitation the rights to use, copy, modify, merge, publish,
13 * distribute, sublicense, and/or sell copies of the Software, and to
14 * permit persons to whom the Software is furnished to do so, subject to
15 * the following conditions:
17 * The above copyright notice and this permission notice shall be
18 * included in all copies or substantial portions of the Software.
20 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
21 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
22 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
23 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
24 * LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
25 * OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
26 * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
38 static gchar *last_result = NULL;
41 run_test(Test *test, gchar **result_out)
45 if((result = test->handler()) == NULL) {
55 run_group(Group *group, gint iterations, gboolean quiet, gboolean time)
57 Test *tests = group->handler();
58 gint i, j, passed = 0;
59 gdouble start_time_group, start_time_test;
63 printf("[%s] (%dx)\n", group->name, iterations);
65 printf("[%s]\n", group->name);
69 start_time_group = get_timestamp();
71 for(i = 0; tests[i].name != NULL; i++) {
76 printf(" %s: ", tests[i].name);
79 start_time_test = get_timestamp();
81 for(j = 0; j < iterations; j++) {
82 iter_pass = run_test(&(tests[i]), &result);
92 printf("OK (%g)\n", get_timestamp() - start_time_test);
99 printf("FAILED (%s)\n", result);
102 if(last_result == result) {
110 gdouble pass_percentage = ((gdouble)passed / (gdouble)i) * 100.0;
112 printf(" %d / %d (%g%%, %g)\n", passed, i,
113 pass_percentage, get_timestamp() - start_time_group);
115 printf(" %d / %d (%g%%)\n", passed, i, pass_percentage);
123 FAILED(const gchar *format, ...)
129 va_start(args, format);
130 n = vasprintf(&ret, format, args);
146 gettimeofday(&tp, NULL);
147 return (gdouble)tp.tv_sec + (1.e-6) * tp.tv_usec;