diff --git a/glib/gmessages.c b/glib/gmessages.c index 7340307ff..d09552ebd 100644 --- a/glib/gmessages.c +++ b/glib/gmessages.c @@ -1159,6 +1159,7 @@ g_test_expect_message (const gchar *log_domain, g_return_if_fail (log_level != 0); g_return_if_fail (pattern != NULL); + g_return_if_fail (~log_level & G_LOG_LEVEL_ERROR); expected = g_new (GTestExpectedMessage, 1); expected->log_domain = g_strdup (log_domain); diff --git a/glib/tests/testing.c b/glib/tests/testing.c index 21f019ea1..2adc003a9 100644 --- a/glib/tests/testing.c +++ b/glib/tests/testing.c @@ -380,6 +380,15 @@ test_expected_messages_null_domain (void) g_test_assert_expected_messages (); } +static void +test_expected_messages_expect_error (void) +{ + /* make sure we can't try to expect a g_error() */ + g_test_expect_message (G_LOG_DOMAIN, G_LOG_LEVEL_CRITICAL, "*G_LOG_LEVEL_ERROR*"); + g_test_expect_message (G_LOG_DOMAIN, G_LOG_LEVEL_ERROR, "this won't work"); + g_test_assert_expected_messages (); +} + static void test_expected_messages_extra_warning (void) { @@ -590,6 +599,7 @@ main (int argc, g_test_add_func ("/misc/expected-messages/subprocess/null-domain", test_expected_messages_null_domain); g_test_add_func ("/misc/expected-messages/subprocess/extra-warning", test_expected_messages_extra_warning); g_test_add_func ("/misc/expected-messages/subprocess/unexpected-extra-warning", test_expected_messages_unexpected_extra_warning); + g_test_add_func ("/misc/expected-messages/expect-error", test_expected_messages_expect_error); g_test_add_func ("/misc/dash-p", test_dash_p); g_test_add_func ("/misc/dash-p/child", test_dash_p_child);