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.
39 #ifdef HAVE_SYS_TIME_H
48 extern gint global_passed
, global_tests
;
50 #ifndef HAVE_VASPRINTF
51 /* systen does not provide a vasprintf function, use the one
52 provided within eglib itself */
53 extern int vasprintf(char **ret
, const char *format
, va_list ap
);
56 static gchar
*last_result
= NULL
;
59 run_test(Test
*test
, gchar
**result_out
)
63 if((result
= test
->handler()) == NULL
) {
73 run_group(Group
*group
, gint iterations
, gboolean quiet
,
74 gboolean time
, gchar
*tests_to_run_s
)
76 Test
*tests
= group
->handler();
77 gint i
, j
, passed
= 0, total
= 0;
78 gdouble start_time_group
, start_time_test
;
79 gchar
**tests_to_run
= NULL
;
83 printf("[%s] (%dx)\n", group
->name
, iterations
);
85 printf("[%s]\n", group
->name
);
89 if(tests_to_run_s
!= NULL
) {
90 tests_to_run
= eg_strsplit(tests_to_run_s
, ",", -1);
93 start_time_group
= get_timestamp();
95 for(i
= 0; tests
[i
].name
!= NULL
; i
++) {
97 gboolean iter_pass
, run
;
100 if(tests_to_run
!= NULL
) {
103 for(j
= 0; tests_to_run
[j
] != NULL
; j
++) {
104 if(strcmp(tests_to_run
[j
], tests
[i
].name
) == 0) {
120 printf(" %s: ", tests
[i
].name
);
123 start_time_test
= get_timestamp();
125 for(j
= 0; j
< iterations
; j
++) {
126 iter_pass
= run_test(&(tests
[i
]), &result
);
136 printf("OK (%g)\n", get_timestamp() - start_time_test
);
143 printf("FAILED (%s)\n", result
);
146 if(last_result
== result
) {
153 global_passed
+= passed
;
154 global_tests
+= total
;
157 gdouble pass_percentage
= ((gdouble
)passed
/ (gdouble
)total
) * 100.0;
159 printf(" %d / %d (%g%%, %g)\n", passed
, total
,
160 pass_percentage
, get_timestamp() - start_time_group
);
162 printf(" %d / %d (%g%%)\n", passed
, total
, pass_percentage
);
166 if(tests_to_run
!= NULL
) {
167 eg_strfreev(tests_to_run
);
170 return passed
== total
;
174 FAILED(const gchar
*format
, ...)
180 #if !defined(HAVE_VASPRINTF) && !defined(_EGLIB_MAJOR)
181 /* We are linked against the real glib, no vasprintf */
182 g_assert_not_reached ();
185 va_start(args
, format
);
186 n
= vasprintf(&ret
, format
, args
);
202 /* FIXME: We should use g_get_current_time here */
204 g_get_current_time (&res
);
205 return res
.tv_sec
+ (1.e
-6) * res
.tv_usec
;
209 * Duplicating code here from EGlib to avoid g_strsplit skew between
214 eg_strsplit (const gchar
*string
, const gchar
*delimiter
, gint max_tokens
)
217 gchar
*strtok_save
, **vector
;
218 gchar
*token
, *token_c
;
222 g_return_val_if_fail(string
!= NULL
, NULL
);
223 g_return_val_if_fail(delimiter
!= NULL
, NULL
);
224 g_return_val_if_fail(delimiter
[0] != 0, NULL
);
226 token_length
= strlen(string
);
227 string_c
= (gchar
*)g_malloc(token_length
+ 1);
228 memcpy(string_c
, string
, token_length
);
229 string_c
[token_length
] = 0;
232 token
= (gchar
*)strtok_r(string_c
, delimiter
, &strtok_save
);
234 while(token
!= NULL
) {
235 token_length
= strlen(token
);
236 token_c
= (gchar
*)g_malloc(token_length
+ 1);
237 memcpy(token_c
, token
, token_length
);
238 token_c
[token_length
] = 0;
240 vector
= vector
== NULL
?
241 (gchar
**)g_malloc(2 * sizeof(vector
)) :
242 (gchar
**)g_realloc(vector
, (size
+ 1) * sizeof(vector
));
244 vector
[size
- 1] = token_c
;
247 if(max_tokens
> 0 && size
>= max_tokens
) {
248 if(size
> max_tokens
) {
254 token
= (gchar
*)strtok_r(NULL
, delimiter
, &strtok_save
);
258 if(vector
!= NULL
&& size
> 0) {
259 vector
[size
- 1] = NULL
;
269 eg_strfreev (gchar
**str_array
)
271 gchar
**orig
= str_array
;
272 if (str_array
== NULL
)
274 while (*str_array
!= NULL
){