[libcamera-devel] [PATCH v2 2/2] tests: ipa: add tests to test IPAModule
Paul Elder
paul.elder at ideasonboard.com
Wed May 15 00:38:08 CEST 2019
Add tests to test the the IPAModule class for loading struct
IPAModuleInfo of a given symbol from a .so library.
Signed-off-by: Paul Elder <paul.elder at ideasonboard.com>
---
Changes in v2:
- added source for test .so
- updated tests to work with new (v2, see 1/2) IPAModule API
test/ipa/ipa_test.cpp | 76 ++++++++++++++++++++++++++++++++++++++++++
test/ipa/meson.build | 23 +++++++++++++
test/ipa/shared_test.c | 16 +++++++++
test/meson.build | 1 +
4 files changed, 116 insertions(+)
create mode 100644 test/ipa/ipa_test.cpp
create mode 100644 test/ipa/meson.build
create mode 100644 test/ipa/shared_test.c
diff --git a/test/ipa/ipa_test.cpp b/test/ipa/ipa_test.cpp
new file mode 100644
index 0000000..96849bf
--- /dev/null
+++ b/test/ipa/ipa_test.cpp
@@ -0,0 +1,76 @@
+/* SPDX-License-Identifier: GPL-2.0-or-later */
+/*
+ * Copyright (C) 2019, Google Inc.
+ *
+ * load-so.cpp - loading .so tests
+ */
+
+#include <iostream>
+
+#include "ipa_module.h"
+
+#include "test.h"
+
+using namespace std;
+using namespace libcamera;
+
+class IPAModuleTest : public Test
+{
+protected:
+ int init()
+ {
+ return 0;
+ }
+
+ int run_test(const string path, const string symbol)
+ {
+ cout << "running lib loader test" << endl;
+
+ IPAModule *ll = new IPAModule(path, symbol);
+
+ if (!ll->isValid()) {
+ cout << "failed to load" << endl;
+ return TestFail;
+ }
+
+ struct IPAModuleInfo info = ll->IPAModuleInfo();
+ cout << "loaded!" << endl;
+ cout << "name = " << info.name << ", version = " << info.version << endl;
+
+ delete ll;
+ return TestPass;
+ }
+
+ int run()
+ {
+ int count = 0;
+
+ cout << endl
+ << "testing 32-bit so from .data" << endl;
+ count += run_test("test/ipa/libfoo.32.so", "asdf");
+
+ cout << endl
+ << "testing 32-bit so from .rodata" << endl;
+ count += run_test("test/ipa/libfoo.32.so", "hjkl");
+
+ cout << endl
+ << "testing 64-bit so from .data" << endl;
+ count += run_test("test/ipa/libfoo.64.so", "asdf");
+
+ cout << endl
+ << "testing 64-bit so from .rodata" << endl;
+ count += run_test("test/ipa/libfoo.64.so", "hjkl");
+
+ /* Two of these should fail due to bitness mismatch. */
+ if (count < -2)
+ return TestFail;
+
+ return TestPass;
+ }
+
+ void cleanup()
+ {
+ }
+};
+
+TEST_REGISTER(IPAModuleTest)
diff --git a/test/ipa/meson.build b/test/ipa/meson.build
new file mode 100644
index 0000000..994d9ef
--- /dev/null
+++ b/test/ipa/meson.build
@@ -0,0 +1,23 @@
+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
+
+libfoo_sources = files([
+ 'shared_test.c'
+])
+
+libfoo_32 = shared_library('foo.32',
+ libfoo_sources,
+ c_args: '-m32',
+ link_args: '-m32')
+
+libfoo_64 = shared_library('foo.64',
+ libfoo_sources)
diff --git a/test/ipa/shared_test.c b/test/ipa/shared_test.c
new file mode 100644
index 0000000..67acfa4
--- /dev/null
+++ b/test/ipa/shared_test.c
@@ -0,0 +1,16 @@
+#include <stdio.h>
+
+struct IPAModuleInfo {
+ const char name[256];
+ unsigned int version;
+};
+
+const struct IPAModuleInfo hjkl = {
+ .name = "Answer to the Ultimate Question of Life, the Universe, and Everything",
+ .version = 42,
+};
+
+struct IPAModuleInfo asdf = {
+ .name = "It's over nine thousand!",
+ .version = 9001,
+};
diff --git a/test/meson.build b/test/meson.build
index d501f2b..ef41367 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')
--
2.20.1
More information about the libcamera-devel
mailing list