mirror of
https://github.com/asterisk/asterisk.git
synced 2025-10-24 05:38:11 +00:00
Unit tests can now be passed custom arguments from the command
line. For example, the following command would run the "mytest" test
in the "/main/mycat" category with the option "myoption=54"
`CLI> test execute category /main/mycat name mytest options myoption=54`
You can also pass options to an entire category...
`CLI> test execute category /main/mycat options myoption=54`
Basically, everything after the "options" keyword is passed verbatim to
the test which must decide what to do with it.
* A new API ast_test_get_cli_args() was created to give the tests access to
the cli_args->argc and cli_args->argv elements.
* Although not needed for the option processing, a new macro
ast_test_validate_cleanup_custom() was added to test.h that allows you
to specify a custom error message instead of just "Condition failed".
* The test_skel.c was updated to demonstrate parsing options and the use
of the ast_test_validate_cleanup_custom() macro.
(cherry picked from commit 6d63b62853
)
141 lines
3.9 KiB
C
141 lines
3.9 KiB
C
/*
|
|
* Asterisk -- An open source telephony toolkit.
|
|
*
|
|
* Copyright (C) <Year>, <Your Name Here>
|
|
*
|
|
* <Your Name Here> <<Your Email Here>>
|
|
*
|
|
* See http://www.asterisk.org for more information about
|
|
* the Asterisk project. Please do not directly contact
|
|
* any of the maintainers of this project for assistance;
|
|
* the project provides a web site, mailing lists and IRC
|
|
* channels for your use.
|
|
*
|
|
* This program is free software, distributed under the terms of
|
|
* the GNU General Public License Version 2. See the LICENSE file
|
|
* at the top of the source tree.
|
|
*/
|
|
|
|
/*!
|
|
* \file
|
|
* \brief Skeleton Test
|
|
*
|
|
* \author\verbatim <Your Name Here> <<Your Email Here>> \endverbatim
|
|
*
|
|
* This is a skeleton for development of an Asterisk test module
|
|
* \ingroup tests
|
|
*/
|
|
|
|
/*** MODULEINFO
|
|
<depend>TEST_FRAMEWORK</depend>
|
|
<support_level>core</support_level>
|
|
***/
|
|
|
|
#include "asterisk.h"
|
|
|
|
#include "asterisk/utils.h"
|
|
#include "asterisk/module.h"
|
|
#include "asterisk/test.h"
|
|
|
|
AST_TEST_DEFINE(sample_test)
|
|
{
|
|
/* Retrieve the command line arguments used to invoke the test */
|
|
struct ast_cli_args *cli_args = ast_test_get_cli_args(test);
|
|
/* Set default values for the options */
|
|
int test_option = 999;
|
|
char test_option2[128] = { 0 };
|
|
void *ptr = NULL;
|
|
void *ptr2 = NULL;
|
|
int i;
|
|
enum ast_test_result_state rc = AST_TEST_PASS;
|
|
|
|
switch (cmd) {
|
|
case TEST_INIT:
|
|
info->name = "sample_test";
|
|
info->category = "/main/sample/";
|
|
info->summary = "sample unit test";
|
|
info->description =
|
|
"This demonstrates what is required to implement "
|
|
"a unit test. You can pass in test-option and "
|
|
"test-option2 as command line arguments to this "
|
|
"test. test-option is an integer and test-option2 "
|
|
"is a string.";
|
|
return AST_TEST_NOT_RUN;
|
|
case TEST_EXECUTE:
|
|
break;
|
|
}
|
|
|
|
/*
|
|
* This is an example of how to get command line arguments
|
|
* from the test framework. The arguments are "test-option"
|
|
* (expected to be an integer) and "test-option2" (expected
|
|
* to be a string).
|
|
*
|
|
* NOTES:
|
|
*
|
|
* cli_args will contain all of the command line arguments
|
|
* including "test execute", etc. so the location of the options
|
|
* will vary depending on how the test was invoked.
|
|
* For instance, this test could be run by either of the following:
|
|
*
|
|
* test execute category /main/sample/ options test-option=444
|
|
* test execute category /main/sample/ name sample_test options test-option=444
|
|
*
|
|
* You therefore need to test each of the items in the argv array
|
|
* to find the ones you are looking for.
|
|
*
|
|
* No special processing is done on string arguments so if your
|
|
* option value is a string, you must deal with the possibility
|
|
* of embedded spaces yourself.
|
|
*/
|
|
|
|
for (i = 0; i < cli_args->argc; i++) {
|
|
ast_test_status_update(test, "Test argument: %d: %s\n", i, cli_args->argv[i]);
|
|
if (ast_begins_with(cli_args->argv[i], "test-option=")) {
|
|
sscanf(cli_args->argv[i], "test-option=%d", &test_option);
|
|
}
|
|
if (ast_begins_with(cli_args->argv[i], "test-option2=")) {
|
|
sscanf(cli_args->argv[i], "test-option2=%s", test_option2);
|
|
}
|
|
}
|
|
|
|
ast_test_status_update(test, "Executing sample test with test-option=%d and test-option2=%s\n",
|
|
test_option, test_option2);
|
|
|
|
if (!(ptr = ast_malloc(8))) {
|
|
ast_test_status_update(test, "ast_malloc() failed\n");
|
|
return AST_TEST_FAIL;
|
|
}
|
|
|
|
ptr2 = ast_malloc(8);
|
|
/*
|
|
* This is an example of how to use the ast_test_validate_cleanup_custom
|
|
* macro to check a condition and cleanup if it fails.
|
|
* If ptr2 is NULL, rc will be set to AST_TEST_FAIL, the specified
|
|
* message will be printed, and the test will jump to the "done"
|
|
* label to perform cleanup.
|
|
*/
|
|
ast_test_validate_cleanup_custom(test, ptr2, rc, done, "ptr2 is NULL\n");
|
|
|
|
done:
|
|
|
|
ast_free(ptr);
|
|
ast_free(ptr2);
|
|
|
|
return rc;
|
|
}
|
|
|
|
static int unload_module(void)
|
|
{
|
|
AST_TEST_UNREGISTER(sample_test);
|
|
return 0;
|
|
}
|
|
|
|
static int load_module(void)
|
|
{
|
|
AST_TEST_REGISTER(sample_test);
|
|
return AST_MODULE_LOAD_SUCCESS;
|
|
}
|
|
|
|
AST_MODULE_INFO_STANDARD(ASTERISK_GPL_KEY, "Skeleton (sample) Test");
|