From d8de003a0482c998c178151bd1e5684fef60b8be Mon Sep 17 00:00:00 2001 From: Paul Elder Date: Fri, 10 May 2019 19:10:41 -0400 Subject: test: ipa: add IPAModule tests Add tests to test the the IPAModule class, for loading the IPA module info from IPA module .so shared objects, with modules written in both C and C++. Signed-off-by: Paul Elder Reviewed-by: Laurent Pinchart --- test/ipa/ipa_test.cpp | 74 ++++++++++++++++++++++++++++++++++++++++++++++++ test/ipa/meson.build | 21 ++++++++++++++ test/ipa/shared_test.c | 6 ++++ test/ipa/shared_test.cpp | 12 ++++++++ test/meson.build | 1 + 5 files changed, 114 insertions(+) create mode 100644 test/ipa/ipa_test.cpp create mode 100644 test/ipa/meson.build create mode 100644 test/ipa/shared_test.c create mode 100644 test/ipa/shared_test.cpp diff --git a/test/ipa/ipa_test.cpp b/test/ipa/ipa_test.cpp new file mode 100644 index 00000000..9861ee26 --- /dev/null +++ b/test/ipa/ipa_test.cpp @@ -0,0 +1,74 @@ +/* SPDX-License-Identifier: GPL-2.0-or-later */ +/* + * Copyright (C) 2019, Google Inc. + * + * load-so.cpp - loading .so tests + */ + +#include +#include + +#include "ipa_module.h" + +#include "test.h" + +using namespace std; +using namespace libcamera; + +class IPAModuleTest : public Test +{ +protected: + int runTest(const string &path, const struct IPAModuleInfo &testInfo) + { + int ret = 0; + + IPAModule *ll = new IPAModule(path); + + if (!ll->isValid()) { + cerr << "test IPA module " << path << " is invalid" + << endl; + delete ll; + return -1; + } + + const struct IPAModuleInfo &info = ll->info(); + + if (strcmp(info.name, testInfo.name)) { + cerr << "test IPA module has incorrect name" << endl; + cerr << "expected \"" << testInfo.name << "\", got \"" + << info.name << "\"" << endl; + ret = -1; + } + + if (info.version != testInfo.version) { + cerr << "test IPA module has incorrect version" << endl; + cerr << "expected \"" << testInfo.version << "\", got \"" + << info.version << "\"" << endl; + ret = -1; + } + + delete ll; + return ret; + } + + int run() override + { + int count = 0; + + const struct IPAModuleInfo testInfo = { + "It's over nine thousand!", + 9001, + }; + + count += runTest("test/ipa/ipa-dummy-c.so", testInfo); + + count += runTest("test/ipa/ipa-dummy-cpp.so", testInfo); + + if (count < 0) + return TestFail; + + return TestPass; + } +}; + +TEST_REGISTER(IPAModuleTest) diff --git a/test/ipa/meson.build b/test/ipa/meson.build new file mode 100644 index 00000000..6df0671b --- /dev/null +++ b/test/ipa/meson.build @@ -0,0 +1,21 @@ +ipa_modules_sources = [ + ['ipa-dummy-c', 'shared_test.c'], + ['ipa-dummy-cpp', 'shared_test.cpp'], +] + +foreach m : ipa_modules_sources + shared_library(m, name_prefix: '', + include_directories: test_includes_public) +endforeach + +ipa_test = [ + ['ipa_test', 'ipa_test.cpp'], +] + +foreach t : ipa_test + exe = executable(t[0], t[1], + link_with : test_libraries, + include_directories : test_includes_internal) + + test(t[0], exe, suite: 'ipa', is_parallel: false) +endforeach diff --git a/test/ipa/shared_test.c b/test/ipa/shared_test.c new file mode 100644 index 00000000..87d182b9 --- /dev/null +++ b/test/ipa/shared_test.c @@ -0,0 +1,6 @@ +#include + +const struct IPAModuleInfo ipaModuleInfo = { + .name = "It's over nine thousand!", + .version = 9001, +}; diff --git a/test/ipa/shared_test.cpp b/test/ipa/shared_test.cpp new file mode 100644 index 00000000..4e5c976c --- /dev/null +++ b/test/ipa/shared_test.cpp @@ -0,0 +1,12 @@ +#include + +namespace libcamera { + +extern "C" { +const struct libcamera::IPAModuleInfo ipaModuleInfo = { + "It's over nine thousand!", + 9001, +}; +}; + +}; /* namespace libcamera */ diff --git a/test/meson.build b/test/meson.build index d501f2be..ef413679 100644 --- a/test/meson.build +++ b/test/meson.build @@ -1,6 +1,7 @@ subdir('libtest') subdir('camera') +subdir('ipa') subdir('media_device') subdir('pipeline') subdir('v4l2_device') -- cgit v1.2.1