gtestutils: Write log to stderr atomically

We used to send the test log to stderr in pieces, but this could be
problematic when running multiple tests in parallel, so let's just prepare
the string in pieces and write it all at once.
This commit is contained in:
Marco Trevisan (Treviño) 2023-01-13 19:07:15 +01:00
parent a943d42104
commit f68c49102e

View File

@ -950,6 +950,7 @@ g_test_log_send (guint n_bytes,
{ {
GTestLogBuffer *lbuffer = g_test_log_buffer_new (); GTestLogBuffer *lbuffer = g_test_log_buffer_new ();
GTestLogMsg *msg; GTestLogMsg *msg;
GString *output;
guint ui; guint ui;
g_test_log_buffer_push (lbuffer, n_bytes, buffer); g_test_log_buffer_push (lbuffer, n_bytes, buffer);
msg = g_test_log_buffer_pop (lbuffer); msg = g_test_log_buffer_pop (lbuffer);
@ -957,22 +958,25 @@ g_test_log_send (guint n_bytes,
g_warn_if_fail (lbuffer->data->len == 0); g_warn_if_fail (lbuffer->data->len == 0);
g_test_log_buffer_free (lbuffer); g_test_log_buffer_free (lbuffer);
/* print message */ /* print message */
g_printerr ("{*LOG(%s)", g_test_log_type_name (msg->log_type)); output = g_string_new (NULL);
g_string_printf (output, "{*LOG(%s)", g_test_log_type_name (msg->log_type));
for (ui = 0; ui < msg->n_strings; ui++) for (ui = 0; ui < msg->n_strings; ui++)
g_printerr (":{%s}", msg->strings[ui]); g_string_append_printf (output, ":{%s}", msg->strings[ui]);
if (msg->n_nums) if (msg->n_nums)
{ {
g_printerr (":("); g_string_append (output, ":(");
for (ui = 0; ui < msg->n_nums; ui++) for (ui = 0; ui < msg->n_nums; ui++)
{ {
if ((long double) (long) msg->nums[ui] == msg->nums[ui]) if ((long double) (long) msg->nums[ui] == msg->nums[ui])
g_printerr ("%s%ld", ui ? ";" : "", (long) msg->nums[ui]); g_string_append_printf (output, "%s%ld", ui ? ";" : "", (long) msg->nums[ui]);
else else
g_printerr ("%s%.16g", ui ? ";" : "", (double) msg->nums[ui]); g_string_append_printf (output, "%s%.16g", ui ? ";" : "", (double) msg->nums[ui]);
} }
g_printerr (")"); g_string_append_c (output, ')');
} }
g_printerr (":LOG*}\n"); g_string_append (output, ":LOG*}");
g_printerr ("%s\n", output->str);
g_string_free (output, TRUE);
g_test_log_msg_free (msg); g_test_log_msg_free (msg);
} }
} }