 3ffef1a55c
			
		
	
	
		3ffef1a55c
		
	
	
	
	
		
			
			This can help debugging issues or develop, when error handling is introduced. Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com> Reviewed-by: Stefan Berger <stefanb@linux.ibm.com> Message-Id: <20230221124802.4103554-6-marcandre.lureau@redhat.com>
		
			
				
	
	
		
			140 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			140 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * Error reporting test
 | |
|  *
 | |
|  * Copyright (C) 2022 Red Hat Inc.
 | |
|  *
 | |
|  * This work is licensed under the terms of the GNU GPL, version 2 or later.
 | |
|  * See the COPYING file in the top-level directory.
 | |
|  */
 | |
| 
 | |
| #include "qemu/osdep.h"
 | |
| #include "glib-compat.h"
 | |
| #include <locale.h>
 | |
| 
 | |
| #include "qemu/error-report.h"
 | |
| #include "qapi/error.h"
 | |
| 
 | |
| static void
 | |
| test_error_report_simple(void)
 | |
| {
 | |
|     if (g_test_subprocess()) {
 | |
|         error_report("%s", "test error");
 | |
|         warn_report("%s", "test warn");
 | |
|         info_report("%s", "test info");
 | |
|         return;
 | |
|     }
 | |
| 
 | |
|     g_test_trap_subprocess(NULL, 0, 0);
 | |
|     g_test_trap_assert_passed();
 | |
|     g_test_trap_assert_stderr("\
 | |
| test-error-report: test error*\
 | |
| test-error-report: warning: test warn*\
 | |
| test-error-report: info: test info*\
 | |
| ");
 | |
| }
 | |
| 
 | |
| static void
 | |
| test_error_report_loc(void)
 | |
| {
 | |
|     if (g_test_subprocess()) {
 | |
|         loc_set_file("some-file.c", 7717);
 | |
|         error_report("%s", "test error1");
 | |
|         loc_set_none();
 | |
|         error_report("%s", "test error2");
 | |
|         return;
 | |
|     }
 | |
| 
 | |
|     g_test_trap_subprocess(NULL, 0, 0);
 | |
|     g_test_trap_assert_passed();
 | |
|     g_test_trap_assert_stderr("\
 | |
| test-error-report:some-file.c:7717: test error1*\
 | |
| test-error-report: test error2*\
 | |
| ");
 | |
| }
 | |
| 
 | |
| static void
 | |
| test_error_report_glog(void)
 | |
| {
 | |
|     if (g_test_subprocess()) {
 | |
|         g_message("gmessage");
 | |
|         return;
 | |
|     }
 | |
| 
 | |
|     g_test_trap_subprocess(NULL, 0, 0);
 | |
|     g_test_trap_assert_passed();
 | |
|     g_test_trap_assert_stderr("test-error-report: info: gmessage*");
 | |
| }
 | |
| 
 | |
| static void
 | |
| test_error_report_once(void)
 | |
| {
 | |
|     int i;
 | |
| 
 | |
|     if (g_test_subprocess()) {
 | |
|         for (i = 0; i < 3; i++) {
 | |
|             warn_report_once("warn");
 | |
|             error_report_once("err");
 | |
|         }
 | |
|         return;
 | |
|     }
 | |
| 
 | |
|     g_test_trap_subprocess(NULL, 0, 0);
 | |
|     g_test_trap_assert_passed();
 | |
|     g_test_trap_assert_stderr("\
 | |
| test-error-report: warning: warn*\
 | |
| test-error-report: err*\
 | |
| ");
 | |
| }
 | |
| 
 | |
| static void
 | |
| test_error_report_timestamp(void)
 | |
| {
 | |
|     if (g_test_subprocess()) {
 | |
|         message_with_timestamp = true;
 | |
|         warn_report("warn");
 | |
|         error_report("err");
 | |
|         return;
 | |
|     }
 | |
| 
 | |
|     g_test_trap_subprocess(NULL, 0, 0);
 | |
|     g_test_trap_assert_passed();
 | |
|     g_test_trap_assert_stderr("\
 | |
| *-*-*:*:* test-error-report: warning: warn*\
 | |
| *-*-*:*:* test-error-report: err*\
 | |
| ");
 | |
| }
 | |
| 
 | |
| static void
 | |
| test_error_warn(void)
 | |
| {
 | |
|     if (g_test_subprocess()) {
 | |
|         error_setg(&error_warn, "Testing &error_warn");
 | |
|         return;
 | |
|     }
 | |
| 
 | |
|     g_test_trap_subprocess(NULL, 0, 0);
 | |
|     g_test_trap_assert_passed();
 | |
|     g_test_trap_assert_stderr("\
 | |
| test-error-report: warning: Testing &error_warn*\
 | |
| ");
 | |
| }
 | |
| 
 | |
| 
 | |
| int
 | |
| main(int argc, char *argv[])
 | |
| {
 | |
|     setlocale(LC_ALL, "");
 | |
| 
 | |
|     g_test_init(&argc, &argv, NULL);
 | |
|     error_init("test-error-report");
 | |
| 
 | |
|     g_test_add_func("/error-report/simple", test_error_report_simple);
 | |
|     g_test_add_func("/error-report/loc", test_error_report_loc);
 | |
|     g_test_add_func("/error-report/glog", test_error_report_glog);
 | |
|     g_test_add_func("/error-report/once", test_error_report_once);
 | |
|     g_test_add_func("/error-report/timestamp", test_error_report_timestamp);
 | |
|     g_test_add_func("/error-report/warn", test_error_warn);
 | |
| 
 | |
|     return g_test_run();
 | |
| }
 |