std::string Logger::getFormattingPattern() { Mutex::ScopedLock lock(loggerMutex); PatternFormatter *p = getPatternFormatter(); return p ? p->getProperty(PatternFormatter::PROP_PATTERN) : string(); }
void PatternFormatterTest::testPatternFormatter() { Message msg; PatternFormatter fmt; msg.setSource("TestSource"); msg.setText("Test message text"); msg.setPid(1234); msg.setTid(1); msg.setThread("TestThread"); msg.setPriority(Message::PRIO_ERROR); msg.setTime(DateTime(2005, 1, 1, 14, 30, 15, 500).timestamp()); msg["testParam"] = "Test Parameter"; std::string result; fmt.setProperty("pattern", "%Y-%m-%dT%H:%M:%S [%s] %p: %t"); fmt.format(msg, result); assert (result == "2005-01-01T14:30:15 [TestSource] Error: Test message text"); result.clear(); fmt.setProperty("pattern", "%w, %e %b %y %H:%M:%S.%i [%s:%I:%T] %q: %t"); fmt.format(msg, result); assert (result == "Sat, 1 Jan 05 14:30:15.500 [TestSource:1:TestThread] E: Test message text"); result.clear(); fmt.setProperty("pattern", "%Y-%m-%d %H:%M:%S [%N:%P:%s]%l-%t"); fmt.format(msg, result); assert (result.find("2005-01-01 14:30:15 [") == 0); assert (result.find(":TestSource]3-Test message text") != std::string::npos); result.clear(); assert (fmt.getProperty("times") == "UTC"); fmt.setProperty("times", "local"); fmt.format(msg, result); assert (result.find("2005-01-01 ") == 0); assert (result.find(":TestSource]3-Test message text") != std::string::npos); result.clear(); fmt.setProperty("pattern", "%[testParam]"); fmt.format(msg, result); assert (result == "Test Parameter"); result.clear(); fmt.setProperty("pattern", "%[testParam] %p"); fmt.format(msg, result); assert (result == "Test Parameter Error"); }