]> git.ipfire.org Git - thirdparty/kea.git/commitdiff
[#1719] DatabaseLogTest.mutexIsolation
authorAndrei Pavel <andrei@isc.org>
Mon, 22 Feb 2021 15:21:10 +0000 (17:21 +0200)
committerAndrei Pavel <andrei@isc.org>
Mon, 8 Mar 2021 15:16:36 +0000 (17:16 +0200)
src/lib/database/tests/Makefile.am
src/lib/database/tests/database_log_unittest.cc [new file with mode: 0644]

index 5a3433681c5f1c9402dcf026507f1d45245fe3d4..dd39beef932fed0f6e9d381353250aaf9d733714 100644 (file)
@@ -22,6 +22,7 @@ TESTS += libdatabase_unittests
 libdatabase_unittests_SOURCES  = audit_entry_unittest.cc
 libdatabase_unittests_SOURCES += backend_selector_unittest.cc
 libdatabase_unittests_SOURCES += database_connection_unittest.cc
+libdatabase_unittests_SOURCES += database_log_unittest.cc
 libdatabase_unittests_SOURCES += dbaccess_parser_unittest.cc
 libdatabase_unittests_SOURCES += run_unittests.cc
 libdatabase_unittests_SOURCES += server_unittest.cc
diff --git a/src/lib/database/tests/database_log_unittest.cc b/src/lib/database/tests/database_log_unittest.cc
new file mode 100644 (file)
index 0000000..1caa12c
--- /dev/null
@@ -0,0 +1,48 @@
+// Copyright (C) 2021 Internet Systems Consortium, Inc. ("ISC")
+//
+// This Source Code Form is subject to the terms of the Mozilla Public
+// License, v. 2.0. If a copy of the MPL was not distributed with this
+// file, You can obtain one at http://mozilla.org/MPL/2.0/.
+
+#include <config.h>
+
+#include <database/db_log.h>
+
+#include <gtest/gtest.h>
+
+using isc::db::DB_DBG_TRACE_DETAIL;
+using isc::db::DB_INVALID_ACCESS;
+using isc::db::DB_LOG_FATAL;
+using isc::db::DB_LOG_ERROR;
+using isc::db::DB_LOG_WARN;
+using isc::db::DB_LOG_INFO;
+using isc::db::DB_LOG_DEBUG;
+using isc::db::db_logger_mutex;
+
+namespace {
+
+/// Test that the mutex unlocks after a call to DB_LOG.
+/// Let's use DB_INVALID_ACCESS as an example for all.
+TEST(DatabaseLogTest, mutexIsolation) {
+    DB_LOG_FATAL(DB_INVALID_ACCESS).arg("hello");
+    EXPECT_TRUE(db_logger_mutex.try_lock());
+    db_logger_mutex.unlock();
+
+    DB_LOG_ERROR(DB_INVALID_ACCESS).arg("hello");
+    EXPECT_TRUE(db_logger_mutex.try_lock());
+    db_logger_mutex.unlock();
+
+    DB_LOG_WARN(DB_INVALID_ACCESS).arg("hello");
+    EXPECT_TRUE(db_logger_mutex.try_lock());
+    db_logger_mutex.unlock();
+
+    DB_LOG_INFO(DB_INVALID_ACCESS).arg("hello");
+    EXPECT_TRUE(db_logger_mutex.try_lock());
+    db_logger_mutex.unlock();
+
+    DB_LOG_DEBUG(DB_DBG_TRACE_DETAIL, DB_INVALID_ACCESS).arg("hello");
+    EXPECT_TRUE(db_logger_mutex.try_lock());
+    db_logger_mutex.unlock();
+}
+
+}  // namespace