You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
405 lines
12 KiB
405 lines
12 KiB
4 years ago
|
/*
|
||
|
* test-tcmodule.c -- testsuite for tcmodule functions;
|
||
|
* everyone feel free to add more tests and improve
|
||
|
* existing ones.
|
||
|
* (C) 2006-2010 - Francesco Romani <fromani -at- gmail -dot- com>
|
||
|
*
|
||
|
* This file is part of transcode, a video stream processing tool.
|
||
|
*
|
||
|
* transcode is free software; you can redistribute it and/or modify
|
||
|
* it under the terms of the GNU General Public License as published by
|
||
|
* the Free Software Foundation; either version 2 of the License, or
|
||
|
* (at your option) any later version.
|
||
|
*
|
||
|
* transcode is distributed in the hope that it will be useful,
|
||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||
|
* GNU General Public License for more details.
|
||
|
*
|
||
|
* You should have received a copy of the GNU General Public License
|
||
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||
|
*/
|
||
|
|
||
|
|
||
|
#include <stdio.h>
|
||
|
#include <stdlib.h>
|
||
|
|
||
|
#include "config.h"
|
||
|
#include "transcode.h"
|
||
|
#include "libtc/libtc.h"
|
||
|
#include "libtc/tcmodule-core.h"
|
||
|
|
||
|
int verbose = TC_QUIET;
|
||
|
int err;
|
||
|
|
||
|
static vob_t *vob = NULL;
|
||
|
|
||
|
static TCFactory factory;
|
||
|
|
||
|
// dependencies
|
||
|
vob_t *tc_get_vob(void) { return vob; }
|
||
|
|
||
|
|
||
|
void aframe_copy(aframe_list_t *dst, const aframe_list_t *src, int copy_data) { ; }
|
||
|
void vframe_copy(vframe_list_t *dst, const vframe_list_t *src, int copy_data) { ; }
|
||
|
|
||
|
// partial line length: I don't bother with full line length,
|
||
|
// it's just a naif padding
|
||
|
#define ADJUST_TO_COL 60
|
||
|
static void test_result_helper(const char *name, int ret, int expected)
|
||
|
{
|
||
|
char spaces[ADJUST_TO_COL] = { ' ' };
|
||
|
size_t slen = strlen(name);
|
||
|
int i = 0, padspace = ADJUST_TO_COL - slen;
|
||
|
|
||
|
if (padspace > 0) {
|
||
|
// do a bit of padding to let the output looks more nice
|
||
|
for (i = 0; i < padspace; i++) {
|
||
|
spaces[i] = ' ';
|
||
|
}
|
||
|
}
|
||
|
|
||
|
if (ret != expected) {
|
||
|
tc_log_error(__FILE__, "'%s'%s%sFAILED%s (%i|%i)",
|
||
|
name, spaces, COL_RED, COL_GRAY,
|
||
|
ret, expected);
|
||
|
} else {
|
||
|
tc_log_info(__FILE__, "'%s'%s%sOK%s",
|
||
|
name, spaces, COL_GREEN, COL_GRAY);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
static int test_bad_init(const char *modpath)
|
||
|
{
|
||
|
factory = tc_new_module_factory("", 0);
|
||
|
err = (factory == NULL) ?-1 :0;
|
||
|
|
||
|
test_result_helper("bad_init::init", err, -1);
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
static int test_init_fini(const char *modpath)
|
||
|
{
|
||
|
factory = tc_new_module_factory(modpath, 0);
|
||
|
err = (factory == NULL) ?-1 :0;
|
||
|
|
||
|
test_result_helper("init_fini::init", err, 0);
|
||
|
test_result_helper("init_fini::fini", tc_del_module_factory(factory), 0);
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
static int test_bad_create(const char *modpath)
|
||
|
{
|
||
|
TCModule module = NULL;
|
||
|
factory = tc_new_module_factory(modpath, verbose);
|
||
|
err = (factory == NULL) ?-1 :0;
|
||
|
|
||
|
test_result_helper("bad_create::init", err, 0);
|
||
|
module = tc_new_module(factory, "inexistent", "inexistent", 0);
|
||
|
if (module != NULL) {
|
||
|
tc_log_error(__FILE__, "loaded inexistent module?!?!");
|
||
|
}
|
||
|
test_result_helper("bad_create::fini", tc_del_module_factory(factory), 0);
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
static int test_create(const char *modpath)
|
||
|
{
|
||
|
TCModule module = NULL;
|
||
|
factory = tc_new_module_factory(modpath, verbose);
|
||
|
err = (factory == NULL) ?-1 :0;
|
||
|
|
||
|
test_result_helper("create::init", err, 0);
|
||
|
module = tc_new_module(factory, "filter", "null", 0);
|
||
|
if (module == NULL) {
|
||
|
tc_log_error(__FILE__, "can't load filter_null");
|
||
|
} else {
|
||
|
test_result_helper("create::check",
|
||
|
tc_compare_modules(module,
|
||
|
module),
|
||
|
1);
|
||
|
test_result_helper("create::instances",
|
||
|
tc_instance_count(factory),
|
||
|
1);
|
||
|
test_result_helper("create::descriptors",
|
||
|
tc_plugin_count(factory),
|
||
|
1);
|
||
|
tc_del_module(factory, module);
|
||
|
}
|
||
|
test_result_helper("create::fini", tc_del_module_factory(factory), 0);
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
static int test_double_create(const char *modpath)
|
||
|
{
|
||
|
TCModule module1 = NULL, module2 = NULL;
|
||
|
factory = tc_new_module_factory(modpath, verbose);
|
||
|
err = (factory == NULL) ?-1 :0;
|
||
|
|
||
|
test_result_helper("double_create::init", err, 0);
|
||
|
module1 = tc_new_module(factory, "filter", "null", TC_VIDEO);
|
||
|
if (module1 == NULL) {
|
||
|
tc_log_error(__FILE__, "can't load filter_null (1)");
|
||
|
}
|
||
|
module2 = tc_new_module(factory, "filter", "null", TC_AUDIO);
|
||
|
if (module2 == NULL) {
|
||
|
tc_log_error(__FILE__, "can't load filter_null (1)");
|
||
|
}
|
||
|
|
||
|
test_result_helper("double_create::check",
|
||
|
tc_compare_modules(module1, module2),
|
||
|
0);
|
||
|
test_result_helper("double_create::instances",
|
||
|
tc_instance_count(factory),
|
||
|
2);
|
||
|
test_result_helper("double_create::descriptors",
|
||
|
tc_plugin_count(factory),
|
||
|
1);
|
||
|
if (module1) {
|
||
|
tc_del_module(factory, module1);
|
||
|
}
|
||
|
if (module2) {
|
||
|
tc_del_module(factory, module2);
|
||
|
}
|
||
|
test_result_helper("double_create::fini", tc_del_module_factory(factory), 0);
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
#define HOW_MUCH_STRESS (512) // at least 32, 2 to let the things work
|
||
|
static int test_stress_create(const char *modpath)
|
||
|
{
|
||
|
TCModule module[HOW_MUCH_STRESS];
|
||
|
int i, equality;
|
||
|
factory = tc_new_module_factory(modpath, verbose);
|
||
|
err = (factory == NULL) ?-1 :0;
|
||
|
|
||
|
test_result_helper("stress_create::init", err, 0);
|
||
|
|
||
|
for (i = 0; i < HOW_MUCH_STRESS; i++) {
|
||
|
module[i] = tc_new_module(factory, "filter", "null", TC_VIDEO);
|
||
|
if (module[i] == NULL) {
|
||
|
tc_log_error(__FILE__, "can't load filter_null (%i)", i);
|
||
|
break;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
test_result_helper("stress_create::create", i, HOW_MUCH_STRESS);
|
||
|
if (HOW_MUCH_STRESS != i) {
|
||
|
tc_log_error(__FILE__, "halted with i = %i (limit = %i)",
|
||
|
i, HOW_MUCH_STRESS);
|
||
|
return 1;
|
||
|
}
|
||
|
|
||
|
// note that we MUST start from 1
|
||
|
for (i = 1; i < HOW_MUCH_STRESS; i++) {
|
||
|
equality = tc_compare_modules(module[i-1], module[i]);
|
||
|
if (equality != 0) {
|
||
|
tc_log_error(__FILE__, "diversion! %i | %i", i-1, i);
|
||
|
break;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
test_result_helper("stress_create::check", i, HOW_MUCH_STRESS);
|
||
|
if (HOW_MUCH_STRESS != i) {
|
||
|
tc_log_error(__FILE__, "halted with i = %i (limit = %i)",
|
||
|
i, HOW_MUCH_STRESS);
|
||
|
return 1;
|
||
|
}
|
||
|
|
||
|
test_result_helper("stress_create::instances",
|
||
|
tc_instance_count(factory),
|
||
|
HOW_MUCH_STRESS);
|
||
|
test_result_helper("stress_create::descriptors",
|
||
|
tc_plugin_count(factory), 1);
|
||
|
|
||
|
|
||
|
for (i = 0; i < HOW_MUCH_STRESS; i++) {
|
||
|
tc_del_module(factory, module[i]);
|
||
|
}
|
||
|
|
||
|
test_result_helper("stress_create::instances (postnuke)",
|
||
|
tc_instance_count(factory), 0);
|
||
|
test_result_helper("stress_create::descriptors (postnuke)",
|
||
|
tc_plugin_count(factory), 0);
|
||
|
|
||
|
|
||
|
test_result_helper("stress_create::fini", tc_del_module_factory(factory), 0);
|
||
|
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
static int test_stress_load(const char *modpath)
|
||
|
{
|
||
|
TCModule module;
|
||
|
int i, breakage = 0, instances = 0, descriptors = 0;
|
||
|
factory = tc_new_module_factory(modpath, verbose);
|
||
|
err = (factory == NULL) ?-1 :0;
|
||
|
|
||
|
test_result_helper("stress_load::init", err, 0);
|
||
|
|
||
|
for (i = 0; i < HOW_MUCH_STRESS; i++) {
|
||
|
module = tc_new_module(factory, "filter", "null", TC_VIDEO);
|
||
|
if (module == NULL) {
|
||
|
tc_log_error(__FILE__, "can't load filter_null (%i)", i);
|
||
|
break;
|
||
|
}
|
||
|
|
||
|
instances = tc_instance_count(factory);
|
||
|
if(instances != 1) {
|
||
|
tc_log_error(__FILE__, "wrong instance count: %i, expected %i\n",
|
||
|
instances, 1);
|
||
|
breakage = 1;
|
||
|
break;
|
||
|
}
|
||
|
|
||
|
descriptors = tc_plugin_count(factory);
|
||
|
if(descriptors != 1) {
|
||
|
tc_log_error(__FILE__, "wrong descriptor count: %i, expected %i\n",
|
||
|
descriptors, 1);
|
||
|
breakage = 1;
|
||
|
break;
|
||
|
}
|
||
|
|
||
|
tc_del_module(factory, module);
|
||
|
|
||
|
instances = tc_instance_count(factory);
|
||
|
if(instances != 0) {
|
||
|
tc_log_error(__FILE__, "wrong instance count (postnuke): %i, expected %i\n",
|
||
|
instances, 0);
|
||
|
breakage = 1;
|
||
|
break;
|
||
|
}
|
||
|
|
||
|
descriptors = tc_plugin_count(factory);
|
||
|
if(descriptors != 0) {
|
||
|
tc_log_error(__FILE__, "wrong descriptor count (postnuke): %i, expected %i\n",
|
||
|
descriptors, 0);
|
||
|
breakage = 1;
|
||
|
break;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
test_result_helper("stress_load::check", breakage, 0);
|
||
|
test_result_helper("stress_load::fini", tc_del_module_factory(factory), 0);
|
||
|
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
static int test_load_filter_encode(const char *modpath)
|
||
|
{
|
||
|
TCModule module1 = NULL, module2 = NULL;
|
||
|
factory = tc_new_module_factory(modpath, verbose);
|
||
|
err = (factory == NULL) ?-1 :0;
|
||
|
|
||
|
test_result_helper("load_filter_encode::init", err, 0);
|
||
|
module1 = tc_new_module(factory, "filter", "null", TC_AUDIO);
|
||
|
if (module1 == NULL) {
|
||
|
tc_log_error(__FILE__, "can't load filter_null (1)");
|
||
|
}
|
||
|
module2 = tc_new_module(factory, "encode", "null", TC_VIDEO);
|
||
|
if (module2 == NULL) {
|
||
|
tc_log_error(__FILE__, "can't load encode_null (1)");
|
||
|
}
|
||
|
|
||
|
test_result_helper("load_filter_encode::check",
|
||
|
tc_compare_modules(module1, module2),
|
||
|
-1);
|
||
|
test_result_helper("load_filter_encode::instances",
|
||
|
tc_instance_count(factory),
|
||
|
2);
|
||
|
test_result_helper("load_filter_encode::descriptors",
|
||
|
tc_plugin_count(factory),
|
||
|
2);
|
||
|
if (module1) {
|
||
|
tc_del_module(factory, module1);
|
||
|
}
|
||
|
if (module2) {
|
||
|
tc_del_module(factory, module2);
|
||
|
}
|
||
|
test_result_helper("load_filter_encode::fini", tc_del_module_factory(factory), 0);
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
static int test_load_encode_multiplex(const char *modpath)
|
||
|
{
|
||
|
TCModule module1 = NULL, module2 = NULL;
|
||
|
factory = tc_new_module_factory(modpath, verbose);
|
||
|
err = (factory == NULL) ?-1 :0;
|
||
|
|
||
|
test_result_helper("load_encode_multiplex::init", err, 0);
|
||
|
module1 = tc_new_module(factory, "encode", "null", TC_VIDEO);
|
||
|
if (module1 == NULL) {
|
||
|
tc_log_error(__FILE__, "can't load encode_null (1)");
|
||
|
}
|
||
|
module2 = tc_new_module(factory, "multiplex", "null", TC_VIDEO|TC_AUDIO);
|
||
|
if (module2 == NULL) {
|
||
|
tc_log_error(__FILE__, "can't load multiplex_null (1)");
|
||
|
}
|
||
|
|
||
|
test_result_helper("load_encode_multiplex::check",
|
||
|
tc_compare_modules(module1, module2),
|
||
|
-1);
|
||
|
test_result_helper("load_encode_multiplex::instances",
|
||
|
tc_instance_count(factory),
|
||
|
2);
|
||
|
test_result_helper("load_encode_multiplex::descriptors",
|
||
|
tc_plugin_count(factory),
|
||
|
2);
|
||
|
if (module1) {
|
||
|
tc_del_module(factory, module1);
|
||
|
}
|
||
|
if (module2) {
|
||
|
tc_del_module(factory, module2);
|
||
|
}
|
||
|
test_result_helper("load_encode_multiplex::fini", tc_del_module_factory(factory), 0);
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
int main(int argc, char* argv[])
|
||
|
{
|
||
|
if(argc != 2) {
|
||
|
fprintf(stderr, "usage: %s /module/path\n", argv[0]);
|
||
|
exit(1);
|
||
|
}
|
||
|
|
||
|
vob = tc_zalloc(sizeof(vob_t));
|
||
|
|
||
|
putchar('\n');
|
||
|
test_bad_init(argv[1]);
|
||
|
putchar('\n');
|
||
|
test_init_fini(argv[1]);
|
||
|
putchar('\n');
|
||
|
test_bad_create(argv[1]);
|
||
|
putchar('\n');
|
||
|
test_create(argv[1]);
|
||
|
putchar('\n');
|
||
|
test_double_create(argv[1]);
|
||
|
putchar('\n');
|
||
|
test_stress_create(argv[1]);
|
||
|
putchar('\n');
|
||
|
test_stress_load(argv[1]);
|
||
|
putchar('\n');
|
||
|
test_load_filter_encode(argv[1]);
|
||
|
putchar('\n');
|
||
|
test_load_encode_multiplex(argv[1]);
|
||
|
|
||
|
tc_free(vob);
|
||
|
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
#include "static_optstr.h"
|
||
|
|
||
|
/*************************************************************************/
|
||
|
|
||
|
/*
|
||
|
* Local variables:
|
||
|
* c-file-style: "stroustrup"
|
||
|
* c-file-offsets: ((case-label . *) (statement-case-intro . *))
|
||
|
* indent-tabs-mode: nil
|
||
|
* End:
|
||
|
*
|
||
|
* vim: expandtab shiftwidth=4:
|
||
|
*/
|