2014-07-03 15:42:19 -06:00
|
|
|
/** ==========================================================================
|
|
|
|
* 2014 by KjellKod.cc. This is PUBLIC DOMAIN to use at your own risk and comes
|
|
|
|
* with no warranties. This code is yours to share, use and modify with no
|
|
|
|
* strings attached and no restrictions or obligations.
|
|
|
|
*
|
|
|
|
* For more information see g3log/LICENSE or refer refer to http://unlicense.org
|
|
|
|
* ============================================================================*/
|
|
|
|
|
2023-11-30 16:17:45 -07:00
|
|
|
#include <g3log/filesink.hpp>
|
2015-07-16 01:55:23 -06:00
|
|
|
#include <g3log/g3log.hpp>
|
|
|
|
#include <g3log/logworker.hpp>
|
2018-02-20 22:02:19 -07:00
|
|
|
#include <memory>
|
2014-03-10 23:25:38 -06:00
|
|
|
|
2014-03-08 23:33:49 -07:00
|
|
|
#include <gtest/gtest.h>
|
|
|
|
#include <string>
|
|
|
|
#include <vector>
|
2014-03-10 23:25:38 -06:00
|
|
|
|
2014-03-08 23:33:49 -07:00
|
|
|
#include <dlfcn.h>
|
2023-11-30 16:17:45 -07:00
|
|
|
#include "tester_sharedlib.h"
|
2014-03-08 23:33:49 -07:00
|
|
|
|
|
|
|
struct LogMessageCounter {
|
|
|
|
std::vector<std::string>& bank;
|
2023-11-30 16:17:45 -07:00
|
|
|
LogMessageCounter(std::vector<std::string>& storeMessages) :
|
|
|
|
bank(storeMessages) {
|
2014-03-08 23:33:49 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
void countMessages(std::string msg) {
|
|
|
|
bank.push_back(msg);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
TEST(DynamicLoadOfLibrary, JustLoadAndExit) {
|
|
|
|
std::vector<std::string> receiver;
|
2023-11-30 16:17:45 -07:00
|
|
|
|
|
|
|
{ // scope to flush logs at logworker exit
|
2015-08-19 10:08:41 -06:00
|
|
|
auto worker = g3::LogWorker::createLogWorker();
|
2018-02-20 22:02:19 -07:00
|
|
|
auto handle = worker->addSink(std::make_unique<LogMessageCounter>(std::ref(receiver)), &LogMessageCounter::countMessages);
|
2023-11-30 16:17:45 -07:00
|
|
|
|
2014-03-10 23:25:38 -06:00
|
|
|
// add another sink just for more throughput of data
|
2018-02-20 22:02:19 -07:00
|
|
|
auto fileHandle = worker->addSink(std::make_unique<g3::FileSink>("runtimeLoadOfDynamiclibs", "/tmp"), &g3::FileSink::fileWrite);
|
2015-07-19 23:10:56 -06:00
|
|
|
g3::initializeLogging(worker.get());
|
2014-03-08 23:33:49 -07:00
|
|
|
|
|
|
|
void* libHandle = dlopen("libtester_sharedlib.so", RTLD_LAZY | RTLD_GLOBAL);
|
|
|
|
EXPECT_FALSE(nullptr == libHandle);
|
2023-11-30 16:17:45 -07:00
|
|
|
LibraryFactory* factory = reinterpret_cast<LibraryFactory*>((dlsym(libHandle, "testRealFactory")));
|
2014-03-08 23:33:49 -07:00
|
|
|
EXPECT_FALSE(nullptr == factory);
|
|
|
|
SomeLibrary* loadedLibrary = factory->CreateLibrary();
|
|
|
|
|
2015-07-20 08:00:33 -06:00
|
|
|
for (auto i = 0; i < 300; ++i) {
|
2014-03-08 23:33:49 -07:00
|
|
|
loadedLibrary->action();
|
|
|
|
}
|
|
|
|
|
|
|
|
delete loadedLibrary;
|
|
|
|
dlclose(libHandle);
|
2023-11-30 16:17:45 -07:00
|
|
|
} // scope exit. All log entries must be flushed now
|
|
|
|
const size_t numberOfMessages = 2 + 300 + 1; // 2 library construction, 300 loop, 1 destoyed library
|
2014-03-08 23:33:49 -07:00
|
|
|
EXPECT_EQ(receiver.size(), numberOfMessages);
|
|
|
|
}
|