diff --git a/src/Console.cc b/src/Console.cc index a4fde2786..4cd764dc8 100644 --- a/src/Console.cc +++ b/src/Console.cc @@ -88,7 +88,7 @@ Logger::~Logger() ///////////////////////////////////////////////// Logger &Logger::operator()() { - Console::log << "(" << ignition::common::systemTimeIso() << ") "; + Console::log() << "(" << ignition::common::systemTimeIso() << ") "; (*this) << Console::Prefix() << this->prefix; return (*this); @@ -99,7 +99,7 @@ Logger &Logger::operator()(const std::string &_file, int _line) { int index = _file.find_last_of("/") + 1; - Console::log << "(" << ignition::common::systemTimeIso() << ") "; + Console::log() << "(" << ignition::common::systemTimeIso() << ") "; std::stringstream prefixString; prefixString << Console::Prefix() << this->prefix << "[" << _file.substr(index , _file.size() - index) << ":" diff --git a/test/integration/console.cc b/test/integration/console.cc new file mode 100644 index 000000000..267e0020f --- /dev/null +++ b/test/integration/console.cc @@ -0,0 +1,48 @@ +/* + * Copyright (C) 2022 Open Source Robotics Foundation + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * +*/ + +#include + +#include "ignition/common/Console.hh" +#include "test_config.h" + +using namespace ignition; + +TEST(Console_TEST, LogInitAfterConsoleOut) +{ + std::string logFilename = "uri.log"; + std::string logDir = common::joinPaths(PROJECT_BINARY_PATH, "test", "uri"); + std::string logFile = common::joinPaths(logDir, logFilename); + + common::Console::SetVerbosity(4); + + // We are not logging to a file yet. + ignerr << "This is an error" << std::endl; + + // Initialize the log file. + ignLogInit(logDir, logFilename); + + // Run the same console output, which should output the message to the log + // file. + ignerr << "This is an error" << std::endl; + std::ifstream t(logFile); + std::string buffer((std::istreambuf_iterator(t)), + std::istreambuf_iterator()); + + EXPECT_TRUE(buffer.find("This is an error") != std::string::npos) + << "Log file content[" << buffer << "]\n"; +}