mirror of
				https://github.com/asterisk/asterisk.git
				synced 2025-11-03 20:38:59 +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.
		
			
				
	
	
		
			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");
 |