Try to make ast_format_str_reduce fail...
authorTilghman Lesher <tilghman@meg.abyt.es>
Thu, 4 Feb 2010 22:43:33 +0000 (22:43 +0000)
committerTilghman Lesher <tilghman@meg.abyt.es>
Thu, 4 Feb 2010 22:43:33 +0000 (22:43 +0000)
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@244768 65c4cc65-6c06-0410-ace0-fbb531ad65f3

main/file.c

index a5f85ff..b8b41e5 100644 (file)
@@ -45,6 +45,7 @@ ASTERISK_FILE_VERSION(__FILE__, "$Revision$")
 #include "asterisk/linkedlists.h"
 #include "asterisk/module.h"
 #include "asterisk/astobj2.h"
+#include "asterisk/test.h"
 
 /*
  * The following variable controls the layout of localized sound files.
@@ -1463,8 +1464,63 @@ static struct ast_cli_entry cli_file[] = {
        AST_CLI_DEFINE(handle_cli_core_show_file_formats, "Displays file formats")
 };
 
+#ifdef TEST_FRAMEWORK
+AST_TEST_DEFINE(test_ast_format_str_reduce)
+{
+       enum ast_test_result_state res = AST_TEST_PASS;
+       int i;
+       struct {
+               const char *input;
+               const char *output;
+       } tests[] = {
+               { "wav", "wav" },
+               { "wav|gsm", "wav|gsm" },
+               { "wav|ulaw|gsm", "wav|ulaw|gsm" },
+               { "wav|WAV|gsm", "wav|WAV|gsm" },
+               { "wav|wav49|gsm", "wav|wav49|gsm" },
+               { "wav|invalid|gsm", "wav|gsm" },
+               { "invalid|gsm", "gsm" },
+               { "ulaw|gsm|invalid", "ulaw|gsm" },
+               { "g723|g726-40|g729|gsm|ilbc|ogg|wav|WAV|siren7|siren14|sln", "g723|g726-40|g729|gsm|ilbc|ogg|wav|WAV|siren7|siren14" },
+               { "ulaw|gsm|ulaw", "ulaw|gsm" },
+               { "ulaw|alaw|gsm|wav|alaw|g729", "ulaw|alaw|gsm|wav|g729" },
+               { "", "" },
+               { NULL, },
+       };
+
+       switch (cmd) {
+       case TEST_INIT:
+               info->name = "test_ast_format_str_reduce";
+               info->category = "main/file/";
+               info->summary = "Test functionality of ast_format_str_reduce API";
+               info->description =
+                       "This test runs the format string reduction API through a series of tests to ensure that it is functioning properly.";
+               return AST_TEST_NOT_RUN;
+       case TEST_EXECUTE:
+               break;
+       }
+
+       ast_str_reset(args->ast_test_error_str);
+       for (i = 0; tests[i].input; i++) {
+               char tmp[256], *ret;
+               ast_copy_string(tmp, tests[i].input, sizeof(tmp));
+               if ((ret = ast_format_str_reduce(tmp)) && strcmp(ret, tests[i].output)) {
+                       res = AST_TEST_FAIL;
+                       ast_str_append(&args->ast_test_error_str, 0, "Format reduction of string '%s' produced '%s', but should have produced '%s'.\n",
+                                       tests[i].input, tmp, tests[i].output);
+               } else if (!ret && !ast_strlen_zero(tests[i].output)) {
+                       res = AST_TEST_FAIL;
+                       ast_str_append(&args->ast_test_error_str, 0, "Format reduction of string '%s' errored out, but should have produced '%s'.\n",
+                                       tests[i].input, tests[i].output);
+               }
+       }
+       return res;
+}
+#endif
+
 int ast_file_init(void)
 {
        ast_cli_register_multiple(cli_file, ARRAY_LEN(cli_file));
+       AST_TEST_REGISTER(test_ast_format_str_reduce);
        return 0;
 }