libcamera/test/ipa/ipa_test.cpp
Paul Elder 87a93e17f8 libcamera: test: remove test IPA and use dummy IPA instead
Use the dummy IPA for testing/sample IPA instead of the earlier test
IPA. Remove the test IPA, and update tests and meson accordingly.

Signed-off-by: Paul Elder <paul.elder@ideasonboard.com>
Reviewed-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
2019-06-05 10:44:52 -04:00

73 lines
1.6 KiB
C++

/* SPDX-License-Identifier: GPL-2.0-or-later */
/*
* Copyright (C) 2019, Google Inc.
*
* load-so.cpp - loading .so tests
*/
#include <iostream>
#include <string.h>
#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 (memcmp(&info, &testInfo, sizeof(info))) {
cerr << "IPA module information mismatch: expected:" << endl
<< "moduleAPIVersion = " << testInfo.moduleAPIVersion << endl
<< "pipelineVersion = " << testInfo.pipelineVersion << endl
<< "pipelineName = " << testInfo.pipelineName << endl
<< "name = " << testInfo.name
<< "got: " << endl
<< "moduleAPIVersion = " << info.moduleAPIVersion << endl
<< "pipelineVersion = " << info.pipelineVersion << endl
<< "pipelineName = " << info.pipelineName << endl
<< "name = " << info.name << endl;
}
delete ll;
return ret;
}
int run() override
{
int count = 0;
const struct IPAModuleInfo testInfo = {
IPA_MODULE_API_VERSION,
0,
"PipelineHandlerVimc",
"Dummy IPA for Vimc",
};
count += runTest("src/ipa/ipa_dummy.so", testInfo);
if (count < 0)
return TestFail;
return TestPass;
}
};
TEST_REGISTER(IPAModuleTest)