summaryrefslogtreecommitdiff
path: root/tests/test_devicestate.c
diff options
context:
space:
mode:
authorDavid Vossel <dvossel@digium.com>2010-02-17 19:18:44 +0000
committerDavid Vossel <dvossel@digium.com>2010-02-17 19:18:44 +0000
commit5b0b04f2d8d7c6814b8df38eac93b28e2dbb6143 (patch)
tree0e16539250f85aa214c933d28f03e88786c502cf /tests/test_devicestate.c
parent57c819fd5eac60f965b50877161be4c1b3ba2dab (diff)
unit test for combined device state mapping and device to exten state mapping
Review: https://reviewboard.asterisk.org/r/516/ git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@247262 65c4cc65-6c06-0410-ace0-fbb531ad65f3
Diffstat (limited to 'tests/test_devicestate.c')
-rw-r--r--tests/test_devicestate.c288
1 files changed, 288 insertions, 0 deletions
diff --git a/tests/test_devicestate.c b/tests/test_devicestate.c
new file mode 100644
index 000000000..d5bf4c160
--- /dev/null
+++ b/tests/test_devicestate.c
@@ -0,0 +1,288 @@
+/*
+ * Asterisk -- An open source telephony toolkit.
+ *
+ * Copyright (C) 2010, David Vossel
+ *
+ * David Vossel <dvossel@digium.com>
+ *
+ * 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 Device State Test Module
+ *
+ * \author\verbatim David Vossel <dvossel@digium.com> \endverbatim
+ *
+ * \ingroup tests
+ */
+
+/*** MODULEINFO
+ <depend>TEST_FRAMEWORK</depend>
+ ***/
+
+#include "asterisk.h"
+
+ASTERISK_FILE_VERSION(__FILE__, "$Revision$")
+
+#include "asterisk/utils.h"
+#include "asterisk/module.h"
+#include "asterisk/test.h"
+#include "asterisk/devicestate.h"
+#include "asterisk/pbx.h"
+
+
+/* These arrays are the result of the 'core show device2extenstate' output. */
+static int combined_results[] = {
+ AST_DEVICE_UNKNOWN,
+ AST_DEVICE_NOT_INUSE,
+ AST_DEVICE_INUSE,
+ AST_DEVICE_BUSY,
+ AST_DEVICE_UNKNOWN,
+ AST_DEVICE_UNAVAILABLE,
+ AST_DEVICE_RINGING,
+ AST_DEVICE_RINGINUSE,
+ AST_DEVICE_ONHOLD,
+ AST_DEVICE_NOT_INUSE,
+ AST_DEVICE_NOT_INUSE,
+ AST_DEVICE_INUSE,
+ AST_DEVICE_BUSY,
+ AST_DEVICE_NOT_INUSE,
+ AST_DEVICE_NOT_INUSE,
+ AST_DEVICE_RINGING,
+ AST_DEVICE_RINGINUSE,
+ AST_DEVICE_ONHOLD,
+ AST_DEVICE_INUSE,
+ AST_DEVICE_INUSE,
+ AST_DEVICE_INUSE,
+ AST_DEVICE_BUSY,
+ AST_DEVICE_INUSE,
+ AST_DEVICE_INUSE,
+ AST_DEVICE_RINGINUSE,
+ AST_DEVICE_RINGINUSE,
+ AST_DEVICE_INUSE,
+ AST_DEVICE_BUSY,
+ AST_DEVICE_BUSY,
+ AST_DEVICE_BUSY,
+ AST_DEVICE_BUSY,
+ AST_DEVICE_BUSY,
+ AST_DEVICE_BUSY,
+ AST_DEVICE_RINGINUSE,
+ AST_DEVICE_RINGINUSE,
+ AST_DEVICE_BUSY,
+ AST_DEVICE_UNKNOWN,
+ AST_DEVICE_NOT_INUSE,
+ AST_DEVICE_INUSE,
+ AST_DEVICE_BUSY,
+ AST_DEVICE_UNKNOWN,
+ AST_DEVICE_UNAVAILABLE,
+ AST_DEVICE_RINGING,
+ AST_DEVICE_RINGINUSE,
+ AST_DEVICE_ONHOLD,
+ AST_DEVICE_UNAVAILABLE,
+ AST_DEVICE_NOT_INUSE,
+ AST_DEVICE_INUSE,
+ AST_DEVICE_BUSY,
+ AST_DEVICE_UNAVAILABLE,
+ AST_DEVICE_UNAVAILABLE,
+ AST_DEVICE_RINGING,
+ AST_DEVICE_RINGINUSE,
+ AST_DEVICE_ONHOLD,
+ AST_DEVICE_RINGING,
+ AST_DEVICE_RINGING,
+ AST_DEVICE_RINGINUSE,
+ AST_DEVICE_RINGINUSE,
+ AST_DEVICE_RINGING,
+ AST_DEVICE_RINGING,
+ AST_DEVICE_RINGING,
+ AST_DEVICE_RINGINUSE,
+ AST_DEVICE_RINGINUSE,
+ AST_DEVICE_RINGINUSE,
+ AST_DEVICE_RINGINUSE,
+ AST_DEVICE_RINGINUSE,
+ AST_DEVICE_RINGINUSE,
+ AST_DEVICE_RINGINUSE,
+ AST_DEVICE_RINGINUSE,
+ AST_DEVICE_RINGINUSE,
+ AST_DEVICE_RINGINUSE,
+ AST_DEVICE_RINGINUSE,
+ AST_DEVICE_ONHOLD,
+ AST_DEVICE_ONHOLD,
+ AST_DEVICE_INUSE,
+ AST_DEVICE_BUSY,
+ AST_DEVICE_ONHOLD,
+ AST_DEVICE_ONHOLD,
+ AST_DEVICE_RINGINUSE,
+ AST_DEVICE_RINGINUSE,
+ AST_DEVICE_ONHOLD,
+};
+
+static int exten_results[] = {
+ AST_EXTENSION_UNAVAILABLE,
+ AST_EXTENSION_NOT_INUSE,
+ AST_EXTENSION_INUSE,
+ AST_EXTENSION_BUSY,
+ AST_EXTENSION_UNAVAILABLE,
+ AST_EXTENSION_UNAVAILABLE,
+ AST_EXTENSION_RINGING,
+ AST_EXTENSION_INUSE | AST_EXTENSION_RINGING,
+ AST_EXTENSION_ONHOLD,
+ AST_EXTENSION_NOT_INUSE,
+ AST_EXTENSION_NOT_INUSE,
+ AST_EXTENSION_INUSE,
+ AST_EXTENSION_BUSY,
+ AST_EXTENSION_NOT_INUSE,
+ AST_EXTENSION_NOT_INUSE,
+ AST_EXTENSION_RINGING,
+ AST_EXTENSION_INUSE | AST_EXTENSION_RINGING,
+ AST_EXTENSION_ONHOLD,
+ AST_EXTENSION_INUSE,
+ AST_EXTENSION_INUSE,
+ AST_EXTENSION_INUSE,
+ AST_EXTENSION_BUSY,
+ AST_EXTENSION_INUSE,
+ AST_EXTENSION_INUSE,
+ AST_EXTENSION_INUSE | AST_EXTENSION_RINGING,
+ AST_EXTENSION_INUSE | AST_EXTENSION_RINGING,
+ AST_EXTENSION_INUSE,
+ AST_EXTENSION_BUSY,
+ AST_EXTENSION_BUSY,
+ AST_EXTENSION_BUSY,
+ AST_EXTENSION_BUSY,
+ AST_EXTENSION_BUSY,
+ AST_EXTENSION_BUSY,
+ AST_EXTENSION_INUSE | AST_EXTENSION_RINGING,
+ AST_EXTENSION_INUSE | AST_EXTENSION_RINGING,
+ AST_EXTENSION_BUSY,
+ AST_EXTENSION_UNAVAILABLE,
+ AST_EXTENSION_NOT_INUSE,
+ AST_EXTENSION_INUSE,
+ AST_EXTENSION_BUSY,
+ AST_EXTENSION_UNAVAILABLE,
+ AST_EXTENSION_UNAVAILABLE,
+ AST_EXTENSION_RINGING,
+ AST_EXTENSION_INUSE | AST_EXTENSION_RINGING,
+ AST_EXTENSION_ONHOLD,
+ AST_EXTENSION_UNAVAILABLE,
+ AST_EXTENSION_NOT_INUSE,
+ AST_EXTENSION_INUSE,
+ AST_EXTENSION_BUSY,
+ AST_EXTENSION_UNAVAILABLE,
+ AST_EXTENSION_UNAVAILABLE,
+ AST_EXTENSION_RINGING,
+ AST_EXTENSION_INUSE | AST_EXTENSION_RINGING,
+ AST_EXTENSION_ONHOLD,
+ AST_EXTENSION_RINGING,
+ AST_EXTENSION_RINGING,
+ AST_EXTENSION_INUSE | AST_EXTENSION_RINGING,
+ AST_EXTENSION_INUSE | AST_EXTENSION_RINGING,
+ AST_EXTENSION_RINGING,
+ AST_EXTENSION_RINGING,
+ AST_EXTENSION_RINGING,
+ AST_EXTENSION_INUSE | AST_EXTENSION_RINGING,
+ AST_EXTENSION_INUSE | AST_EXTENSION_RINGING,
+ AST_EXTENSION_INUSE | AST_EXTENSION_RINGING,
+ AST_EXTENSION_INUSE | AST_EXTENSION_RINGING,
+ AST_EXTENSION_INUSE | AST_EXTENSION_RINGING,
+ AST_EXTENSION_INUSE | AST_EXTENSION_RINGING,
+ AST_EXTENSION_INUSE | AST_EXTENSION_RINGING,
+ AST_EXTENSION_INUSE | AST_EXTENSION_RINGING,
+ AST_EXTENSION_INUSE | AST_EXTENSION_RINGING,
+ AST_EXTENSION_INUSE | AST_EXTENSION_RINGING,
+ AST_EXTENSION_INUSE | AST_EXTENSION_RINGING,
+ AST_EXTENSION_ONHOLD,
+ AST_EXTENSION_ONHOLD,
+ AST_EXTENSION_INUSE,
+ AST_EXTENSION_BUSY,
+ AST_EXTENSION_ONHOLD,
+ AST_EXTENSION_ONHOLD,
+ AST_EXTENSION_INUSE | AST_EXTENSION_RINGING,
+ AST_EXTENSION_INUSE | AST_EXTENSION_RINGING,
+ AST_EXTENSION_ONHOLD,
+};
+
+AST_TEST_DEFINE(device2extenstate_test)
+{
+ int res = AST_TEST_PASS;
+ struct ast_devstate_aggregate agg;
+ enum ast_device_state i, j, combined;
+ enum ast_extension_states exten;
+ int k = 0;
+
+ switch (cmd) {
+ case TEST_INIT:
+ info->name = "device2extenstate_test";
+ info->category = "main/devstate/";
+ info->summary = "Tests combined devstate mapping and device to extension state mapping.";
+ info->description =
+ "Verifies device state aggregate results match the expected combined "
+ "devstate. Then verifies the combined devstate maps to the expected "
+ "extension state.";
+ return AST_TEST_NOT_RUN;
+ case TEST_EXECUTE:
+ break;
+ }
+
+ if (ARRAY_LEN(exten_results) != (AST_DEVICE_TOTAL * AST_DEVICE_TOTAL)) {
+ ast_test_status_update(test, "Result array is %d long when it should be %d. "
+ "Something has changed, this test must be updated.\n",
+ (int) ARRAY_LEN(exten_results), (AST_DEVICE_TOTAL * AST_DEVICE_TOTAL));
+ return AST_TEST_FAIL;
+ }
+
+ if (ARRAY_LEN(combined_results) != ARRAY_LEN(exten_results)) {
+ ast_test_status_update(test, "combined_results and exten_results arrays do not match in length.\n");
+ return AST_TEST_FAIL;
+ }
+
+ for (i = 0; i < AST_DEVICE_TOTAL; i++) {
+ for (j = 0; j < AST_DEVICE_TOTAL; j++) {
+ ast_devstate_aggregate_init(&agg);
+ ast_devstate_aggregate_add(&agg, i);
+ ast_devstate_aggregate_add(&agg, j);
+ combined = ast_devstate_aggregate_result(&agg);
+ if (combined_results[k] != combined) {
+ ast_test_status_update(test, "Expected combined dev state %s "
+ "does not match %s at combined_result[%d].\n",
+ ast_devstate2str(combined_results[k]),
+ ast_devstate2str(combined), k);
+ res = AST_TEST_FAIL;
+ }
+
+ exten = ast_devstate_to_extenstate(combined);
+
+ if (exten_results[k] != exten) {
+ ast_test_status_update(test, "Expected exten state %s "
+ "does not match %s at exten_result[%d]\n",
+ ast_extension_state2str(exten_results[k]),
+ ast_extension_state2str(exten), k);
+ res = AST_TEST_FAIL;
+ }
+ k++;
+ }
+ }
+
+ return res;
+}
+
+static int unload_module(void)
+{
+ AST_TEST_UNREGISTER(device2extenstate_test);
+ return 0;
+}
+
+static int load_module(void)
+{
+ AST_TEST_REGISTER(device2extenstate_test);
+ return AST_MODULE_LOAD_SUCCESS;
+}
+
+AST_MODULE_INFO_STANDARD(ASTERISK_GPL_KEY, "Device State Test");