output_option_unittest.cc 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. // Copyright (C) 2011 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 <string>
  15. #include <gtest/gtest.h>
  16. #include <log/output_option.h>
  17. using namespace isc::log;
  18. using namespace std;
  19. // As OutputOption is a struct, the only meaningful test is to check that it
  20. // initializes correctly.
  21. TEST(OutputOptionTest, Initialization) {
  22. OutputOption option;
  23. EXPECT_EQ(OutputOption::DEST_CONSOLE, option.destination);
  24. EXPECT_EQ(OutputOption::STR_STDERR, option.stream);
  25. EXPECT_FALSE(option.flush);
  26. EXPECT_EQ(string("LOCAL0"), option.facility);
  27. EXPECT_EQ(string(""), option.filename);
  28. EXPECT_EQ(0, option.maxsize);
  29. EXPECT_EQ(0, option.maxver);
  30. }
  31. TEST(OutputOption, getDestination) {
  32. EXPECT_EQ(OutputOption::DEST_CONSOLE, getDestination("console"));
  33. EXPECT_EQ(OutputOption::DEST_CONSOLE, getDestination("CONSOLE"));
  34. EXPECT_EQ(OutputOption::DEST_CONSOLE, getDestination("CoNSoLE"));
  35. EXPECT_EQ(OutputOption::DEST_FILE, getDestination("file"));
  36. EXPECT_EQ(OutputOption::DEST_FILE, getDestination("FILE"));
  37. EXPECT_EQ(OutputOption::DEST_FILE, getDestination("fIlE"));
  38. EXPECT_EQ(OutputOption::DEST_SYSLOG, getDestination("syslog"));
  39. EXPECT_EQ(OutputOption::DEST_SYSLOG, getDestination("SYSLOG"));
  40. EXPECT_EQ(OutputOption::DEST_SYSLOG, getDestination("SYSlog"));
  41. // bad values should default to DEST_CONSOLE
  42. EXPECT_EQ(OutputOption::DEST_CONSOLE, getDestination("SOME_BAD_VALUE"));
  43. }
  44. TEST(OutputOption, getStream) {
  45. EXPECT_EQ(OutputOption::STR_STDOUT, getStream("stdout"));
  46. EXPECT_EQ(OutputOption::STR_STDOUT, getStream("STDOUT"));
  47. EXPECT_EQ(OutputOption::STR_STDOUT, getStream("STdouT"));
  48. EXPECT_EQ(OutputOption::STR_STDERR, getStream("stderr"));
  49. EXPECT_EQ(OutputOption::STR_STDERR, getStream("STDERR"));
  50. EXPECT_EQ(OutputOption::STR_STDERR, getStream("StDeRR"));
  51. // bad values should default to stdout
  52. EXPECT_EQ(OutputOption::STR_STDOUT, getStream("some bad value"));
  53. EXPECT_EQ(OutputOption::STR_STDOUT, getStream(""));
  54. }