[asterisk-commits] mjordan: branch mjordan/voicemail_refactor_01_08_11 r330573 - /team/mjordan/v...

SVN commits to the Asterisk project asterisk-commits at lists.digium.com
Tue Aug 2 09:48:06 CDT 2011


Author: mjordan
Date: Tue Aug  2 09:48:02 2011
New Revision: 330573

URL: http://svnview.digium.com/svn/asterisk?view=rev&rev=330573
Log:
initial update

Added:
    team/mjordan/voicemail_refactor_01_08_11/apps/voicemail/
    team/mjordan/voicemail_refactor_01_08_11/apps/voicemail/test_vm_config_parser.c   (with props)
    team/mjordan/voicemail_refactor_01_08_11/apps/voicemail/test_vm_filesystem.c   (with props)
    team/mjordan/voicemail_refactor_01_08_11/apps/voicemail/vm_config_parser.c   (with props)
    team/mjordan/voicemail_refactor_01_08_11/apps/voicemail/vm_filesystem.c   (with props)
    team/mjordan/voicemail_refactor_01_08_11/apps/voicemail/vm_imap.c   (with props)
    team/mjordan/voicemail_refactor_01_08_11/apps/voicemail/vm_mail.c   (with props)
    team/mjordan/voicemail_refactor_01_08_11/apps/voicemail/vm_odbc.c   (with props)

Added: team/mjordan/voicemail_refactor_01_08_11/apps/voicemail/test_vm_config_parser.c
URL: http://svnview.digium.com/svn/asterisk/team/mjordan/voicemail_refactor_01_08_11/apps/voicemail/test_vm_config_parser.c?view=auto&rev=330573
==============================================================================
--- team/mjordan/voicemail_refactor_01_08_11/apps/voicemail/test_vm_config_parser.c (added)
+++ team/mjordan/voicemail_refactor_01_08_11/apps/voicemail/test_vm_config_parser.c Tue Aug  2 09:48:02 2011
@@ -1,0 +1,650 @@
+
+#include "asterisk.h"
+
+ASTERISK_FILE_VERSION(__FILE__, "$Revision$")
+
+#include "asterisk/test.h"
+#include "asterisk/app.h"
+
+#include "include/voicemail.h"
+#include "include/test_voicemail.h"
+
+/* The current default values, from vm_config_parser.c */
+
+static const unsigned int default_max_messages = 100;
+static const unsigned int default_max_messages_limit = 9999;
+static const unsigned int default_min_password_length = 0;
+static const char * default_sound_vm_password = "vm-password";
+static const char * default_sound_vm_newpassword = "vm-newpassword";
+static const char * default_sound_vm_password_changed = "vm-passchanged";
+static const char * default_sound_vm_reenter_password = "vm-reenterpassword";
+static const char * default_sound_vm_mismatch = "vm-mismatch";
+static const char * default_sound_vm_invalid_password = "vm-invalid-password";
+static const char * default_sound_vm_pls_try_again = "vm-pls-try-again";
+static const char * default_character_set = "ISO-8859-1";
+
+static const char * default_listen_control_forward_key = "#";
+static const char * default_listen_control_reverse_key = "*";
+static const char * default_listen_control_pause_key = "0";
+static const char * default_listen_control_restart_key = "2";
+static const char * default_listen_control_stop_key = "13456789";
+
+static const char * default_smdi_interface = "/dev/ttyS0";
+static const char * default_format_string = "wav";
+static const unsigned int default_skip_ms = 3000;
+static const unsigned int default_max_logins = 3;
+static const unsigned int default_min_say_duration = 2;
+static const unsigned int default_poll_frequency = 30;
+static const char * default_users_context = "default";
+static unsigned char default_adsifdn[4] = "\x00\x00\x00\x0F";
+static unsigned char default_adsisec[4] = "\x9B\xDB\xF7\xAC";
+static unsigned int default_adsiver = 1;
+static char default_email_date_format[32] = "%A, %B %d, %Y at %r";
+static char default_pager_date_format[32] = "%A, %B %d, %Y at %r";
+
+
+static struct ast_config * make_empty_config(void)
+{
+	struct ast_config *cfg = ast_config_new();
+	struct ast_category *tmp_category;
+
+	/* Add the [general] category */
+	tmp_category = ast_category_new("general", "voicemail.conf", 1);
+	ast_category_append(cfg, tmp_category);
+
+	return cfg;
+}
+
+static struct ast_config * make_populated_config(void)
+{
+	struct ast_config * cfg = ast_config_new();
+	struct ast_category *tmp_category;
+	struct ast_variable *tmp_variable;
+
+	/* Add the [general] category */
+	tmp_category = ast_category_new("general", "voicemail.conf", 1);
+
+	tmp_variable = ast_variable_new("format", "wav49|gsm|wav", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("serveremail", "asterisk", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("attach", "yes", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("maxmsg", "0", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("maxsecs", "180", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("minsecs", "3", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("maxgreet", "60", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("skipms", "4000", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("maxsilence", "10", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("silencethreshold", "128", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("maxlogins", "5", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("moveheard", "yes", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("forward_urgent_auto", "yes", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("userscontext", "not_default", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("externpass", "/usr/bin/myapp", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("externnotify", "/usr/bin/myapp", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("externpasscheck", "/usr/local/bin/voicemailpwcheck.py", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("directoryintro", "dir-intro", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("charset", "UTF-8", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("pbxskip", "yes", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("usedirectory", "yes", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("fromstring", "The Asterisk PBX", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("emailsubject", "[PBX]: New message ${VM_MSGNUM} in mailbox ${VM_MAILBOX}", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("emailbody", "Dear ${VM_NAME}:\n\n\tjust wanted to let you know you were just ${IF($[\"${VM_CIDNUM}\" = \"${ORIG_VM_CIDNUM}\"]?left:forwarded)} a ${VM_DUR} long message (number ${VM_MSGNUM})\nin mailbox ${VM_MAILBOX} from ${VM_CALLERID}, on ${VM_DATE},\n${IF($[\"${VM_CIDNUM}\" = \"${ORIG_VM_CIDNUM}\"]?so:(originally sent by ${ORIG_VM_CALLERID} on ${ORIG_VM_DATE})\nso)} you might want to check it when you get a chance.  Thanks!\n\n\t\t\t\t--Asterisk\n", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("pagerfromstring", "The Asterisk PBX", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("pagersubject", "New VM", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("pagerbody", "New ${VM_DUR} long msg in box ${VM_MAILBOX}\nfrom ${VM_CALLERID}, on ${VM_DATE}", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("emaildateformat", "%A, %B, %Y", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("pagerdateformat", "%T %D", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("mailcmd", "/usr/sbin/fakemail", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("pollmailboxes", "yes", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("pollfreq", "180", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("passwordlocation", "spooldir", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("messagewrap", "yes", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("minpassword", "4", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("backupdeleted", "1000", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("tz", "central", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("attachfmt", "gsm", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("saycid", "yes", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("cidinternalcontexts", "default,internal", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("sayduration", "no", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("saydurationm", "5", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("dialout", "fromvm", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("sendvoicemail", "yes", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("callback", "fromvm", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("exitcontext", "fromvm", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("review", "yes", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("operator", "yes", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("envelope", "no", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("volgain", "1.0", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("nextaftercmd", "yes", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("forcename", "yes", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("forcegreetings", "yes", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("tempgreetwarn", "yes", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("locale", "de_DE.UTF-8", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("folderpath", "/var/spool/test/", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+
+	/* SMDI */
+	tmp_variable = ast_variable_new("smdienable", "yes", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("smdiport", "/dev/ttyS1", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+
+	/* ADSI */
+	tmp_variable = ast_variable_new("adsifdn", "ABABABAB", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("adsisec", "CDCDCDCD", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("adsiver", "9", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+
+	/* Sounds */
+	tmp_variable = ast_variable_new("vm-password", "custom-vm-password", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("vm-newpassword", "custom-vm-newpassword", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("vm-passchanged", "custom-vm-passchanged", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("vm-reenterpassword", "custom-vm-reenterpassword", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("vm-mismatch", "custom-vm-mismatch", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("vm-invalid-password", "custom-vm-invalid-password", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("vm-pls-try-again", "custom-vm-pls-try-again", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+
+	/* Listen control */
+	tmp_variable = ast_variable_new("listen-control-forward-key", "*", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("listen-control-reverse-key", "#", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("listen-control-pause-key", "1", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("listen-control-restart-key", "0", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("listen-control-stop-key", "23456789", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+
+	ast_category_append(cfg, tmp_category);
+
+	/* zone messages */
+	tmp_category = ast_category_new("zonemessages", "voicemail.conf", 1);
+
+	tmp_variable = ast_variable_new("eastern", "America/New_York|'vm-received' Q 'digits/at' IMp", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("central", "America/Chicago|'vm-received' Q 'digits/at' IMp", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("central24", "America/Chicago|'vm-received' q 'digits/at' H N 'hours'", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("military", "Zulu|'vm-received' q 'digits/at' H N 'hours' 'phonetic/z_p'", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("european", "Europe/Copenhagen|'vm-received' a d b 'digits/at' HM", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+
+	ast_category_append(cfg, tmp_category);
+
+	/* users */
+	tmp_category = ast_category_new("default", "voicemail.conf", 1);
+
+	tmp_variable = ast_variable_new("1234", "4242,Example Mailbox,root at localhost", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("4200", "9855,Mark Spencer,markster at linux-support.net,mypager at digium.com,attach=no|serveremail=myaddy at digium.com|tz=central|maxmsg=10", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("4069", "6522,Matt Brooks,matt at marko.net,,|tz=central|attach=yes|saycid=yes|dialout=fromvm|callback=fromvm|review=yes|operator=yes|envelope=yes|moveheard=yes|sayduration=yes|saydurationm=1", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+	tmp_variable = ast_variable_new("7200", "6522,Matt Jordan,,,delete=1|emailsubject=You have a new voicemail.|emailbody=Click on the attachment to listen.\n\nThanks-\tAsterisk!\n|rip=2010-06-04", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+
+	ast_category_append(cfg, tmp_category);
+
+	tmp_category = ast_category_new("test", "voicemail.conf", 1);
+
+	tmp_variable = ast_variable_new("7200", "6522,Matt Jordan,,,delete=1|emailsubject=You have a new voicemail.|emailbody=Click on the attachment to listen.\n\nThanks-\tAsterisk!\n|rip=2010-06-04", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+
+	ast_category_append(cfg, tmp_category);
+
+	return cfg;
+}
+
+AST_TEST_DEFINE(test_vm_default_config)
+{
+	int result = AST_TEST_PASS;
+	struct ast_config * cfg = make_empty_config();
+	struct ast_category * tmp_category;
+	struct ast_variable * tmp_variable;
+	struct vm_config * vm_config;
+
+	switch (cmd) {
+	case TEST_INIT:
+		info->name = "test_vm_default_config";
+		info->category = "/apps/app_voicemail/";
+		info->summary = "VoiceMail Config Parser (default) unit test";
+		info->description =
+			"This tests the parsing of an empty ast_config object and the populating of the default field values";
+		return AST_TEST_NOT_RUN;
+	case TEST_EXECUTE:
+		break;
+	}
+
+	/* Test loading an empty ast_config object */
+	if (vm_load_config(0, &cfg, &vm_config)) {
+		ast_test_status_update(test, "Failed to load vm_config using empty (default) ast_config object\n");
+		result = AST_TEST_FAIL;
+	} else {
+		/* Check all defaults */
+		/* Sounds */
+		VM_TEST_STRING_EQUAL(default_sound_vm_password, vm_config->sound_config->vm_password);
+		VM_TEST_STRING_EQUAL(default_sound_vm_newpassword, vm_config->sound_config->vm_newpassword);
+		VM_TEST_STRING_EQUAL(default_sound_vm_password_changed, vm_config->sound_config->vm_password_changed);
+		VM_TEST_STRING_EQUAL(default_sound_vm_reenter_password, vm_config->sound_config->vm_reenter_password);
+		VM_TEST_STRING_EQUAL(default_sound_vm_mismatch, vm_config->sound_config->vm_mismatch);
+		VM_TEST_STRING_EQUAL(default_sound_vm_invalid_password, vm_config->sound_config->vm_invalid_password);
+		VM_TEST_STRING_EQUAL(default_sound_vm_pls_try_again, vm_config->sound_config->vm_pls_try_again);
+
+		/* Listen control */
+		VM_TEST_STRING_EQUAL(default_listen_control_forward_key, vm_config->listen_control_config->listen_control_forward_key);
+		VM_TEST_STRING_EQUAL(default_listen_control_reverse_key, vm_config->listen_control_config->listen_control_reverse_key);
+		VM_TEST_STRING_EQUAL(default_listen_control_pause_key, vm_config->listen_control_config->listen_control_pause_key);
+		VM_TEST_STRING_EQUAL(default_listen_control_restart_key, vm_config->listen_control_config->listen_control_restart_key);
+		VM_TEST_STRING_EQUAL(default_listen_control_stop_key, vm_config->listen_control_config->listen_control_stop_key);
+
+		/* ADSI Settings */
+		VM_TEST_MEM_EQUAL(default_adsifdn, vm_config->adsi_config->adsifdn, 4);
+		VM_TEST_MEM_EQUAL(default_adsisec, vm_config->adsi_config->adsisec, 4);
+		VM_TEST_NUMERIC_EQUAL(default_adsiver, vm_config->adsi_config->adsiver);
+
+		/* SMDI */
+		VM_TEST_NUMERIC_EQUAL(0, vm_config->smdi_config->enabled);
+		/* SMDI interface should not be set if it is not enabled */
+		VM_TEST_STRING_NOT_EQUAL(default_smdi_interface, vm_config->smdi_config->smdi_interface);
+
+		/* General settings */
+		VM_TEST_STRING_EQUAL(default_format_string, vm_config->format);
+		VM_TEST_STRING_EQUAL(default_users_context, vm_config->default_users_context);
+		VM_TEST_STRING_EQUAL(default_email_date_format, vm_config->email_date_format);
+		VM_TEST_STRING_EQUAL(default_pager_date_format, vm_config->pager_date_format);
+		VM_TEST_STRING_EQUAL(default_character_set, vm_config->charset);
+		VM_TEST_NUMERIC_EQUAL(default_skip_ms, vm_config->skip_ms);
+		VM_TEST_NUMERIC_EQUAL(default_max_logins, vm_config->max_logins);
+		VM_TEST_NUMERIC_EQUAL(default_min_say_duration, vm_config->min_say_duration);
+		VM_TEST_NUMERIC_EQUAL(default_poll_frequency, vm_config->poll_frequency);
+		VM_TEST_NUMERIC_EQUAL(default_min_password_length, vm_config->min_password_length);
+		VM_TEST_NUMERIC_EQUAL(default_max_messages, vm_config->max_messages);
+	}
+
+	/* Check that SMDI is set properly if enabled */
+	tmp_category = ast_category_get(cfg, "general");
+	tmp_variable = ast_variable_new("smdienable", "1", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+
+
+	/* Test loading the ast_config object */
+	if (vm_load_config(0, &cfg, &vm_config)) {
+		ast_test_status_update(test, "Failed to load vm_config using ast_config object with smdienabled flag\n");
+		result = AST_TEST_FAIL;
+	} else {
+		/* SMDI */
+		VM_TEST_NUMERIC_NOT_EQUAL(0, vm_config->smdi_config->enabled);
+		VM_TEST_STRING_EQUAL(default_smdi_interface, vm_config->smdi_config->smdi_interface);
+	}
+
+	ast_config_destroy(cfg);
+	ao2_ref(vm_config, -1);
+
+	return result;
+}
+
+AST_TEST_DEFINE(test_vm_parse_config)
+{
+	int result = AST_TEST_PASS;
+	struct ast_config * cfg = make_populated_config();
+	struct vm_config * vm_config;
+	unsigned char test_adsifdn[4] = "\xAB\xAB\xAB\xAB";
+	unsigned char test_adsisec[4] = "\xCD\xCD\xCD\xCD";
+
+	switch (cmd) {
+	case TEST_INIT:
+		info->name = "test_vm_parse_config";
+		info->category = "/apps/app_voicemail/";
+		info->summary = "VoiceMail Config Parser unit test";
+		info->description =
+			"This tests the parsing of an ast_config object and the populating of all possible field values";
+		return AST_TEST_NOT_RUN;
+	case TEST_EXECUTE:
+		break;
+	}
+
+	/* Load the ast_config object and check the values */
+	if (vm_load_config(0, &cfg, &vm_config)) {
+		ast_test_status_update(test, "Failed to load vm_config using populated ast_config object\n");
+		result = AST_TEST_FAIL;
+	} else {
+		VM_TEST_MEM_EQUAL(test_adsifdn,vm_config->adsi_config->adsifdn, 4);
+		VM_TEST_MEM_EQUAL(test_adsisec, vm_config->adsi_config->adsisec, 4);
+		VM_TEST_NUMERIC_EQUAL(9, vm_config->adsi_config->adsiver);
+
+		VM_TEST_STRING_EQUAL("gsm", vm_config->attach_format);
+		VM_TEST_STRING_EQUAL("fromvm", vm_config->callback_context);
+		VM_TEST_STRING_EQUAL("UTF-8", vm_config->charset);
+		VM_TEST_STRING_EQUAL("default", vm_config->cid_internal_contexts[0]);
+		VM_TEST_STRING_EQUAL("internal", vm_config->cid_internal_contexts[1]);
+		VM_TEST_STRING_EQUAL("not_default", vm_config->default_users_context);
+		VM_TEST_STRING_EQUAL("fromvm", vm_config->dial_out_context);
+		VM_TEST_STRING_EQUAL("dir-intro", vm_config->directory_intro_path);
+
+		VM_TEST_STRING_EQUAL("%A, %B, %Y",vm_config->email_date_format);
+		VM_TEST_STRING_EQUAL("[PBX]: New message ${VM_MSGNUM} in mailbox ${VM_MAILBOX}", vm_config->email_subject);
+		VM_TEST_STRING_EQUAL("Dear ${VM_NAME}:\n\n\tjust wanted to let you know you were just ${IF($[\"${VM_CIDNUM}\" = \"${ORIG_VM_CIDNUM}\"]?left:forwarded)} a ${VM_DUR} long message (number ${VM_MSGNUM})\nin mailbox ${VM_MAILBOX} from ${VM_CALLERID}, on ${VM_DATE},\n${IF($[\"${VM_CIDNUM}\" = \"${ORIG_VM_CIDNUM}\"]?so:(originally sent by ${ORIG_VM_CALLERID} on ${ORIG_VM_DATE})\nso)} you might want to check it when you get a chance.  Thanks!\n\n\t\t\t\t--Asterisk\n", vm_config->email_body);
+		VM_TEST_STRING_EQUAL("asterisk", vm_config->email_server);
+		VM_TEST_STRING_EQUAL("The Asterisk PBX", vm_config->email_from_string);
+		VM_TEST_STRING_EQUAL("/usr/bin/myapp", vm_config->extern_notify_cmd);
+		VM_TEST_STRING_EQUAL("/usr/local/bin/voicemailpwcheck.py", vm_config->extern_pass_check_cmd);
+		VM_TEST_STRING_EQUAL("/usr/bin/myapp", vm_config->extern_pass_cmd);
+		VM_TEST_STRING_EQUAL("/var/spool/test/", vm_config->folder_path);
+		VM_TEST_STRING_EQUAL("wav49|gsm|wav", vm_config->format);
+		VM_TEST_NUMERIC_EQUAL(VM_ATTACH, ast_test_flag((&vm_config->globalflags), VM_ATTACH));
+		VM_TEST_NUMERIC_EQUAL(VM_MOVEHEARD, ast_test_flag((&vm_config->globalflags), VM_MOVEHEARD));
+		VM_TEST_NUMERIC_EQUAL(VM_FWDURGAUTO, ast_test_flag((&vm_config->globalflags), VM_FWDURGAUTO));
+		VM_TEST_NUMERIC_EQUAL(VM_PBXSKIP, ast_test_flag((&vm_config->globalflags), VM_PBXSKIP));
+		VM_TEST_NUMERIC_EQUAL(VM_DIRECFORWARD, ast_test_flag((&vm_config->globalflags), VM_DIRECFORWARD));
+		VM_TEST_NUMERIC_EQUAL(VM_POLLMAILBOXES, ast_test_flag((&vm_config->globalflags), VM_POLLMAILBOXES));
+		VM_TEST_NUMERIC_EQUAL(VM_MESSAGEWRAP, ast_test_flag((&vm_config->globalflags), VM_MESSAGEWRAP));
+		VM_TEST_NUMERIC_EQUAL(VM_SAYCID, ast_test_flag((&vm_config->globalflags), VM_SAYCID));
+		VM_TEST_NUMERIC_EQUAL(0, ast_test_flag((&vm_config->globalflags), VM_SAYDURATION));
+		VM_TEST_NUMERIC_EQUAL(VM_SVMAIL, ast_test_flag((&vm_config->globalflags), VM_SVMAIL));
+		VM_TEST_NUMERIC_EQUAL(VM_REVIEW, ast_test_flag((&vm_config->globalflags), VM_REVIEW));
+		VM_TEST_NUMERIC_EQUAL(VM_OPERATOR, ast_test_flag((&vm_config->globalflags), VM_OPERATOR));
+		VM_TEST_NUMERIC_EQUAL(0, ast_test_flag((&vm_config->globalflags), VM_ENVELOPE));
+		VM_TEST_NUMERIC_EQUAL(VM_SKIPAFTERCMD, ast_test_flag((&vm_config->globalflags), VM_SKIPAFTERCMD));
+		VM_TEST_NUMERIC_EQUAL(VM_FORCEGREET, ast_test_flag((&vm_config->globalflags), VM_FORCEGREET));
+		VM_TEST_NUMERIC_EQUAL(VM_FORCENAME, ast_test_flag((&vm_config->globalflags), VM_FORCENAME));
+		VM_TEST_NUMERIC_EQUAL(VM_TEMPGREETWARN, ast_test_flag((&vm_config->globalflags), VM_TEMPGREETWARN));
+
+		VM_TEST_STRING_EQUAL("*", vm_config->listen_control_config->listen_control_forward_key);
+		VM_TEST_STRING_EQUAL("1", vm_config->listen_control_config->listen_control_pause_key);
+		VM_TEST_STRING_EQUAL("0", vm_config->listen_control_config->listen_control_restart_key);
+		VM_TEST_STRING_EQUAL("#", vm_config->listen_control_config->listen_control_reverse_key);
+		VM_TEST_STRING_EQUAL("23456789", vm_config->listen_control_config->listen_control_stop_key);
+
+		VM_TEST_STRING_EQUAL("de_DE.UTF-8", vm_config->locale);
+		VM_TEST_STRING_EQUAL("/usr/sbin/fakemail", vm_config->mail_command);
+		VM_TEST_NUMERIC_EQUAL(1000, vm_config->max_deleted_messages);
+		VM_TEST_NUMERIC_EQUAL(5, vm_config->max_logins);
+		VM_TEST_NUMERIC_EQUAL(180, vm_config->max_message_duration);
+		VM_TEST_NUMERIC_EQUAL(60, vm_config->max_message_greeting_length);
+		VM_TEST_NUMERIC_EQUAL(0, vm_config->max_messages);
+		VM_TEST_NUMERIC_EQUAL(10000, vm_config->max_silence);
+		VM_TEST_NUMERIC_EQUAL(3, vm_config->min_message_duration);
+		VM_TEST_NUMERIC_EQUAL(4, vm_config->min_password_length);
+		VM_TEST_NUMERIC_EQUAL(5, vm_config->min_say_duration);
+		VM_TEST_STRING_EQUAL("fromvm", vm_config->op_exit_context);
+		VM_TEST_STRING_EQUAL("%T %D", vm_config->pager_date_format);
+		VM_TEST_STRING_EQUAL("New ${VM_DUR} long msg in box ${VM_MAILBOX}\nfrom ${VM_CALLERID}, on ${VM_DATE}", vm_config->pager_body);
+		VM_TEST_STRING_EQUAL("The Asterisk PBX", vm_config->pager_from_string);
+		VM_TEST_STRING_EQUAL("New VM", vm_config->pager_subject);
+		VM_TEST_NUMERIC_EQUAL(OPT_PWLOC_SPOOLDIR, vm_config->password_location);
+		VM_TEST_NUMERIC_EQUAL(VM_PWD_CHANGE_EXTERNAL, ast_test_flag((&vm_config->passwordflags), VM_PWD_CHANGE_EXTERNAL));
+		VM_TEST_NUMERIC_EQUAL(180, vm_config->poll_frequency);
+		VM_TEST_NUMERIC_EQUAL(128, vm_config->silence_threshold);
+		VM_TEST_NUMERIC_EQUAL(4000, vm_config->skip_ms);
+
+		VM_TEST_NUMERIC_NOT_EQUAL(0, vm_config->smdi_config->enabled);
+		VM_TEST_STRING_EQUAL("/dev/ttyS1", vm_config->smdi_config->smdi_interface);
+
+		VM_TEST_STRING_EQUAL("custom-vm-invalid-password", vm_config->sound_config->vm_invalid_password);
+		VM_TEST_STRING_EQUAL("custom-vm-mismatch", vm_config->sound_config->vm_mismatch);
+		VM_TEST_STRING_EQUAL("custom-vm-newpassword", vm_config->sound_config->vm_newpassword);
+		VM_TEST_STRING_EQUAL("custom-vm-password", vm_config->sound_config->vm_password);
+		VM_TEST_STRING_EQUAL("custom-vm-passchanged", vm_config->sound_config->vm_password_changed);
+		VM_TEST_STRING_EQUAL("custom-vm-pls-try-again", vm_config->sound_config->vm_pls_try_again);
+		VM_TEST_STRING_EQUAL("custom-vm-reenterpassword", vm_config->sound_config->vm_reenter_password);
+
+		VM_TEST_NUMERIC_EQUAL(1.0, vm_config->volgain);
+		VM_TEST_STRING_EQUAL("central", vm_config->zonetag);
+
+		ao2_ref(vm_config, -1);
+	}
+
+	ast_config_destroy(cfg);
+
+	return result;
+}
+
+AST_TEST_DEFINE(test_vm_reload_config)
+{
+	int result = AST_TEST_PASS;
+	struct ast_config * cfg = make_empty_config();
+	struct vm_config * vm_config;
+
+	switch (cmd) {
+	case TEST_INIT:
+		info->name = "test_vm_reload_config";
+		info->category = "/apps/app_voicemail/";
+		info->summary = "VoiceMail Config Parser reload unit test";
+		info->description =
+			"This tests the reloading of ast_config object";
+		return AST_TEST_NOT_RUN;
+	case TEST_EXECUTE:
+		break;
+	}
+
+	/* Test loading the empty object */
+	if (vm_load_config(0, &cfg, &vm_config)) {
+		ast_test_status_update(test, "Failed to load vm_config using empty ast_config object\n");
+		result = AST_TEST_FAIL;
+	} else {
+		/* Check that the folder path is set to the default */
+		VM_TEST_STRING_EQUAL("/var/spool/asterisk/voicemail/", vm_config->folder_path);
+	}
+
+	ast_config_destroy(cfg);
+
+	/* Reload using the current voicemail.conf. */
+	if (vm_load_config(1, &cfg, &vm_config)) {
+		ast_test_status_update(test, "Failed to execute reload using voicemail.conf\n");
+		result = AST_TEST_FAIL;
+	}
+
+	ast_config_destroy(cfg);
+	ao2_ref(vm_config, -1);
+
+	return result;
+}
+
+AST_TEST_DEFINE(test_vm_user_default)
+{
+	int result = AST_TEST_PASS;
+	struct ast_config * cfg = make_populated_config();
+	struct ast_vm_user * vmu = NULL;
+	struct vm_config * vm_config;
+
+	switch (cmd) {
+	case TEST_INIT:
+		info->name = "test_vm_default_user";
+		info->category = "/apps/app_voicemail/";
+		info->summary = "VoiceMail Config Parser default user test";
+		info->description =
+			"This tests the creation of a voicemail user and the population of their values using the defaults from the voicemail config";
+		return AST_TEST_NOT_RUN;
+	case TEST_EXECUTE:
+		break;
+	}
+
+	if (vm_load_config(0, &cfg, &vm_config)) {
+		ast_test_status_update(test, "Failed to load vm_config using empty ast_config object\n");
+		result = AST_TEST_FAIL;
+	} else {
+
+		/* Extract the basic user */
+		if (!(vmu = vm_find_user("default", "1234"))) {
+			ast_test_status_update(test, "Failed to find user default, 1234\n");
+			result = AST_TEST_FAIL;
+		} else {
+			/* Check the properties to make sure the defaults are populated either from the config or from presets */
+			VM_TEST_STRING_EQUAL("", vmu->attachfmt);
+			VM_TEST_STRING_EQUAL("fromvm", vmu->callback);
+			VM_TEST_STRING_EQUAL("default", vmu->context);
+			VM_TEST_STRING_EQUAL("fromvm", vmu->dialout);
+			VM_TEST_STRING_EQUAL("root at localhost", vmu->email);
+			VM_TEST_STRING_EQUAL("fromvm",vmu->exit);
+			VM_TEST_STRING_EQUAL("Example Mailbox", vmu->fullname);
+			VM_TEST_STRING_EQUAL(vm_config->locale, vmu->locale);
+			VM_TEST_STRING_EQUAL("1234", vmu->mailbox);
+			VM_TEST_NUMERIC_EQUAL(vm_config->max_deleted_messages, vmu->maxdeletedmsg);
+			VM_TEST_NUMERIC_EQUAL(vm_config->max_messages, vmu->maxmsg);
+			VM_TEST_NUMERIC_EQUAL(vm_config->max_message_duration, vmu->maxsecs);
+			VM_TEST_NUMERIC_EQUAL(vm_config->min_message_duration, vmu->minsecs);
+			VM_TEST_STRING_EQUAL("", vmu->pager);
+			VM_TEST_STRING_EQUAL("4242", vmu->password);
+			VM_TEST_NUMERIC_EQUAL(OPT_PWLOC_SPOOLDIR, vmu->passwordlocation);
+			VM_TEST_NUMERIC_EQUAL(5, vmu->saydurationm);
+			VM_TEST_STRING_EQUAL("", vmu->serveremail);
+			VM_TEST_NUMERIC_EQUAL(1.0, vmu->volgain);
+			VM_TEST_STRING_EQUAL("central", vmu->zonetag);
+
+			ao2_ref(vmu, -1);
+		}
+	}
+
+	ast_config_destroy(cfg);
+	ao2_ref(vm_config, -1);
+
+	return result;
+}
+
+AST_TEST_DEFINE(test_vm_user_overrides)
+{
+	int result = AST_TEST_PASS;
+	struct ast_config * cfg = make_populated_config();
+	struct ast_vm_user * vmu = NULL;
+	struct vm_config * vm_config;
+
+	switch (cmd) {
+	case TEST_INIT:
+		info->name = "test_vm_user_overrides";
+		info->category = "/apps/app_voicemail/";
+		info->summary = "VoiceMail Config Parser default user test";
+		info->description =
+			"This tests the creation of a voicemail user and the population of their values using the overrides from their configuration";
+		return AST_TEST_NOT_RUN;
+	case TEST_EXECUTE:
+		break;
+	}
+
+	if (vm_load_config(0, &cfg, &vm_config)) {
+		ast_test_status_update(test, "Failed to load vm_config using empty ast_config object\n");
+		result = AST_TEST_FAIL;
+	} else {
+
+		/* Extract a user */
+		if (!(vmu = vm_find_user("default", "7200"))) {
+			ast_test_status_update(test, "Failed to find user default, 7200\n");
+			result = AST_TEST_FAIL;
+		} else {
+			/* Check the properties to make sure the defaults are populated either from the config or from presets */
+			VM_TEST_STRING_EQUAL("", vmu->attachfmt);
+			VM_TEST_STRING_EQUAL("fromvm", vmu->callback);
+			VM_TEST_STRING_EQUAL("default", vmu->context);
+			VM_TEST_STRING_EQUAL("fromvm", vmu->dialout);
+			VM_TEST_STRING_EQUAL("", vmu->email);
+			VM_TEST_STRING_EQUAL("fromvm",vmu->exit);
+			VM_TEST_NUMERIC_EQUAL(VM_DELETE, ast_test_flag(vmu, VM_DELETE));
+			VM_TEST_STRING_EQUAL("Matt Jordan", vmu->fullname);
+			VM_TEST_STRING_EQUAL(vm_config->locale, vmu->locale);
+			VM_TEST_STRING_EQUAL("7200", vmu->mailbox);
+			VM_TEST_STRING_EQUAL("You have a new voicemail.", vmu->emailsubject);
+			VM_TEST_STRING_EQUAL("Click on the attachment to listen.\n\nThanks-\tAsterisk!\n", vmu->emailbody);
+			VM_TEST_NUMERIC_EQUAL(vm_config->max_deleted_messages, vmu->maxdeletedmsg);
+			VM_TEST_NUMERIC_EQUAL(vm_config->max_messages, vmu->maxmsg);
+			VM_TEST_NUMERIC_EQUAL(vm_config->max_message_duration, vmu->maxsecs);
+			VM_TEST_NUMERIC_EQUAL(vm_config->min_message_duration, vmu->minsecs);
+			VM_TEST_STRING_EQUAL("", vmu->pager);
+			VM_TEST_STRING_EQUAL("6522", vmu->password);
+			VM_TEST_NUMERIC_EQUAL(OPT_PWLOC_SPOOLDIR, vmu->passwordlocation);
+			VM_TEST_NUMERIC_EQUAL(5, vmu->saydurationm);
+			VM_TEST_STRING_EQUAL("", vmu->serveremail);
+			VM_TEST_NUMERIC_EQUAL(1.0, vmu->volgain);
+			VM_TEST_STRING_EQUAL("central", vmu->zonetag);
+
+			ao2_ref(vmu, -1);
+		}
+	}
+
+	ast_config_destroy(cfg);
+	ao2_ref(vm_config, -1);
+
+	return result;
+}
+
+void vm_register_config_tests(void)
+{
+	AST_TEST_REGISTER(test_vm_default_config);
+	AST_TEST_REGISTER(test_vm_parse_config);
+	AST_TEST_REGISTER(test_vm_reload_config);
+	AST_TEST_REGISTER(test_vm_user_default);
+	AST_TEST_REGISTER(test_vm_user_overrides);
+}
+
+void vm_unregister_config_tests(void)
+{
+	AST_TEST_UNREGISTER(test_vm_default_config);
+	AST_TEST_UNREGISTER(test_vm_parse_config);
+	AST_TEST_UNREGISTER(test_vm_reload_config);
+	AST_TEST_UNREGISTER(test_vm_user_default);
+	AST_TEST_UNREGISTER(test_vm_user_overrides);
+}

Propchange: team/mjordan/voicemail_refactor_01_08_11/apps/voicemail/test_vm_config_parser.c
------------------------------------------------------------------------------
    svn:eol-style = native

Propchange: team/mjordan/voicemail_refactor_01_08_11/apps/voicemail/test_vm_config_parser.c
------------------------------------------------------------------------------
    svn:keywords = Author Date Id Revision

Propchange: team/mjordan/voicemail_refactor_01_08_11/apps/voicemail/test_vm_config_parser.c
------------------------------------------------------------------------------
    svn:mime-type = text/plain

Added: team/mjordan/voicemail_refactor_01_08_11/apps/voicemail/test_vm_filesystem.c
URL: http://svnview.digium.com/svn/asterisk/team/mjordan/voicemail_refactor_01_08_11/apps/voicemail/test_vm_filesystem.c?view=auto&rev=330573
==============================================================================
--- team/mjordan/voicemail_refactor_01_08_11/apps/voicemail/test_vm_filesystem.c (added)
+++ team/mjordan/voicemail_refactor_01_08_11/apps/voicemail/test_vm_filesystem.c Tue Aug  2 09:48:02 2011
@@ -1,0 +1,1666 @@
+
+#include "asterisk.h"
+
+ASTERISK_FILE_VERSION(__FILE__, "$Revision$")
+
+#include <dirent.h>
+#include <sys/stat.h>
+
+#include "asterisk/test.h"
+#include "asterisk/app.h"
+
+#include "include/voicemail.h"
+#include "include/test_voicemail.h"
+
+static const char * MSG_INFO_CATEGORY = "message";
+
+static const char * MSG_INFO_FLD_ORIGMAILBOX = "origmailbox";
+
+static const char * MSG_INFO_FLD_CONTEXT = "context";
+
+static const char * MSG_INFO_FLD_MACROCONTEXT = "macrocontext";
+
+static const char * MSG_INFO_FLD_EXTEN = "exten";
+
+static const char * MSG_INFO_FLD_RDNIS = "rdnis";
+
+static const char * MSG_INFO_FLD_PRIORITY = "priority";
+
+static const char * MSG_INFO_FLD_CALLERCHAN = "callerchan";
+
+static const char * MSG_INFO_FLD_CALLERID = "callerid";
+
+static const char * MSG_INFO_FLD_ORIGDATE = "origdate";
+
+static const char * MSG_INFO_FLD_ORIGTIME = "origtime";
+
+static const char * MSG_INFO_FLD_CATEGORY = "category";
+
+static const char * MSG_INFO_FLD_FLAG = "flag";
+
+static const char * MSG_INFO_FLD_DURATION = "duration";
+
+/* Basic test definition block */
+/*
+AST_TEST_DEFINE(test_vm_fs_METHOD_NAME)
+{
+	int result = AST_TEST_FAIL;
+
+	switch (cmd) {
+	case TEST_INIT:
+		info->name = "vm_fs_METHOD_NAME";
+		info->category = "/apps/app_voicemail/";
+		info->summary = "VoiceMail FileSystem METHOD_NAME unit test";
+		info->description =
+			"This tests ... using the file system backend driver";
+		return AST_TEST_NOT_RUN;
+	case TEST_EXECUTE:
+		break;
+	}
+
+	return result;
+}
+*/
+
+/* Test helper functions */
+
+/*!
+ * \internal
+ * \brief Make an empty test configuration
+ *
+ * \return An ast_config structure that is empty (potentially invalid)
+ */
+static struct ast_config * make_empty_ast_config(void)
+{
+	struct ast_config * cfg;
+
+	cfg = ast_config_new();
+
+	return cfg;
+}
+
+/*!
+ * \internal
+ * \brief Make an empty vm test configuration
+ *
+ * \return A vm_config structure that is empty (potentially invalid)
+ */
+static struct vm_config * make_empty_vm_config(void)
+{
+	struct vm_config * cfg;
+
+	if ((cfg = ao2_alloc(sizeof(*cfg), vm_config_destroy))) {
+		if (   !(cfg->sound_config = ast_calloc(1, sizeof(*(cfg->sound_config))))
+			|| !(cfg->smdi_config = ast_calloc(1, sizeof(*(cfg->smdi_config))))
+			|| !(cfg->listen_control_config = ast_calloc(1, sizeof(*(cfg->listen_control_config))))
+			|| !(cfg->adsi_config = ast_calloc(1, sizeof(*(cfg->adsi_config)))))
+		{
+			ao2_ref(cfg, -1);
+			cfg = NULL;
+		} else {
+			if (   ast_string_field_init(cfg->sound_config, 512)
+			    || ast_string_field_init(cfg->smdi_config, 512)
+		        || ast_string_field_init(cfg, 512)) {
+				ao2_ref(cfg, -1);
+				cfg = NULL;
+			}
+		}
+	}
+
+	return cfg;
+}
+
+/*!
+ * \internal
+ * \brief Make a valid test configuration to use for any of the tests
+ *
+ * \details
+ * The test configuration returned has the following:
+ * [general]
+ * format = wav49|wav
+ *
+ * [zonemessages]
+ * eastern = America/New_York|'vm-received' Q 'digits/at' IMp
+ * central = America/Chicago|'vm-received' Q 'digits/at' IMp
+ * central24 = America/Chicago|'vm-received' q 'digits/at' H N 'hours'
+ * military = Zulu|'vm-received' q 'digits/at' H N 'hours' 'phonetic/z_p'
+ * european = Europe/Copenhagen|'vm-received' a d b 'digits/at' HM
+
+ * \return An ast_config structure with populated categories and variables
+ *
+ */
+static struct ast_config * make_ast_config(void)
+{
+	struct ast_config * cfg;
+	struct ast_category * tmp_category;
+	struct ast_variable * tmp_variable;
+
+	cfg = ast_config_new();
+
+	/* Add the [general] category and its variables */
+	tmp_category = ast_category_new("general", "voicemail.conf", 1);
+
+	tmp_variable = ast_variable_new("format", "wav49|wav", "voicemail.conf");
+	ast_variable_append(tmp_category, tmp_variable);
+
+	ast_category_append(cfg, tmp_category);
+
+	/* Add the [zonemessages] category and its variables.  Note that this shouldn't be used

[... 8110 lines stripped ...]



More information about the asterisk-commits mailing list