log_buffer_unittest.cc 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139
  1. // Copyright (C) 2012 Internet Systems Consortium, Inc. ("ISC")
  2. //
  3. // Permission to use, copy, modify, and/or distribute this software for any
  4. // purpose with or without fee is hereby granted, provided that the above
  5. // copyright notice and this permission notice appear in all copies.
  6. //
  7. // THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES WITH
  8. // REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
  9. // AND FITNESS. IN NO EVENT SHALL ISC BE LIABLE FOR ANY SPECIAL, DIRECT,
  10. // INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
  11. // LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE
  12. // OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
  13. // PERFORMANCE OF THIS SOFTWARE.
  14. #include "config.h"
  15. #include <gtest/gtest.h>
  16. #include <log/macros.h>
  17. #include <log/logger_support.h>
  18. #include <log/log_messages.h>
  19. #include <log/log_buffer_impl.h>
  20. #include <log4cplus/loggingmacros.h>
  21. #include <log4cplus/logger.h>
  22. #include <log4cplus/nullappender.h>
  23. #include <log4cplus/spi/loggingevent.h>
  24. using namespace isc::log;
  25. using namespace isc::log::internal;
  26. namespace isc {
  27. namespace log {
  28. class LogBufferTest : public ::testing::Test {
  29. protected:
  30. LogBufferTest() : buffer_appender1(new BufferAppender()),
  31. buffer_appender2(new BufferAppender()),
  32. appender1(buffer_appender1),
  33. appender2(buffer_appender2),
  34. logger(log4cplus::Logger::getInstance("buffer"))
  35. {
  36. logger.setLogLevel(log4cplus::TRACE_LOG_LEVEL);
  37. }
  38. ~LogBufferTest() {
  39. // If any log messages are left, we don't care, get rid of them,
  40. // by flushing them to a null appender
  41. // Given the 'messages should not get lost' approach of the logging
  42. // system, not flushing them to a null appender would cause them
  43. // to be dumped to stdout as the test is destroyed, making
  44. // unnecessarily messy test output.
  45. log4cplus::SharedAppenderPtr null_appender(
  46. new log4cplus::NullAppender());
  47. logger.removeAllAppenders();
  48. logger.addAppender(null_appender);
  49. buffer_appender1->flush();
  50. buffer_appender2->flush();
  51. }
  52. //LogBuffer buffer_appender1->
  53. //LogBuffer buffer_appender2->
  54. BufferAppender* buffer_appender1;
  55. BufferAppender* buffer_appender2;
  56. log4cplus::SharedAppenderPtr appender1;
  57. log4cplus::SharedAppenderPtr appender2;
  58. log4cplus::Logger logger;
  59. };
  60. // Test that log events are indeed stored, and that they are
  61. // flushed to the new appenders of their logger
  62. TEST_F(LogBufferTest, flush) {
  63. ASSERT_EQ(0, buffer_appender1->getBufferSize());
  64. ASSERT_EQ(0, buffer_appender2->getBufferSize());
  65. // Create a Logger, log a few messages with the first appender
  66. logger.addAppender(appender1);
  67. LOG4CPLUS_INFO(logger, "Foo");
  68. ASSERT_EQ(1, buffer_appender1->getBufferSize());
  69. LOG4CPLUS_INFO(logger, "Foo");
  70. ASSERT_EQ(2, buffer_appender1->getBufferSize());
  71. LOG4CPLUS_INFO(logger, "Foo");
  72. ASSERT_EQ(3, buffer_appender1->getBufferSize());
  73. // Second buffer should still be empty
  74. ASSERT_EQ(0, buffer_appender2->getBufferSize());
  75. // Replace the appender by the second one, and call flush;
  76. // this should cause all events to be moved to the second buffer
  77. logger.removeAllAppenders();
  78. logger.addAppender(appender2);
  79. buffer_appender1->flush();
  80. ASSERT_EQ(0, buffer_appender1->getBufferSize());
  81. ASSERT_EQ(3, buffer_appender2->getBufferSize());
  82. }
  83. // Once flushed, logging new messages with the same buffer should fail
  84. TEST_F(LogBufferTest, addAfterFlush) {
  85. logger.addAppender(appender1);
  86. buffer_appender1->flush();
  87. EXPECT_THROW(LOG4CPLUS_INFO(logger, "Foo"), LogBufferAddAfterFlush);
  88. // It should not have been added
  89. ASSERT_EQ(0, buffer_appender1->getBufferSize());
  90. // But logging should work again as long as a different buffer is used
  91. logger.removeAllAppenders();
  92. logger.addAppender(appender2);
  93. LOG4CPLUS_INFO(logger, "Foo");
  94. ASSERT_EQ(1, buffer_appender2->getBufferSize());
  95. }
  96. /*
  97. TEST_F(LogBufferTest, addDirectly) {
  98. // A few direct calls
  99. log4cplus::spi::InternalLoggingEvent event("buffer",
  100. log4cplus::INFO_LOG_LEVEL,
  101. "Bar", "file", 123);
  102. buffer_appender1->append(event);
  103. ASSERT_EQ(1, buffer_appender1->getBufferSize());
  104. // Do one from a smaller scope to make sure destruction doesn't harm
  105. {
  106. log4cplus::spi::InternalLoggingEvent event2("buffer",
  107. log4cplus::INFO_LOG_LEVEL,
  108. "Bar", "file", 123);
  109. buffer_appender1->append(event2);
  110. }
  111. ASSERT_EQ(2, buffer_appender1->getBufferSize());
  112. // And flush them to the next
  113. logger.removeAllAppenders();
  114. logger.addAppender(appender2);
  115. buffer_appender1->flush();
  116. ASSERT_EQ(0, buffer_appender1->getBufferSize());
  117. ASSERT_EQ(2, buffer_appender2->getBufferSize());
  118. }
  119. */
  120. }
  121. }