123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170 |
- #include "asterisk.h"
- #include "asterisk/callerid.h"
- ASTERISK_FILE_VERSION(__FILE__, "$Revision$")
- #include "asterisk/utils.h"
- #include "asterisk/module.h"
- #include "asterisk/test.h"
- struct cid_set {
- char *cid;
- char *name;
- char *number;
- };
- AST_TEST_DEFINE(parse_nominal)
- {
- static const struct cid_set cid_sets[] = {
- {"\"name\" <number>", "name", "number"},
- {"\" name \" <number>", " name ", "number"},
- {"name <number>", "name", "number"},
- {" name <number>", "name", "number"},
- {"\"\" <number>", NULL, "number"},
- {"<number>", NULL, "number"},
- {"name", "name", NULL},
- {" name", "name", NULL},
- {"\"name\"", "name", NULL},
- {"\"*10\"", "*10", NULL},
- {" \"*10\"", "*10", NULL},
- {"\"name\" <>", "name", NULL},
- {"name <>", "name", NULL},
- {"1234", NULL, "1234"},
- {" 1234", NULL, "1234"},
- {"\"na\\\"me\" <number>", "na\"me", "number"},
- };
- char *name;
- char *number;
- int i;
- switch (cmd) {
- case TEST_INIT:
- info->name = "parse_nominal";
- info->category = "/main/callerid/";
- info->summary = "Callerid nominal parse unit test";
- info->description =
- "This tests parsing of nominal callerid strings.";
- return AST_TEST_NOT_RUN;
- case TEST_EXECUTE:
- break;
- }
- for (i = 0; i < ARRAY_LEN(cid_sets); i++) {
- RAII_VAR(char *, callerid, ast_strdup(cid_sets[i].cid), ast_free);
- ast_callerid_parse(callerid, &name, &number);
- if (!cid_sets[i].name == !ast_strlen_zero(name) || (cid_sets[i].name && strcmp(name, cid_sets[i].name))) {
- ast_test_status_update(test,
- "Expected callerid name '%s' instead of '%s'\n",
- cid_sets[i].name, name);
- return AST_TEST_FAIL;
- }
- if (!cid_sets[i].number == !ast_strlen_zero(number) || (cid_sets[i].number && strcmp(number, cid_sets[i].number))) {
- ast_test_status_update(test,
- "Expected callerid number '%s' instead of '%s'\n",
- cid_sets[i].number, number);
- return AST_TEST_FAIL;
- }
- }
- return AST_TEST_PASS;
- }
- AST_TEST_DEFINE(parse_off_nominal)
- {
- static const struct cid_set cid_sets[] = {
- {"na\\\"me <number>", "na\"me", "number"},
- {"\"na\"me\" <number>", "na\"me", "number"},
- {"na\"me <number>", "na\"me", "number"},
- {"\"name <number>", "\"name", "number"},
- {"name <number", "name", "number"},
- {"\"name <number>\"", "name", "number"},
- };
- char *name;
- char *number;
- int i;
- switch (cmd) {
- case TEST_INIT:
- info->name = "parse_off_nominal";
- info->category = "/main/callerid/";
- info->summary = "Callerid off-nominal parse unit test";
- info->description =
- "This tests parsing of off-nominal callerid strings.";
- return AST_TEST_NOT_RUN;
- case TEST_EXECUTE:
- break;
- }
- for (i = 0; i < ARRAY_LEN(cid_sets); i++) {
- RAII_VAR(char *, callerid, ast_strdup(cid_sets[i].cid), ast_free);
- ast_callerid_parse(callerid, &name, &number);
- if (!cid_sets[i].name == !ast_strlen_zero(name) || (cid_sets[i].name && strcmp(name, cid_sets[i].name))) {
- ast_test_status_update(test,
- "Expected callerid name '%s' instead of '%s'\n",
- cid_sets[i].name, name);
- return AST_TEST_FAIL;
- }
- if (!cid_sets[i].number == !ast_strlen_zero(number) || (cid_sets[i].number && strcmp(number, cid_sets[i].number))) {
- ast_test_status_update(test,
- "Expected callerid number '%s' instead of '%s'\n",
- cid_sets[i].number, number);
- return AST_TEST_FAIL;
- }
- }
- return AST_TEST_PASS;
- }
- static int unload_module(void)
- {
- AST_TEST_UNREGISTER(parse_nominal);
- AST_TEST_UNREGISTER(parse_off_nominal);
- return 0;
- }
- static int load_module(void)
- {
- AST_TEST_REGISTER(parse_nominal);
- AST_TEST_REGISTER(parse_off_nominal);
- return AST_MODULE_LOAD_SUCCESS;
- }
- AST_MODULE_INFO_STANDARD(ASTERISK_GPL_KEY, "Callerid Parse Tests");
|