summaryrefslogtreecommitdiff
path: root/test/log
diff options
context:
space:
mode:
Diffstat (limited to 'test/log')
-rw-r--r--test/log/log_api.cpp151
-rw-r--r--test/log/log_process.cpp153
-rw-r--r--test/log/meson.build13
3 files changed, 317 insertions, 0 deletions
diff --git a/test/log/log_api.cpp b/test/log/log_api.cpp
new file mode 100644
index 00000000..33622f84
--- /dev/null
+++ b/test/log/log_api.cpp
@@ -0,0 +1,151 @@
+/* SPDX-License-Identifier: GPL-2.0-or-later */
+/*
+ * Copyright (C) 2019, Google Inc.
+ *
+ * log.cpp - log API test
+ */
+
+#include <algorithm>
+#include <fcntl.h>
+#include <iostream>
+#include <list>
+#include <sstream>
+#include <stdio.h>
+#include <string.h>
+#include <sys/stat.h>
+#include <sys/types.h>
+#include <unistd.h>
+
+#include <libcamera/logging.h>
+
+#include "log.h"
+#include "test.h"
+
+using namespace std;
+using namespace libcamera;
+
+LOG_DEFINE_CATEGORY(LogAPITest)
+
+class LogAPITest : public Test
+{
+protected:
+ void doLogging()
+ {
+ logSetLevel("LogAPITest", "DEBUG");
+ LOG(LogAPITest, Info) << "good 1";
+
+ logSetLevel("LogAPITest", "WARN");
+ LOG(LogAPITest, Info) << "bad";
+
+ logSetLevel("LogAPITest", "ERROR");
+ LOG(LogAPITest, Error) << "good 3";
+ LOG(LogAPITest, Info) << "bad";
+
+ logSetLevel("LogAPITest", "WARN");
+ LOG(LogAPITest, Warning) << "good 5";
+ LOG(LogAPITest, Info) << "bad";
+ }
+
+ int verifyOutput(istream &is)
+ {
+ list<int> goodList = { 1, 3, 5 };
+ string line;
+ while (getline(is, line)) {
+ if (goodList.empty()) {
+ cout << "Too many log lines" << endl;
+ return TestFail;
+ }
+
+ unsigned int digit = line.back() - '0';
+ unsigned int expect = goodList.front();
+ goodList.pop_front();
+ if (digit != expect) {
+ cout << "Incorrect log line" << endl;
+ return TestFail;
+ }
+ }
+
+ if (!goodList.empty()) {
+ cout </* SPDX-License-Identifier: GPL-2.0-or-later */ /* * Copyright (C) 2019, Google Inc. * * control_serialization.cpp - Serialize and deserialize controls */ #include <iostream> #include <libcamera/camera.h> #include <libcamera/control_ids.h> #include <libcamera/controls.h> #include "libcamera/internal/byte_stream_buffer.h" #include "libcamera/internal/control_serializer.h" #include "serialization_test.h" #include "test.h" using namespace std; using namespace libcamera; class ControlSerializationTest : public SerializationTest { protected: int init() override { return status_; } int run() override { ControlSerializer serializer(ControlSerializer::Role::Proxy); ControlSerializer deserializer(ControlSerializer::Role::Worker); std::vector<uint8_t> infoData; std::vector<uint8_t> listData; size_t size; int ret; /* Create a control list with three controls. */ const ControlInfoMap &infoMap = camera_->controls(); ControlList list(infoMap); list.set(controls::Brightness, 0.5f); list.set(controls::Contrast, 1.2f); list.set(controls::Saturation, 0.2f); /* * Serialize the control list, this should fail as the control * info map hasn't been serialized.lass='add'>+#include <unistd.h>
+#include <vector>
+
+#include <libcamera/camera_manager.h>
+#include <libcamera/event_dispatcher.h>
+#include <libcamera/logging.h>
+#include <libcamera/timer.h>
+
+#include "log.h"
+#include "process.h"
+#include "test.h"
+#include "utils.h"
+
+using namespace std;
+using namespace libcamera;
+
+static const string message("hello from the child");
+
+LOG_DEFINE_CATEGORY(LogProcessTest)
+
+class LogProcessTestChild
+{
+public:
+ int run(int status, int num)
+ {
+ usleep(50000);
+
+ string logPath = "/tmp/libcamera.worker.test." +
+ to_string(num) + ".log";
+ if (logSetFile(logPath.c_str()) < 0)
+ return TestSkip;
+
+ LOG(LogProcessTest, Warning) << message;
+
+ return status;
+ }
+};
+
+class LogProcessTest : public Test
+{
+protected:
+ int init()
+ {
+ random_device random;
+ num_ = random();
+ logPath_ = "/tmp/libcamera.worker.test." +
+ to_string(num_) + ".log";
+
+ proc_.finished.connect(this, &LogProcessTest::procFinished);
+ return 0;
+ }
+
+ int run()
+ {
+ EventDispatcher *dispatcher = CameraManager::instance()->eventDispatcher();
+ Timer timeout;
+
+ int exitCode = 42;
+ vector<std::string> args;
+ args.push_back(to_string(exitCode));
+ args.push_back(to_string(num_));
+ int ret = proc_.start("/proc/self/exe", args);
+ if (ret) {
+ cerr << "failed to start process" << endl;
+ return TestFail;
+ }
+
+ timeout.start(200);
+ while (timeout.isRunning())
+ dispatcher->processEvents();
+
+ if (exitStatus_ != Process::NormalExit) {
+ cerr << "process did not exit normally" << endl;
+ return TestFail;
+ }
+
+ if (exitCode_ == TestSkip)
+ return TestSkip;
+
+ if (exitCode_ != exitCode) {
+ cerr << "exit code should be " << exitCode
+ << ", actual is " << exitCode_ << endl;
+ return TestFail;
+ }
+
+ int fd = open(logPath_.c_str(), O_RDONLY, S_IRUSR);
+ if (fd < 0) {
+ cerr << "failed to open tmp log file" << endl;
+ return TestFail;
+ }
+
+ char buf[200];
+ memset(buf, 0, sizeof(buf));
+ if (read(fd, buf, sizeof(buf)) < 0) {
+ cerr << "Failed to read tmp log file" << endl;
+ return TestFail;
+ }
+ close(fd);
+
+ string str(buf);
+ if (str.find(message) == string::npos)
+ return TestFail;
+
+ return TestPass;
+ }
+
+ void cleanup()
+ {
+ unlink(logPath_.c_str());
+ }
+
+private:
+ void procFinished(Process *proc, enum Process::ExitStatus exitStatus, int exitCode)
+ {
+ exitStatus_ = exitStatus;
+ exitCode_ = exitCode;
+ }
+
+ Process proc_;
+ Process::ExitStatus exitStatus_;
+ string logPath_;
+ int exitCode_;
+ int num_;
+};
+
+/*
+ * Can't use TEST_REGISTER() as single binary needs to act as both
+ * parent and child processes.
+ */
+int main(int argc, char **argv)
+{
+ if (argc == 3) {
+ int status = std::stoi(argv[1]);
+ int num = std::stoi(argv[2]);
+ LogProcessTestChild child;
+ return child.run(status, num);
+ }
+
+ return LogProcessTest().execute();
+}
diff --git a/test/log/meson.build b/test/log/meson.build
new file mode 100644
index 00000000..95f6c1a2
--- /dev/null
+++ b/test/log/meson.build
@@ -0,0 +1,13 @@
+log_test = [
+ ['log_api', 'log_api.cpp'],
+ ['log_process', 'log_process.cpp'],
+]
+
+foreach t : log_test
+ exe = executable(t[0], t[1],
+ dependencies : libcamera_dep,
+ link_with : test_libraries,
+ include_directories : test_includes_internal)
+
+ test(t[0], exe, suite : 'log')
+endforeach