<p>Friendly Automation <strong>merged</strong> this change.</p><p><a href="https://gerrit.asterisk.org/c/testsuite/+/11285">View Change</a></p><div style="white-space:pre-wrap">Approvals:
  Joshua Colp: Looks good to me, but someone else must approve
  George Joseph: Looks good to me, approved
  Friendly Automation: Approved for Submit

</div><pre style="font-family: monospace,monospace; white-space: pre-wrap;">testsuite: Add tests for mailbox polling.<br><br>Added five new tests for mailbox polling:<br>- Polling of a single mailbox<br>- Polling of multiple mailboxes<br>- Polling a single mailbox with multiple subscriptions<br>- Polling when no mailboxes have subscriptions<br>- Polling before and after an endpoint unregisters<br><br>Change-Id: Id3a40527624c094e253d56ee2df5381b03b22169<br>---<br>A tests/apps/voicemail/polling/poll_multiple_mailboxes/configs/ast1/pjsip.conf<br>A tests/apps/voicemail/polling/poll_multiple_mailboxes/configs/ast1/voicemail.conf<br>A tests/apps/voicemail/polling/poll_multiple_mailboxes/run-test<br>A tests/apps/voicemail/polling/poll_multiple_mailboxes/test-config.yaml<br>A tests/apps/voicemail/polling/poll_no_subs/configs/ast1/extensions.conf<br>A tests/apps/voicemail/polling/poll_no_subs/configs/ast1/voicemail.conf<br>A tests/apps/voicemail/polling/poll_no_subs/run-test<br>A tests/apps/voicemail/polling/poll_no_subs/test-config.yaml<br>A tests/apps/voicemail/polling/poll_same_mailbox/configs/ast1/pjsip.conf<br>A tests/apps/voicemail/polling/poll_same_mailbox/configs/ast1/voicemail.conf<br>A tests/apps/voicemail/polling/poll_same_mailbox/run-test<br>A tests/apps/voicemail/polling/poll_same_mailbox/test-config.yaml<br>A tests/apps/voicemail/polling/poll_single_mailbox/configs/ast1/pjsip.conf<br>A tests/apps/voicemail/polling/poll_single_mailbox/configs/ast1/voicemail.conf<br>A tests/apps/voicemail/polling/poll_single_mailbox/run-test<br>A tests/apps/voicemail/polling/poll_single_mailbox/test-config.yaml<br>A tests/apps/voicemail/polling/poll_sub_unsub/configs/ast1/extensions.conf<br>A tests/apps/voicemail/polling/poll_sub_unsub/configs/ast1/pjsip.conf<br>A tests/apps/voicemail/polling/poll_sub_unsub/configs/ast1/voicemail.conf<br>A tests/apps/voicemail/polling/poll_sub_unsub/run-test<br>A tests/apps/voicemail/polling/poll_sub_unsub/sipp/register.xml<br>A tests/apps/voicemail/polling/poll_sub_unsub/sipp/unregister.xml<br>A tests/apps/voicemail/polling/poll_sub_unsub/test-config.yaml<br>A tests/apps/voicemail/polling/tests.yaml<br>M tests/apps/voicemail/tests.yaml<br>25 files changed, 812 insertions(+), 0 deletions(-)<br><br></pre><pre style="font-family: monospace,monospace; white-space: pre-wrap;"><span>diff --git a/tests/apps/voicemail/polling/poll_multiple_mailboxes/configs/ast1/pjsip.conf b/tests/apps/voicemail/polling/poll_multiple_mailboxes/configs/ast1/pjsip.conf</span><br><span>new file mode 100644</span><br><span>index 0000000..3bffe84</span><br><span>--- /dev/null</span><br><span>+++ b/tests/apps/voicemail/polling/poll_multiple_mailboxes/configs/ast1/pjsip.conf</span><br><span>@@ -0,0 +1,51 @@</span><br><span style="color: hsl(120, 100%, 40%);">+[dummy-transport]</span><br><span style="color: hsl(120, 100%, 40%);">+type=transport</span><br><span style="color: hsl(120, 100%, 40%);">+bind=0.0.0.0</span><br><span style="color: hsl(120, 100%, 40%);">+protocol=udp</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+[aor](!)</span><br><span style="color: hsl(120, 100%, 40%);">+type=aor</span><br><span style="color: hsl(120, 100%, 40%);">+max_contacts=1</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+[auth](!)</span><br><span style="color: hsl(120, 100%, 40%);">+type=auth</span><br><span style="color: hsl(120, 100%, 40%);">+auth_type=userpass</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+[endpoint](!)</span><br><span style="color: hsl(120, 100%, 40%);">+type=endpoint</span><br><span style="color: hsl(120, 100%, 40%);">+allow=!all,ulaw</span><br><span style="color: hsl(120, 100%, 40%);">+transport=dummy-transport</span><br><span style="color: hsl(120, 100%, 40%);">+context=default</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+[1234](aor)</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+[1234](auth)</span><br><span style="color: hsl(120, 100%, 40%);">+username=1234</span><br><span style="color: hsl(120, 100%, 40%);">+password=1234</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+[1234](endpoint)</span><br><span style="color: hsl(120, 100%, 40%);">+auth=1234</span><br><span style="color: hsl(120, 100%, 40%);">+aors=1234</span><br><span style="color: hsl(120, 100%, 40%);">+mailboxes=1234@default</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+[5678](aor)</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+[5678](auth)</span><br><span style="color: hsl(120, 100%, 40%);">+username=5678</span><br><span style="color: hsl(120, 100%, 40%);">+password=5678</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+[5678](endpoint)</span><br><span style="color: hsl(120, 100%, 40%);">+auth=5678</span><br><span style="color: hsl(120, 100%, 40%);">+aors=5678</span><br><span style="color: hsl(120, 100%, 40%);">+mailboxes=5678@default</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+[9999](aor)</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+[9999](auth)</span><br><span style="color: hsl(120, 100%, 40%);">+username=9999</span><br><span style="color: hsl(120, 100%, 40%);">+password=9999</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+[9999](endpoint)</span><br><span style="color: hsl(120, 100%, 40%);">+auth=9999</span><br><span style="color: hsl(120, 100%, 40%);">+aors=9999</span><br><span style="color: hsl(120, 100%, 40%);">+mailboxes=9999@default</span><br><span>diff --git a/tests/apps/voicemail/polling/poll_multiple_mailboxes/configs/ast1/voicemail.conf b/tests/apps/voicemail/polling/poll_multiple_mailboxes/configs/ast1/voicemail.conf</span><br><span>new file mode 100644</span><br><span>index 0000000..489a7a3</span><br><span>--- /dev/null</span><br><span>+++ b/tests/apps/voicemail/polling/poll_multiple_mailboxes/configs/ast1/voicemail.conf</span><br><span>@@ -0,0 +1,6 @@</span><br><span style="color: hsl(120, 100%, 40%);">+; Voicemail Configuration</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+[general]</span><br><span style="color: hsl(120, 100%, 40%);">+format = ulaw</span><br><span style="color: hsl(120, 100%, 40%);">+pollmailboxes=yes</span><br><span style="color: hsl(120, 100%, 40%);">+pollfreq=2</span><br><span>diff --git a/tests/apps/voicemail/polling/poll_multiple_mailboxes/run-test b/tests/apps/voicemail/polling/poll_multiple_mailboxes/run-test</span><br><span>new file mode 100755</span><br><span>index 0000000..4db0314</span><br><span>--- /dev/null</span><br><span>+++ b/tests/apps/voicemail/polling/poll_multiple_mailboxes/run-test</span><br><span>@@ -0,0 +1,98 @@</span><br><span style="color: hsl(120, 100%, 40%);">+#!/usr/bin/env python</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+'''</span><br><span style="color: hsl(120, 100%, 40%);">+Copyright (C) 2019, Sangoma Technologies Corporation</span><br><span style="color: hsl(120, 100%, 40%);">+Ben Ford <bford@digium.com></span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+This program is free software, distributed under the terms of</span><br><span style="color: hsl(120, 100%, 40%);">+the GNU General Public License Version 2.</span><br><span style="color: hsl(120, 100%, 40%);">+'''</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+import sys</span><br><span style="color: hsl(120, 100%, 40%);">+import logging</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+from asterisk.asterisk import Asterisk</span><br><span style="color: hsl(120, 100%, 40%);">+from asterisk.test_case import TestCase</span><br><span style="color: hsl(120, 100%, 40%);">+from asterisk.voicemail import VoiceMailMailboxManagement</span><br><span style="color: hsl(120, 100%, 40%);">+from twisted.internet import reactor</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+LOGGER = logging.getLogger(__name__)</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+class PollingTest(TestCase):</span><br><span style="color: hsl(120, 100%, 40%);">+    def __init__(self):</span><br><span style="color: hsl(120, 100%, 40%);">+        TestCase.__init__(self)</span><br><span style="color: hsl(120, 100%, 40%);">+        self.passed = False</span><br><span style="color: hsl(120, 100%, 40%);">+        self.flags = 0</span><br><span style="color: hsl(120, 100%, 40%);">+        self.create_asterisk()</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+    def stop_test(self, passed=False):</span><br><span style="color: hsl(120, 100%, 40%);">+        self.passed = passed</span><br><span style="color: hsl(120, 100%, 40%);">+        reactor.stop()</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+    def handle_message_waiting(self, ami, event):</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+        mailbox = event.get("mailbox")</span><br><span style="color: hsl(120, 100%, 40%);">+        old = int(event.get("old"))</span><br><span style="color: hsl(120, 100%, 40%);">+        new = int(event.get("new"))</span><br><span style="color: hsl(120, 100%, 40%);">+        waiting = int(event.get("waiting"))</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+        # Conditions:</span><br><span style="color: hsl(120, 100%, 40%);">+        # - If INBOX count is 1, then we need to remove the voicemail and set flag</span><br><span style="color: hsl(120, 100%, 40%);">+        # - If INBOX count is 0, just set flag</span><br><span style="color: hsl(120, 100%, 40%);">+        # - Once flags reaches 2^6-1 (111111), we've met all conditions</span><br><span style="color: hsl(120, 100%, 40%);">+        if new == 1 and waiting == 1:</span><br><span style="color: hsl(120, 100%, 40%);">+            if old != 0:</span><br><span style="color: hsl(120, 100%, 40%);">+                LOGGER.error("Expected 'Old' to be 0")</span><br><span style="color: hsl(120, 100%, 40%);">+                self.stop_test()</span><br><span style="color: hsl(120, 100%, 40%);">+            if mailbox == "1234@default":</span><br><span style="color: hsl(120, 100%, 40%);">+                self.flags |= 1</span><br><span style="color: hsl(120, 100%, 40%);">+            elif mailbox == "5678@default":</span><br><span style="color: hsl(120, 100%, 40%);">+                self.flags |= 2</span><br><span style="color: hsl(120, 100%, 40%);">+            elif mailbox == "9999@default":</span><br><span style="color: hsl(120, 100%, 40%);">+                self.flags |= 4</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+            data = mailbox.split("@")</span><br><span style="color: hsl(120, 100%, 40%);">+            mailbox = data[0]</span><br><span style="color: hsl(120, 100%, 40%);">+            if not self.voicemailManager.remove_mailbox("default", mailbox):</span><br><span style="color: hsl(120, 100%, 40%);">+                LOGGER.error("Failed to remove voicemail for mailbox {0}".format(mailbox))</span><br><span style="color: hsl(120, 100%, 40%);">+                self.stop_test()</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+        elif new == 0 and waiting == 0 and old == 0:</span><br><span style="color: hsl(120, 100%, 40%);">+            if mailbox == "1234@default":</span><br><span style="color: hsl(120, 100%, 40%);">+                self.flags |= 8</span><br><span style="color: hsl(120, 100%, 40%);">+            elif mailbox == "5678@default":</span><br><span style="color: hsl(120, 100%, 40%);">+                self.flags |= 16</span><br><span style="color: hsl(120, 100%, 40%);">+            elif mailbox == "9999@default":</span><br><span style="color: hsl(120, 100%, 40%);">+                self.flags |= 32</span><br><span style="color: hsl(120, 100%, 40%);">+        </span><br><span style="color: hsl(120, 100%, 40%);">+        # self.flags should be 63 (2^6-1 == 111111 in binary)</span><br><span style="color: hsl(120, 100%, 40%);">+        if self.flags == 63:</span><br><span style="color: hsl(120, 100%, 40%);">+            self.stop_test(True)</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+    def ami_connect(self, ami):</span><br><span style="color: hsl(120, 100%, 40%);">+        ami.registerEvent("MessageWaiting", self.handle_message_waiting)</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+        mailboxes = ["1234", "5678", "9999"]</span><br><span style="color: hsl(120, 100%, 40%);">+        self.voicemailManager = VoiceMailMailboxManagement(self.ast[0])</span><br><span style="color: hsl(120, 100%, 40%);">+        for mailbox in mailboxes:</span><br><span style="color: hsl(120, 100%, 40%);">+            self.voicemailManager.create_mailbox("default", mailbox, True)</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+        formats = ["ulaw"]</span><br><span style="color: hsl(120, 100%, 40%);">+        for mailbox in mailboxes:</span><br><span style="color: hsl(120, 100%, 40%);">+            if not self.voicemailManager.create_dummy_voicemail("default", mailbox, VoiceMailMailboxManagement.inbox_folder_name, 1, formats):</span><br><span style="color: hsl(120, 100%, 40%);">+                LOGGER.error("Failed to create voicemail for mailbox {0}".format(mailbox))</span><br><span style="color: hsl(120, 100%, 40%);">+                self.stop_test()</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+    def run(self):</span><br><span style="color: hsl(120, 100%, 40%);">+        TestCase.run(self)</span><br><span style="color: hsl(120, 100%, 40%);">+        self.create_ami_factory()</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+def main():</span><br><span style="color: hsl(120, 100%, 40%);">+    test = PollingTest()</span><br><span style="color: hsl(120, 100%, 40%);">+    reactor.run()</span><br><span style="color: hsl(120, 100%, 40%);">+    if not test.passed:</span><br><span style="color: hsl(120, 100%, 40%);">+        return 1</span><br><span style="color: hsl(120, 100%, 40%);">+    return 0</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+if __name__ == "__main__":</span><br><span style="color: hsl(120, 100%, 40%);">+    sys.exit(main() or 0)</span><br><span>diff --git a/tests/apps/voicemail/polling/poll_multiple_mailboxes/test-config.yaml b/tests/apps/voicemail/polling/poll_multiple_mailboxes/test-config.yaml</span><br><span>new file mode 100644</span><br><span>index 0000000..cfedd6d</span><br><span>--- /dev/null</span><br><span>+++ b/tests/apps/voicemail/polling/poll_multiple_mailboxes/test-config.yaml</span><br><span>@@ -0,0 +1,19 @@</span><br><span style="color: hsl(120, 100%, 40%);">+testinfo:</span><br><span style="color: hsl(120, 100%, 40%);">+    summary: 'Test polling of multiple mailboxes'</span><br><span style="color: hsl(120, 100%, 40%);">+    description: |</span><br><span style="color: hsl(120, 100%, 40%);">+        This test verifies that polling multiple mailboxes works as intended. A fake</span><br><span style="color: hsl(120, 100%, 40%);">+        message is added to various mailboxes that triggers events when the polling</span><br><span style="color: hsl(120, 100%, 40%);">+        frequency timeout is reached, which will cause the test to then remove the</span><br><span style="color: hsl(120, 100%, 40%);">+        messages and end the test.</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+properties:</span><br><span style="color: hsl(120, 100%, 40%);">+    buildoption: 'TEST_FRAMEWORK'</span><br><span style="color: hsl(120, 100%, 40%);">+    dependencies:</span><br><span style="color: hsl(120, 100%, 40%);">+        - python : 'twisted'</span><br><span style="color: hsl(120, 100%, 40%);">+        - python : 'starpy'</span><br><span style="color: hsl(120, 100%, 40%);">+        - asterisk: 'app_voicemail'</span><br><span style="color: hsl(120, 100%, 40%);">+        - asterisk: 'chan_pjsip'</span><br><span style="color: hsl(120, 100%, 40%);">+        - asterisk: 'res_pjsip'</span><br><span style="color: hsl(120, 100%, 40%);">+    tags:</span><br><span style="color: hsl(120, 100%, 40%);">+        - voicemail</span><br><span style="color: hsl(120, 100%, 40%);">+        - apps</span><br><span>diff --git a/tests/apps/voicemail/polling/poll_no_subs/configs/ast1/extensions.conf b/tests/apps/voicemail/polling/poll_no_subs/configs/ast1/extensions.conf</span><br><span>new file mode 100644</span><br><span>index 0000000..eed7ea0</span><br><span>--- /dev/null</span><br><span>+++ b/tests/apps/voicemail/polling/poll_no_subs/configs/ast1/extensions.conf</span><br><span>@@ -0,0 +1,11 @@</span><br><span style="color: hsl(120, 100%, 40%);">+[default]</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+exten => playback,1,NoOp()</span><br><span style="color: hsl(120, 100%, 40%);">+ same => n,Answer()</span><br><span style="color: hsl(120, 100%, 40%);">+ same => n,Playback(silence/5)</span><br><span style="color: hsl(120, 100%, 40%);">+ same => n,Hangup()</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+exten => echo,1,NoOp()</span><br><span style="color: hsl(120, 100%, 40%);">+ same => n,Answer()</span><br><span style="color: hsl(120, 100%, 40%);">+ same => n,Echo()</span><br><span style="color: hsl(120, 100%, 40%);">+ same => n,Hangup()</span><br><span>diff --git a/tests/apps/voicemail/polling/poll_no_subs/configs/ast1/voicemail.conf b/tests/apps/voicemail/polling/poll_no_subs/configs/ast1/voicemail.conf</span><br><span>new file mode 100644</span><br><span>index 0000000..489a7a3</span><br><span>--- /dev/null</span><br><span>+++ b/tests/apps/voicemail/polling/poll_no_subs/configs/ast1/voicemail.conf</span><br><span>@@ -0,0 +1,6 @@</span><br><span style="color: hsl(120, 100%, 40%);">+; Voicemail Configuration</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+[general]</span><br><span style="color: hsl(120, 100%, 40%);">+format = ulaw</span><br><span style="color: hsl(120, 100%, 40%);">+pollmailboxes=yes</span><br><span style="color: hsl(120, 100%, 40%);">+pollfreq=2</span><br><span>diff --git a/tests/apps/voicemail/polling/poll_no_subs/run-test b/tests/apps/voicemail/polling/poll_no_subs/run-test</span><br><span>new file mode 100755</span><br><span>index 0000000..0d6a1c9</span><br><span>--- /dev/null</span><br><span>+++ b/tests/apps/voicemail/polling/poll_no_subs/run-test</span><br><span>@@ -0,0 +1,79 @@</span><br><span style="color: hsl(120, 100%, 40%);">+#!/usr/bin/env python</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+'''</span><br><span style="color: hsl(120, 100%, 40%);">+Copyright (C) 2019, Sangoma Technologies Corporation</span><br><span style="color: hsl(120, 100%, 40%);">+Ben Ford <bford@digium.com></span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+This program is free software, distributed under the terms of</span><br><span style="color: hsl(120, 100%, 40%);">+the GNU General Public License Version 2.</span><br><span style="color: hsl(120, 100%, 40%);">+'''</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+import sys</span><br><span style="color: hsl(120, 100%, 40%);">+import logging</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+from asterisk.asterisk import Asterisk</span><br><span style="color: hsl(120, 100%, 40%);">+from asterisk.test_case import TestCase</span><br><span style="color: hsl(120, 100%, 40%);">+from asterisk.voicemail import VoiceMailMailboxManagement</span><br><span style="color: hsl(120, 100%, 40%);">+from twisted.internet import reactor</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+LOGGER = logging.getLogger(__name__)</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+class PollingTest(TestCase):</span><br><span style="color: hsl(120, 100%, 40%);">+    def __init__(self):</span><br><span style="color: hsl(120, 100%, 40%);">+        TestCase.__init__(self)</span><br><span style="color: hsl(120, 100%, 40%);">+        self.passed = False</span><br><span style="color: hsl(120, 100%, 40%);">+        self.create_asterisk()</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+    def stop_test(self, passed=False):</span><br><span style="color: hsl(120, 100%, 40%);">+        self.passed = passed</span><br><span style="color: hsl(120, 100%, 40%);">+        # Sometimes the reactor has already stopped, we only care if the test passed</span><br><span style="color: hsl(120, 100%, 40%);">+        try:</span><br><span style="color: hsl(120, 100%, 40%);">+            reactor.stop()</span><br><span style="color: hsl(120, 100%, 40%);">+        except Exception as e:</span><br><span style="color: hsl(120, 100%, 40%);">+            LOGGER.info("Error while stopping reactor: '{0}'".format(e))</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+    def handle_message_waiting(self, ami, event):</span><br><span style="color: hsl(120, 100%, 40%);">+        LOGGER.error("Got a MessageWaiting event we weren't expecting!")</span><br><span style="color: hsl(120, 100%, 40%);">+        self.stop_test()</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+    def handle_hangup(self, ami, event):</span><br><span style="color: hsl(120, 100%, 40%);">+        if "Local/playback@default" in event.get("channel"):</span><br><span style="color: hsl(120, 100%, 40%);">+            self.stop_test(True)</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+    def handle_originate_failure(self, reason):</span><br><span style="color: hsl(120, 100%, 40%);">+        LOGGER.error("Failed to originate call! Reason: {0}".format(reason))</span><br><span style="color: hsl(120, 100%, 40%);">+        self.stop_test()</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+    def ami_connect(self, ami):</span><br><span style="color: hsl(120, 100%, 40%);">+        ami.registerEvent("MessageWaiting", self.handle_message_waiting)</span><br><span style="color: hsl(120, 100%, 40%);">+        ami.registerEvent("Hangup", self.handle_hangup)</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+        self.voicemailManager = VoiceMailMailboxManagement(self.ast[0])</span><br><span style="color: hsl(120, 100%, 40%);">+        self.voicemailManager.create_mailbox("default", "1234", True)</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+        formats = ["ulaw"]</span><br><span style="color: hsl(120, 100%, 40%);">+        if not self.voicemailManager.create_dummy_voicemail("default", "1234", VoiceMailMailboxManagement.inbox_folder_name, 1, formats):</span><br><span style="color: hsl(120, 100%, 40%);">+            LOGGER.error("Failed to create voicemail")</span><br><span style="color: hsl(120, 100%, 40%);">+            self.stop_test()</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+        variable = {}</span><br><span style="color: hsl(120, 100%, 40%);">+        ami.originate(channel="Local/playback@default",</span><br><span style="color: hsl(120, 100%, 40%);">+                      context="default",</span><br><span style="color: hsl(120, 100%, 40%);">+                      exten="echo",</span><br><span style="color: hsl(120, 100%, 40%);">+                      priority="1",</span><br><span style="color: hsl(120, 100%, 40%);">+                      variable=variable</span><br><span style="color: hsl(120, 100%, 40%);">+                    ).addErrback(self.handle_originate_failure)</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+    def run(self):</span><br><span style="color: hsl(120, 100%, 40%);">+        TestCase.run(self)</span><br><span style="color: hsl(120, 100%, 40%);">+        self.create_ami_factory()</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+def main():</span><br><span style="color: hsl(120, 100%, 40%);">+    test = PollingTest()</span><br><span style="color: hsl(120, 100%, 40%);">+    reactor.run()</span><br><span style="color: hsl(120, 100%, 40%);">+    if not test.passed:</span><br><span style="color: hsl(120, 100%, 40%);">+        return 1</span><br><span style="color: hsl(120, 100%, 40%);">+    return 0</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+if __name__ == "__main__":</span><br><span style="color: hsl(120, 100%, 40%);">+    sys.exit(main() or 0)</span><br><span>diff --git a/tests/apps/voicemail/polling/poll_no_subs/test-config.yaml b/tests/apps/voicemail/polling/poll_no_subs/test-config.yaml</span><br><span>new file mode 100644</span><br><span>index 0000000..3f8f08d</span><br><span>--- /dev/null</span><br><span>+++ b/tests/apps/voicemail/polling/poll_no_subs/test-config.yaml</span><br><span>@@ -0,0 +1,20 @@</span><br><span style="color: hsl(120, 100%, 40%);">+testinfo:</span><br><span style="color: hsl(120, 100%, 40%);">+    summary: 'Test polling of mailboxes with no subscriptions'</span><br><span style="color: hsl(120, 100%, 40%);">+    description: |</span><br><span style="color: hsl(120, 100%, 40%);">+        This test verifies that polling a mailbox with no subscriptions does</span><br><span style="color: hsl(120, 100%, 40%);">+        not trigger a notification that a change was made. The test will end</span><br><span style="color: hsl(120, 100%, 40%);">+        after a short playback, and if an event for mailbox polling is detected</span><br><span style="color: hsl(120, 100%, 40%);">+        during that time, the test will fail.</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+properties:</span><br><span style="color: hsl(120, 100%, 40%);">+    buildoption: 'TEST_FRAMEWORK'</span><br><span style="color: hsl(120, 100%, 40%);">+    dependencies:</span><br><span style="color: hsl(120, 100%, 40%);">+        - python : 'twisted'</span><br><span style="color: hsl(120, 100%, 40%);">+        - python : 'starpy'</span><br><span style="color: hsl(120, 100%, 40%);">+        - asterisk: 'app_playback'</span><br><span style="color: hsl(120, 100%, 40%);">+        - asterisk: 'app_voicemail'</span><br><span style="color: hsl(120, 100%, 40%);">+        - asterisk: 'chan_pjsip'</span><br><span style="color: hsl(120, 100%, 40%);">+        - asterisk: 'res_pjsip'</span><br><span style="color: hsl(120, 100%, 40%);">+    tags:</span><br><span style="color: hsl(120, 100%, 40%);">+        - voicemail</span><br><span style="color: hsl(120, 100%, 40%);">+        - apps</span><br><span>diff --git a/tests/apps/voicemail/polling/poll_same_mailbox/configs/ast1/pjsip.conf b/tests/apps/voicemail/polling/poll_same_mailbox/configs/ast1/pjsip.conf</span><br><span>new file mode 100644</span><br><span>index 0000000..4c7b3e1</span><br><span>--- /dev/null</span><br><span>+++ b/tests/apps/voicemail/polling/poll_same_mailbox/configs/ast1/pjsip.conf</span><br><span>@@ -0,0 +1,49 @@</span><br><span style="color: hsl(120, 100%, 40%);">+[dummy-transport]</span><br><span style="color: hsl(120, 100%, 40%);">+type=transport</span><br><span style="color: hsl(120, 100%, 40%);">+bind=0.0.0.0</span><br><span style="color: hsl(120, 100%, 40%);">+protocol=udp</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+[aor](!)</span><br><span style="color: hsl(120, 100%, 40%);">+type=aor</span><br><span style="color: hsl(120, 100%, 40%);">+max_contacts=1</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+[auth](!)</span><br><span style="color: hsl(120, 100%, 40%);">+type=auth</span><br><span style="color: hsl(120, 100%, 40%);">+auth_type=userpass</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+[endpoint](!)</span><br><span style="color: hsl(120, 100%, 40%);">+type=endpoint</span><br><span style="color: hsl(120, 100%, 40%);">+allow=!all,ulaw</span><br><span style="color: hsl(120, 100%, 40%);">+transport=dummy-transport</span><br><span style="color: hsl(120, 100%, 40%);">+context=default</span><br><span style="color: hsl(120, 100%, 40%);">+mailboxes=1234@default</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+[1234](aor)</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+[1234](auth)</span><br><span style="color: hsl(120, 100%, 40%);">+username=1234</span><br><span style="color: hsl(120, 100%, 40%);">+password=1234</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+[1234](endpoint)</span><br><span style="color: hsl(120, 100%, 40%);">+auth=1234</span><br><span style="color: hsl(120, 100%, 40%);">+aors=1234</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+[5678](aor)</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+[5678](auth)</span><br><span style="color: hsl(120, 100%, 40%);">+username=5678</span><br><span style="color: hsl(120, 100%, 40%);">+password=5678</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+[5678](endpoint)</span><br><span style="color: hsl(120, 100%, 40%);">+auth=5678</span><br><span style="color: hsl(120, 100%, 40%);">+aors=5678</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+[9999](aor)</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+[9999](auth)</span><br><span style="color: hsl(120, 100%, 40%);">+username=9999</span><br><span style="color: hsl(120, 100%, 40%);">+password=9999</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+[9999](endpoint)</span><br><span style="color: hsl(120, 100%, 40%);">+auth=9999</span><br><span style="color: hsl(120, 100%, 40%);">+aors=9999</span><br><span>diff --git a/tests/apps/voicemail/polling/poll_same_mailbox/configs/ast1/voicemail.conf b/tests/apps/voicemail/polling/poll_same_mailbox/configs/ast1/voicemail.conf</span><br><span>new file mode 100644</span><br><span>index 0000000..489a7a3</span><br><span>--- /dev/null</span><br><span>+++ b/tests/apps/voicemail/polling/poll_same_mailbox/configs/ast1/voicemail.conf</span><br><span>@@ -0,0 +1,6 @@</span><br><span style="color: hsl(120, 100%, 40%);">+; Voicemail Configuration</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+[general]</span><br><span style="color: hsl(120, 100%, 40%);">+format = ulaw</span><br><span style="color: hsl(120, 100%, 40%);">+pollmailboxes=yes</span><br><span style="color: hsl(120, 100%, 40%);">+pollfreq=2</span><br><span>diff --git a/tests/apps/voicemail/polling/poll_same_mailbox/run-test b/tests/apps/voicemail/polling/poll_same_mailbox/run-test</span><br><span>new file mode 100755</span><br><span>index 0000000..78d0773</span><br><span>--- /dev/null</span><br><span>+++ b/tests/apps/voicemail/polling/poll_same_mailbox/run-test</span><br><span>@@ -0,0 +1,87 @@</span><br><span style="color: hsl(120, 100%, 40%);">+#!/usr/bin/env python</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+'''</span><br><span style="color: hsl(120, 100%, 40%);">+Copyright (C) 2019, Sangoma Technologies Corporation</span><br><span style="color: hsl(120, 100%, 40%);">+Ben Ford <bford@digium.com></span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+This program is free software, distributed under the terms of</span><br><span style="color: hsl(120, 100%, 40%);">+the GNU General Public License Version 2.</span><br><span style="color: hsl(120, 100%, 40%);">+'''</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+import sys</span><br><span style="color: hsl(120, 100%, 40%);">+import logging</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+from asterisk.asterisk import Asterisk</span><br><span style="color: hsl(120, 100%, 40%);">+from asterisk.test_case import TestCase</span><br><span style="color: hsl(120, 100%, 40%);">+from asterisk.voicemail import VoiceMailMailboxManagement</span><br><span style="color: hsl(120, 100%, 40%);">+from twisted.internet import reactor</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+LOGGER = logging.getLogger(__name__)</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+class PollingTest(TestCase):</span><br><span style="color: hsl(120, 100%, 40%);">+    def __init__(self):</span><br><span style="color: hsl(120, 100%, 40%);">+        TestCase.__init__(self)</span><br><span style="color: hsl(120, 100%, 40%);">+        self.passed = False</span><br><span style="color: hsl(120, 100%, 40%);">+        self.counter = 0</span><br><span style="color: hsl(120, 100%, 40%);">+        self.create_asterisk()</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+    def stop_test(self, passed=False):</span><br><span style="color: hsl(120, 100%, 40%);">+        self.passed = passed</span><br><span style="color: hsl(120, 100%, 40%);">+        reactor.stop()</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+    def handle_message_waiting(self, ami, event):</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+        if event.get("mailbox") != "1234@default":</span><br><span style="color: hsl(120, 100%, 40%);">+            return</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+        old = int(event.get("old"))</span><br><span style="color: hsl(120, 100%, 40%);">+        new = int(event.get("new"))</span><br><span style="color: hsl(120, 100%, 40%);">+        waiting = int(event.get("waiting"))</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+        # Conditions:</span><br><span style="color: hsl(120, 100%, 40%);">+        # - If INBOX count is 1, increment self.counter</span><br><span style="color: hsl(120, 100%, 40%);">+        # - When self.counter reaches 3, we got all 3 events we expected,</span><br><span style="color: hsl(120, 100%, 40%);">+        #   so delete the voicemail</span><br><span style="color: hsl(120, 100%, 40%);">+        # - INBOX count should only be 0 after we delete the voicemail, so</span><br><span style="color: hsl(120, 100%, 40%);">+        #   increment the counter here to end the test</span><br><span style="color: hsl(120, 100%, 40%);">+        # - Once self.counter reaches 3 after removing the voicemail, we've</span><br><span style="color: hsl(120, 100%, 40%);">+        #   received all the events, so stop the test</span><br><span style="color: hsl(120, 100%, 40%);">+        if new == 1 and waiting == 1:</span><br><span style="color: hsl(120, 100%, 40%);">+            if old != 0:</span><br><span style="color: hsl(120, 100%, 40%);">+                LOGGER.error("Expected 'Old' to be 0")</span><br><span style="color: hsl(120, 100%, 40%);">+                self.stop_test()</span><br><span style="color: hsl(120, 100%, 40%);">+            self.counter += 1</span><br><span style="color: hsl(120, 100%, 40%);">+            if self.counter == 3:</span><br><span style="color: hsl(120, 100%, 40%);">+                self.counter = 0</span><br><span style="color: hsl(120, 100%, 40%);">+                if not self.voicemailManager.remove_mailbox("default", "1234"):</span><br><span style="color: hsl(120, 100%, 40%);">+                    LOGGER.error("Failed to remove voicemail")</span><br><span style="color: hsl(120, 100%, 40%);">+                    self.stop_test()</span><br><span style="color: hsl(120, 100%, 40%);">+        elif new == 0 and waiting == 0 and old == 0:</span><br><span style="color: hsl(120, 100%, 40%);">+            self.counter += 1</span><br><span style="color: hsl(120, 100%, 40%);">+            if self.counter == 3:</span><br><span style="color: hsl(120, 100%, 40%);">+                self.stop_test(True)</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+    def ami_connect(self, ami):</span><br><span style="color: hsl(120, 100%, 40%);">+        ami.registerEvent("MessageWaiting", self.handle_message_waiting)</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+        self.voicemailManager = VoiceMailMailboxManagement(self.ast[0])</span><br><span style="color: hsl(120, 100%, 40%);">+        self.voicemailManager.create_mailbox("default", "1234", True)</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+        formats = ["ulaw"]</span><br><span style="color: hsl(120, 100%, 40%);">+        if not self.voicemailManager.create_dummy_voicemail("default", "1234", VoiceMailMailboxManagement.inbox_folder_name, 1, formats):</span><br><span style="color: hsl(120, 100%, 40%);">+            LOGGER.error("Failed to create voicemail")</span><br><span style="color: hsl(120, 100%, 40%);">+            self.stop_test()</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+    def run(self):</span><br><span style="color: hsl(120, 100%, 40%);">+        TestCase.run(self)</span><br><span style="color: hsl(120, 100%, 40%);">+        self.create_ami_factory()</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+def main():</span><br><span style="color: hsl(120, 100%, 40%);">+    test = PollingTest()</span><br><span style="color: hsl(120, 100%, 40%);">+    reactor.run()</span><br><span style="color: hsl(120, 100%, 40%);">+    if not test.passed:</span><br><span style="color: hsl(120, 100%, 40%);">+        return 1</span><br><span style="color: hsl(120, 100%, 40%);">+    return 0</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+if __name__ == "__main__":</span><br><span style="color: hsl(120, 100%, 40%);">+    sys.exit(main() or 0)</span><br><span>diff --git a/tests/apps/voicemail/polling/poll_same_mailbox/test-config.yaml b/tests/apps/voicemail/polling/poll_same_mailbox/test-config.yaml</span><br><span>new file mode 100644</span><br><span>index 0000000..fedb1db</span><br><span>--- /dev/null</span><br><span>+++ b/tests/apps/voicemail/polling/poll_same_mailbox/test-config.yaml</span><br><span>@@ -0,0 +1,18 @@</span><br><span style="color: hsl(120, 100%, 40%);">+testinfo:</span><br><span style="color: hsl(120, 100%, 40%);">+    summary: 'Test polling of a single mailbox with multiple subscriptions'</span><br><span style="color: hsl(120, 100%, 40%);">+    description: |</span><br><span style="color: hsl(120, 100%, 40%);">+        This test verifies that polling a single mailbox with multiple subscriptions</span><br><span style="color: hsl(120, 100%, 40%);">+        works as intended. The test will wait for the given number of notifications</span><br><span style="color: hsl(120, 100%, 40%);">+        to occur, then remove the voicemail and end the test.</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+properties:</span><br><span style="color: hsl(120, 100%, 40%);">+    buildoption: 'TEST_FRAMEWORK'</span><br><span style="color: hsl(120, 100%, 40%);">+    dependencies:</span><br><span style="color: hsl(120, 100%, 40%);">+        - python : 'twisted'</span><br><span style="color: hsl(120, 100%, 40%);">+        - python : 'starpy'</span><br><span style="color: hsl(120, 100%, 40%);">+        - asterisk: 'app_voicemail'</span><br><span style="color: hsl(120, 100%, 40%);">+        - asterisk: 'chan_pjsip'</span><br><span style="color: hsl(120, 100%, 40%);">+        - asterisk: 'res_pjsip'</span><br><span style="color: hsl(120, 100%, 40%);">+    tags:</span><br><span style="color: hsl(120, 100%, 40%);">+        - voicemail</span><br><span style="color: hsl(120, 100%, 40%);">+        - apps</span><br><span>diff --git a/tests/apps/voicemail/polling/poll_single_mailbox/configs/ast1/pjsip.conf b/tests/apps/voicemail/polling/poll_single_mailbox/configs/ast1/pjsip.conf</span><br><span>new file mode 100644</span><br><span>index 0000000..dce5f75</span><br><span>--- /dev/null</span><br><span>+++ b/tests/apps/voicemail/polling/poll_single_mailbox/configs/ast1/pjsip.conf</span><br><span>@@ -0,0 +1,23 @@</span><br><span style="color: hsl(120, 100%, 40%);">+[dummy-transport]</span><br><span style="color: hsl(120, 100%, 40%);">+type=transport</span><br><span style="color: hsl(120, 100%, 40%);">+bind=0.0.0.0</span><br><span style="color: hsl(120, 100%, 40%);">+protocol=udp</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+[1234]</span><br><span style="color: hsl(120, 100%, 40%);">+type=aor</span><br><span style="color: hsl(120, 100%, 40%);">+max_contacts=1</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+[1234]</span><br><span style="color: hsl(120, 100%, 40%);">+type=auth</span><br><span style="color: hsl(120, 100%, 40%);">+auth_type=userpass</span><br><span style="color: hsl(120, 100%, 40%);">+username=1234</span><br><span style="color: hsl(120, 100%, 40%);">+password=1234</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+[1234]</span><br><span style="color: hsl(120, 100%, 40%);">+type=endpoint</span><br><span style="color: hsl(120, 100%, 40%);">+allow=!all,ulaw</span><br><span style="color: hsl(120, 100%, 40%);">+auth=1234</span><br><span style="color: hsl(120, 100%, 40%);">+aors=1234</span><br><span style="color: hsl(120, 100%, 40%);">+transport=dummy-transport</span><br><span style="color: hsl(120, 100%, 40%);">+context=default</span><br><span style="color: hsl(120, 100%, 40%);">+mailboxes=1234@default</span><br><span>diff --git a/tests/apps/voicemail/polling/poll_single_mailbox/configs/ast1/voicemail.conf b/tests/apps/voicemail/polling/poll_single_mailbox/configs/ast1/voicemail.conf</span><br><span>new file mode 100644</span><br><span>index 0000000..489a7a3</span><br><span>--- /dev/null</span><br><span>+++ b/tests/apps/voicemail/polling/poll_single_mailbox/configs/ast1/voicemail.conf</span><br><span>@@ -0,0 +1,6 @@</span><br><span style="color: hsl(120, 100%, 40%);">+; Voicemail Configuration</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+[general]</span><br><span style="color: hsl(120, 100%, 40%);">+format = ulaw</span><br><span style="color: hsl(120, 100%, 40%);">+pollmailboxes=yes</span><br><span style="color: hsl(120, 100%, 40%);">+pollfreq=2</span><br><span>diff --git a/tests/apps/voicemail/polling/poll_single_mailbox/run-test b/tests/apps/voicemail/polling/poll_single_mailbox/run-test</span><br><span>new file mode 100755</span><br><span>index 0000000..df85667</span><br><span>--- /dev/null</span><br><span>+++ b/tests/apps/voicemail/polling/poll_single_mailbox/run-test</span><br><span>@@ -0,0 +1,81 @@</span><br><span style="color: hsl(120, 100%, 40%);">+#!/usr/bin/env python</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+'''</span><br><span style="color: hsl(120, 100%, 40%);">+Copyright (C) 2019, Sangoma Technologies Corporation</span><br><span style="color: hsl(120, 100%, 40%);">+Ben Ford <bford@digium.com></span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+This program is free software, distributed under the terms of</span><br><span style="color: hsl(120, 100%, 40%);">+the GNU General Public License Version 2.</span><br><span style="color: hsl(120, 100%, 40%);">+'''</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+import sys</span><br><span style="color: hsl(120, 100%, 40%);">+import logging</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+from asterisk.asterisk import Asterisk</span><br><span style="color: hsl(120, 100%, 40%);">+from asterisk.test_case import TestCase</span><br><span style="color: hsl(120, 100%, 40%);">+from asterisk.voicemail import VoiceMailMailboxManagement</span><br><span style="color: hsl(120, 100%, 40%);">+from twisted.internet import reactor</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+LOGGER = logging.getLogger(__name__)</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+class PollingTest(TestCase):</span><br><span style="color: hsl(120, 100%, 40%);">+    def __init__(self):</span><br><span style="color: hsl(120, 100%, 40%);">+        TestCase.__init__(self)</span><br><span style="color: hsl(120, 100%, 40%);">+        self.passed = False</span><br><span style="color: hsl(120, 100%, 40%);">+        self.test_phase = 1</span><br><span style="color: hsl(120, 100%, 40%);">+        self.create_asterisk()</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+    def stop_test(self, passed=False):</span><br><span style="color: hsl(120, 100%, 40%);">+        self.passed = passed</span><br><span style="color: hsl(120, 100%, 40%);">+        reactor.stop()</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+    def handle_message_waiting(self, ami, event):</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+        if event.get("mailbox") != "1234@default":</span><br><span style="color: hsl(120, 100%, 40%);">+            return</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+        old = int(event.get("old"))</span><br><span style="color: hsl(120, 100%, 40%);">+        new = int(event.get("new"))</span><br><span style="color: hsl(120, 100%, 40%);">+        waiting = int(event.get("waiting"))</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+        # Phase 1: We are looking for an INBOX count of 1</span><br><span style="color: hsl(120, 100%, 40%);">+        if self.test_phase == 1:</span><br><span style="color: hsl(120, 100%, 40%);">+            if new != 1 or waiting != 1:</span><br><span style="color: hsl(120, 100%, 40%);">+                return</span><br><span style="color: hsl(120, 100%, 40%);">+            if old != 0:</span><br><span style="color: hsl(120, 100%, 40%);">+                self.stop_test()</span><br><span style="color: hsl(120, 100%, 40%);">+            self.test_phase = 2</span><br><span style="color: hsl(120, 100%, 40%);">+            if not self.voicemailManager.remove_mailbox("default", "1234"):</span><br><span style="color: hsl(120, 100%, 40%);">+                LOGGER.error("Failed to remove voicemail")</span><br><span style="color: hsl(120, 100%, 40%);">+                self.stop_test()</span><br><span style="color: hsl(120, 100%, 40%);">+        # Phase 2: We don't expect there to be any messages</span><br><span style="color: hsl(120, 100%, 40%);">+        elif self.test_phase == 2:</span><br><span style="color: hsl(120, 100%, 40%);">+            if new != 0 or old != 0 or waiting != 0:</span><br><span style="color: hsl(120, 100%, 40%);">+                LOGGER.error("Expected empty mailbox")</span><br><span style="color: hsl(120, 100%, 40%);">+                self.stop_test()</span><br><span style="color: hsl(120, 100%, 40%);">+            self.stop_test(True)</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+    def ami_connect(self, ami):</span><br><span style="color: hsl(120, 100%, 40%);">+        ami.registerEvent("MessageWaiting", self.handle_message_waiting)</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+        self.voicemailManager = VoiceMailMailboxManagement(self.ast[0])</span><br><span style="color: hsl(120, 100%, 40%);">+        self.voicemailManager.create_mailbox("default", "1234", True)</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+        formats = ["ulaw"]</span><br><span style="color: hsl(120, 100%, 40%);">+        if not self.voicemailManager.create_dummy_voicemail("default", "1234", VoiceMailMailboxManagement.inbox_folder_name, 1, formats):</span><br><span style="color: hsl(120, 100%, 40%);">+            LOGGER.error("Failed to create voicemail")</span><br><span style="color: hsl(120, 100%, 40%);">+            self.stop_test()</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+    def run(self):</span><br><span style="color: hsl(120, 100%, 40%);">+        TestCase.run(self)</span><br><span style="color: hsl(120, 100%, 40%);">+        self.create_ami_factory()</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+def main():</span><br><span style="color: hsl(120, 100%, 40%);">+    test = PollingTest()</span><br><span style="color: hsl(120, 100%, 40%);">+    reactor.run()</span><br><span style="color: hsl(120, 100%, 40%);">+    if not test.passed:</span><br><span style="color: hsl(120, 100%, 40%);">+        return 1</span><br><span style="color: hsl(120, 100%, 40%);">+    return 0</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+if __name__ == "__main__":</span><br><span style="color: hsl(120, 100%, 40%);">+    sys.exit(main() or 0)</span><br><span>diff --git a/tests/apps/voicemail/polling/poll_single_mailbox/test-config.yaml b/tests/apps/voicemail/polling/poll_single_mailbox/test-config.yaml</span><br><span>new file mode 100644</span><br><span>index 0000000..cd60cb0</span><br><span>--- /dev/null</span><br><span>+++ b/tests/apps/voicemail/polling/poll_single_mailbox/test-config.yaml</span><br><span>@@ -0,0 +1,19 @@</span><br><span style="color: hsl(120, 100%, 40%);">+testinfo:</span><br><span style="color: hsl(120, 100%, 40%);">+    summary: 'Test polling of a single mailbox'</span><br><span style="color: hsl(120, 100%, 40%);">+    description: |</span><br><span style="color: hsl(120, 100%, 40%);">+        This test verifies that polling a single mailbox works as intended. A fake</span><br><span style="color: hsl(120, 100%, 40%);">+        message is added to the mailbox that triggers an event when the polling</span><br><span style="color: hsl(120, 100%, 40%);">+        frequency timeout is reached, which will cause the test to then remove the</span><br><span style="color: hsl(120, 100%, 40%);">+        message to end the test.</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+properties:</span><br><span style="color: hsl(120, 100%, 40%);">+    buildoption: 'TEST_FRAMEWORK'</span><br><span style="color: hsl(120, 100%, 40%);">+    dependencies:</span><br><span style="color: hsl(120, 100%, 40%);">+        - python : 'twisted'</span><br><span style="color: hsl(120, 100%, 40%);">+        - python : 'starpy'</span><br><span style="color: hsl(120, 100%, 40%);">+        - asterisk: 'app_voicemail'</span><br><span style="color: hsl(120, 100%, 40%);">+        - asterisk: 'chan_pjsip'</span><br><span style="color: hsl(120, 100%, 40%);">+        - asterisk: 'res_pjsip'</span><br><span style="color: hsl(120, 100%, 40%);">+    tags:</span><br><span style="color: hsl(120, 100%, 40%);">+        - voicemail</span><br><span style="color: hsl(120, 100%, 40%);">+        - apps</span><br><span>diff --git a/tests/apps/voicemail/polling/poll_sub_unsub/configs/ast1/extensions.conf b/tests/apps/voicemail/polling/poll_sub_unsub/configs/ast1/extensions.conf</span><br><span>new file mode 100644</span><br><span>index 0000000..eed7ea0</span><br><span>--- /dev/null</span><br><span>+++ b/tests/apps/voicemail/polling/poll_sub_unsub/configs/ast1/extensions.conf</span><br><span>@@ -0,0 +1,11 @@</span><br><span style="color: hsl(120, 100%, 40%);">+[default]</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+exten => playback,1,NoOp()</span><br><span style="color: hsl(120, 100%, 40%);">+ same => n,Answer()</span><br><span style="color: hsl(120, 100%, 40%);">+ same => n,Playback(silence/5)</span><br><span style="color: hsl(120, 100%, 40%);">+ same => n,Hangup()</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+exten => echo,1,NoOp()</span><br><span style="color: hsl(120, 100%, 40%);">+ same => n,Answer()</span><br><span style="color: hsl(120, 100%, 40%);">+ same => n,Echo()</span><br><span style="color: hsl(120, 100%, 40%);">+ same => n,Hangup()</span><br><span>diff --git a/tests/apps/voicemail/polling/poll_sub_unsub/configs/ast1/pjsip.conf b/tests/apps/voicemail/polling/poll_sub_unsub/configs/ast1/pjsip.conf</span><br><span>new file mode 100644</span><br><span>index 0000000..091bdab</span><br><span>--- /dev/null</span><br><span>+++ b/tests/apps/voicemail/polling/poll_sub_unsub/configs/ast1/pjsip.conf</span><br><span>@@ -0,0 +1,16 @@</span><br><span style="color: hsl(120, 100%, 40%);">+[dummy-transport]</span><br><span style="color: hsl(120, 100%, 40%);">+type=transport</span><br><span style="color: hsl(120, 100%, 40%);">+bind=0.0.0.0</span><br><span style="color: hsl(120, 100%, 40%);">+protocol=udp</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+[1234]</span><br><span style="color: hsl(120, 100%, 40%);">+type=aor</span><br><span style="color: hsl(120, 100%, 40%);">+max_contacts=1</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+[1234]</span><br><span style="color: hsl(120, 100%, 40%);">+type=endpoint</span><br><span style="color: hsl(120, 100%, 40%);">+allow=!all,ulaw</span><br><span style="color: hsl(120, 100%, 40%);">+aors=1234</span><br><span style="color: hsl(120, 100%, 40%);">+transport=dummy-transport</span><br><span style="color: hsl(120, 100%, 40%);">+context=default</span><br><span style="color: hsl(120, 100%, 40%);">+mailboxes=1234@default</span><br><span>diff --git a/tests/apps/voicemail/polling/poll_sub_unsub/configs/ast1/voicemail.conf b/tests/apps/voicemail/polling/poll_sub_unsub/configs/ast1/voicemail.conf</span><br><span>new file mode 100644</span><br><span>index 0000000..489a7a3</span><br><span>--- /dev/null</span><br><span>+++ b/tests/apps/voicemail/polling/poll_sub_unsub/configs/ast1/voicemail.conf</span><br><span>@@ -0,0 +1,6 @@</span><br><span style="color: hsl(120, 100%, 40%);">+; Voicemail Configuration</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+[general]</span><br><span style="color: hsl(120, 100%, 40%);">+format = ulaw</span><br><span style="color: hsl(120, 100%, 40%);">+pollmailboxes=yes</span><br><span style="color: hsl(120, 100%, 40%);">+pollfreq=2</span><br><span>diff --git a/tests/apps/voicemail/polling/poll_sub_unsub/run-test b/tests/apps/voicemail/polling/poll_sub_unsub/run-test</span><br><span>new file mode 100755</span><br><span>index 0000000..c77827e</span><br><span>--- /dev/null</span><br><span>+++ b/tests/apps/voicemail/polling/poll_sub_unsub/run-test</span><br><span>@@ -0,0 +1,123 @@</span><br><span style="color: hsl(120, 100%, 40%);">+#!/usr/bin/env python</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+'''</span><br><span style="color: hsl(120, 100%, 40%);">+Copyright (C) 2019, Sangoma Technologies Corporation</span><br><span style="color: hsl(120, 100%, 40%);">+Ben Ford <bford@digium.com></span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+This program is free software, distributed under the terms of</span><br><span style="color: hsl(120, 100%, 40%);">+the GNU General Public License Version 2.</span><br><span style="color: hsl(120, 100%, 40%);">+'''</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+import sys</span><br><span style="color: hsl(120, 100%, 40%);">+import logging</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+from asterisk.asterisk import Asterisk</span><br><span style="color: hsl(120, 100%, 40%);">+from asterisk.test_case import TestCase</span><br><span style="color: hsl(120, 100%, 40%);">+from asterisk.voicemail import VoiceMailMailboxManagement</span><br><span style="color: hsl(120, 100%, 40%);">+from asterisk.sipp import SIPpScenario</span><br><span style="color: hsl(120, 100%, 40%);">+from twisted.internet import reactor</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+LOGGER = logging.getLogger(__name__)</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+class PollingTest(TestCase):</span><br><span style="color: hsl(120, 100%, 40%);">+    def __init__(self):</span><br><span style="color: hsl(120, 100%, 40%);">+        TestCase.__init__(self)</span><br><span style="color: hsl(120, 100%, 40%);">+        self.passed = False</span><br><span style="color: hsl(120, 100%, 40%);">+        self.test_phase = 1</span><br><span style="color: hsl(120, 100%, 40%);">+        self._registered_done = False</span><br><span style="color: hsl(120, 100%, 40%);">+        self._unregistered_done = False</span><br><span style="color: hsl(120, 100%, 40%);">+        self.sipp_register = {'scenario': 'register.xml',</span><br><span style="color: hsl(120, 100%, 40%);">+                              '-i': '127.0.0.2', '-p': '5061',</span><br><span style="color: hsl(120, 100%, 40%);">+                              '-s': '1234'}</span><br><span style="color: hsl(120, 100%, 40%);">+        self.sipp_unregister = {'scenario': 'unregister.xml',</span><br><span style="color: hsl(120, 100%, 40%);">+                                '-i': '127.0.0.2', '-p': '5061',</span><br><span style="color: hsl(120, 100%, 40%);">+                                '-s': '1234'}</span><br><span style="color: hsl(120, 100%, 40%);">+        self.create_asterisk()</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+    def stop_test(self, passed=False):</span><br><span style="color: hsl(120, 100%, 40%);">+        self.passed = passed</span><br><span style="color: hsl(120, 100%, 40%);">+        # Sometimes the reactor has already stopped, we only care if the test passed</span><br><span style="color: hsl(120, 100%, 40%);">+        try:</span><br><span style="color: hsl(120, 100%, 40%);">+            reactor.stop()</span><br><span style="color: hsl(120, 100%, 40%);">+        except Exception as e:</span><br><span style="color: hsl(120, 100%, 40%);">+            LOGGER.info("Error while stopping reactor: '{0}'".format(e))</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+    def handle_message_waiting(self, ami, event):</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+        if event.get("mailbox") != "1234@default":</span><br><span style="color: hsl(120, 100%, 40%);">+            return</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+        old = int(event.get("old"))</span><br><span style="color: hsl(120, 100%, 40%);">+        new = int(event.get("new"))</span><br><span style="color: hsl(120, 100%, 40%);">+        waiting = int(event.get("waiting"))</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+        # Phase 1: We should get a MessageWaiting notification after registering</span><br><span style="color: hsl(120, 100%, 40%);">+        if self.test_phase == 1:</span><br><span style="color: hsl(120, 100%, 40%);">+            if new != 1 or waiting != 1 or old != 0:</span><br><span style="color: hsl(120, 100%, 40%);">+                LOGGER.error("Mailbox count was different than expected")</span><br><span style="color: hsl(120, 100%, 40%);">+                self.stop_test()</span><br><span style="color: hsl(120, 100%, 40%);">+            sipp = SIPpScenario(self.test_name, self.sipp_unregister)</span><br><span style="color: hsl(120, 100%, 40%);">+            sipp.run(self)</span><br><span style="color: hsl(120, 100%, 40%);">+            self.test_phase = 2</span><br><span style="color: hsl(120, 100%, 40%);">+        # Phase 2: There should not be a notification after unregistering</span><br><span style="color: hsl(120, 100%, 40%);">+        elif self.test_phase == 2:</span><br><span style="color: hsl(120, 100%, 40%);">+            LOGGER.error("Got a MessageWaiting event in a test phase we shouldn't have")</span><br><span style="color: hsl(120, 100%, 40%);">+            self.stop_test()</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+    def handle_originate_failure(self, reason):</span><br><span style="color: hsl(120, 100%, 40%);">+        LOGGER.error("Failed to originate call! Reason: {0}".format(reason))</span><br><span style="color: hsl(120, 100%, 40%);">+        self.stop_test()</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+    def handle_hangup(self, ami, event):</span><br><span style="color: hsl(120, 100%, 40%);">+        if "Local/playback@default" in event.get("channel"):</span><br><span style="color: hsl(120, 100%, 40%);">+            self.stop_test(True)</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+    def handle_contact_status(self, ami, event):</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+        if event.get("aor") != "1234":</span><br><span style="color: hsl(120, 100%, 40%);">+            return</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+        status = event.get("contactstatus")</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+        if status == "Created":</span><br><span style="color: hsl(120, 100%, 40%);">+            self.voicemailManager = VoiceMailMailboxManagement(self.ast[0])</span><br><span style="color: hsl(120, 100%, 40%);">+            self.voicemailManager.create_mailbox("default", "1234", True)</span><br><span style="color: hsl(120, 100%, 40%);">+            formats = ["ulaw"]</span><br><span style="color: hsl(120, 100%, 40%);">+            if not self.voicemailManager.create_dummy_voicemail("default", "1234", VoiceMailMailboxManagement.inbox_folder_name, 1, formats):</span><br><span style="color: hsl(120, 100%, 40%);">+                LOGGER.error("Failed to create voicemail")</span><br><span style="color: hsl(120, 100%, 40%);">+                self.stop_test()</span><br><span style="color: hsl(120, 100%, 40%);">+        elif status == "Removed":</span><br><span style="color: hsl(120, 100%, 40%);">+            # Remove the voicemail from the mailbox</span><br><span style="color: hsl(120, 100%, 40%);">+            self.voicemailManager.remove_mailbox("default", "1234")</span><br><span style="color: hsl(120, 100%, 40%);">+            </span><br><span style="color: hsl(120, 100%, 40%);">+            # Originate a channel that will end the test on hangup</span><br><span style="color: hsl(120, 100%, 40%);">+            variable = {}</span><br><span style="color: hsl(120, 100%, 40%);">+            ami.originate(channel="Local/playback@default",</span><br><span style="color: hsl(120, 100%, 40%);">+                          context="default",</span><br><span style="color: hsl(120, 100%, 40%);">+                          exten="echo",</span><br><span style="color: hsl(120, 100%, 40%);">+                          priority="1",</span><br><span style="color: hsl(120, 100%, 40%);">+                          variable=variable</span><br><span style="color: hsl(120, 100%, 40%);">+                         ).addErrback(self.handle_originate_failure)</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+    def ami_connect(self, ami):</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+        ami.registerEvent("ContactStatus", self.handle_contact_status)</span><br><span style="color: hsl(120, 100%, 40%);">+        ami.registerEvent("MessageWaiting", self.handle_message_waiting)</span><br><span style="color: hsl(120, 100%, 40%);">+        ami.registerEvent("Hangup", self.handle_hangup)</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+        sipp = SIPpScenario(self.test_name, self.sipp_register)</span><br><span style="color: hsl(120, 100%, 40%);">+        sipp.run(self)</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+    def run(self):</span><br><span style="color: hsl(120, 100%, 40%);">+        TestCase.run(self)</span><br><span style="color: hsl(120, 100%, 40%);">+        self.create_ami_factory()</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+def main():</span><br><span style="color: hsl(120, 100%, 40%);">+    test = PollingTest()</span><br><span style="color: hsl(120, 100%, 40%);">+    reactor.run()</span><br><span style="color: hsl(120, 100%, 40%);">+    if not test.passed:</span><br><span style="color: hsl(120, 100%, 40%);">+        return 1</span><br><span style="color: hsl(120, 100%, 40%);">+    return 0</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+if __name__ == "__main__":</span><br><span style="color: hsl(120, 100%, 40%);">+    sys.exit(main() or 0)</span><br><span>diff --git a/tests/apps/voicemail/polling/poll_sub_unsub/sipp/register.xml b/tests/apps/voicemail/polling/poll_sub_unsub/sipp/register.xml</span><br><span>new file mode 100644</span><br><span>index 0000000..5918b96</span><br><span>--- /dev/null</span><br><span>+++ b/tests/apps/voicemail/polling/poll_sub_unsub/sipp/register.xml</span><br><span>@@ -0,0 +1,24 @@</span><br><span style="color: hsl(120, 100%, 40%);">+<?xml version="1.0" encoding="ISO-8859-1" ?></span><br><span style="color: hsl(120, 100%, 40%);">+<!DOCTYPE scenario SYSTEM "sipp.dtd"></span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+<scenario name="Basic Sipstone UAC"></span><br><span style="color: hsl(120, 100%, 40%);">+    <send retrans="500"></span><br><span style="color: hsl(120, 100%, 40%);">+        <![CDATA[</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+        REGISTER sip:[remote_ip]:[remote_port] SIP/2.0</span><br><span style="color: hsl(120, 100%, 40%);">+        Via: SIP/2.0/[transport] [local_ip]:[local_port];branch=[branch]</span><br><span style="color: hsl(120, 100%, 40%);">+        From: "[service]" <sip:[service]@[local_ip]:[local_port]>;tag=[pid]SIPpTag00[call_number]</span><br><span style="color: hsl(120, 100%, 40%);">+        To: "[service]" <sip:[service]@[remote_ip]:[remote_port]></span><br><span style="color: hsl(120, 100%, 40%);">+        Call-ID: [call_id]</span><br><span style="color: hsl(120, 100%, 40%);">+        CSeq: 1 REGISTER</span><br><span style="color: hsl(120, 100%, 40%);">+        Max-Forwards: 70</span><br><span style="color: hsl(120, 100%, 40%);">+        Contact: <sip:[service]@[local_ip]:[local_port]>;transport=[transport]</span><br><span style="color: hsl(120, 100%, 40%);">+        Subject: Performance Test</span><br><span style="color: hsl(120, 100%, 40%);">+        Content-Length: 0</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+        ]]></span><br><span style="color: hsl(120, 100%, 40%);">+    </send></span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+    <recv response="200" rtd="true" timeout="5000"/></span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+</scenario></span><br><span>diff --git a/tests/apps/voicemail/polling/poll_sub_unsub/sipp/unregister.xml b/tests/apps/voicemail/polling/poll_sub_unsub/sipp/unregister.xml</span><br><span>new file mode 100644</span><br><span>index 0000000..cc340ad</span><br><span>--- /dev/null</span><br><span>+++ b/tests/apps/voicemail/polling/poll_sub_unsub/sipp/unregister.xml</span><br><span>@@ -0,0 +1,25 @@</span><br><span style="color: hsl(120, 100%, 40%);">+<?xml version="1.0" encoding="ISO-8859-1" ?></span><br><span style="color: hsl(120, 100%, 40%);">+<!DOCTYPE scenario SYSTEM "sipp.dtd"></span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+<scenario name="Basic Sipstone UAC"></span><br><span style="color: hsl(120, 100%, 40%);">+    <send retrans="500"></span><br><span style="color: hsl(120, 100%, 40%);">+        <![CDATA[</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+        REGISTER sip:[remote_ip]:[remote_port] SIP/2.0</span><br><span style="color: hsl(120, 100%, 40%);">+        Via: SIP/2.0/[transport] [local_ip]:[local_port];branch=[branch]</span><br><span style="color: hsl(120, 100%, 40%);">+        From: "[service]" <sip:[service]@[local_ip]:[local_port]>;tag=[pid]SIPpTag00[call_number]</span><br><span style="color: hsl(120, 100%, 40%);">+        To: "[service]" <sip:[service]@[remote_ip]:[remote_port]></span><br><span style="color: hsl(120, 100%, 40%);">+        Call-ID: [call_id]</span><br><span style="color: hsl(120, 100%, 40%);">+        CSeq: 1 REGISTER</span><br><span style="color: hsl(120, 100%, 40%);">+  Max-Forwards: 70</span><br><span style="color: hsl(120, 100%, 40%);">+      Expires: 0</span><br><span style="color: hsl(120, 100%, 40%);">+        Contact: <sip:[service]@[local_ip]:[local_port]>;transport=[transport]</span><br><span style="color: hsl(120, 100%, 40%);">+        Subject: Performance Test</span><br><span style="color: hsl(120, 100%, 40%);">+        Content-Length: 0</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+        ]]></span><br><span style="color: hsl(120, 100%, 40%);">+    </send></span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+    <recv response="200" rtd="true"/></span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+</scenario></span><br><span>diff --git a/tests/apps/voicemail/polling/poll_sub_unsub/test-config.yaml b/tests/apps/voicemail/polling/poll_sub_unsub/test-config.yaml</span><br><span>new file mode 100644</span><br><span>index 0000000..c2c8982</span><br><span>--- /dev/null</span><br><span>+++ b/tests/apps/voicemail/polling/poll_sub_unsub/test-config.yaml</span><br><span>@@ -0,0 +1,20 @@</span><br><span style="color: hsl(120, 100%, 40%);">+testinfo:</span><br><span style="color: hsl(120, 100%, 40%);">+    summary: 'Test polling after subscribing then unsubscribing'</span><br><span style="color: hsl(120, 100%, 40%);">+    description: |</span><br><span style="color: hsl(120, 100%, 40%);">+        This test verifies that a notification is received after subscribing to</span><br><span style="color: hsl(120, 100%, 40%);">+        a mailbox, and that no notification is received after unsubscribing from</span><br><span style="color: hsl(120, 100%, 40%);">+        the mailbox.</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+properties:</span><br><span style="color: hsl(120, 100%, 40%);">+    buildoption: 'TEST_FRAMEWORK'</span><br><span style="color: hsl(120, 100%, 40%);">+    dependencies:</span><br><span style="color: hsl(120, 100%, 40%);">+        - python : 'twisted'</span><br><span style="color: hsl(120, 100%, 40%);">+        - python : 'starpy'</span><br><span style="color: hsl(120, 100%, 40%);">+        - asterisk: 'app_echo'</span><br><span style="color: hsl(120, 100%, 40%);">+        - asterisk: 'app_playback'</span><br><span style="color: hsl(120, 100%, 40%);">+        - asterisk: 'app_voicemail'</span><br><span style="color: hsl(120, 100%, 40%);">+        - asterisk: 'chan_pjsip'</span><br><span style="color: hsl(120, 100%, 40%);">+        - asterisk: 'res_pjsip'</span><br><span style="color: hsl(120, 100%, 40%);">+    tags:</span><br><span style="color: hsl(120, 100%, 40%);">+        - voicemail</span><br><span style="color: hsl(120, 100%, 40%);">+        - apps</span><br><span>diff --git a/tests/apps/voicemail/polling/tests.yaml b/tests/apps/voicemail/polling/tests.yaml</span><br><span>new file mode 100644</span><br><span>index 0000000..171a45f</span><br><span>--- /dev/null</span><br><span>+++ b/tests/apps/voicemail/polling/tests.yaml</span><br><span>@@ -0,0 +1,7 @@</span><br><span style="color: hsl(120, 100%, 40%);">+# Enter tests here in the order they should be considered for execution:</span><br><span style="color: hsl(120, 100%, 40%);">+tests:</span><br><span style="color: hsl(120, 100%, 40%);">+    - test: 'poll_multiple_mailboxes'</span><br><span style="color: hsl(120, 100%, 40%);">+    - test: 'poll_no_subs'</span><br><span style="color: hsl(120, 100%, 40%);">+    - test: 'poll_same_mailbox'</span><br><span style="color: hsl(120, 100%, 40%);">+    - test: 'poll_single_mailbox'</span><br><span style="color: hsl(120, 100%, 40%);">+    - test: 'poll_sub_unsub'</span><br><span>diff --git a/tests/apps/voicemail/tests.yaml b/tests/apps/voicemail/tests.yaml</span><br><span>index 0ec6c61..735dbb7 100644</span><br><span>--- a/tests/apps/voicemail/tests.yaml</span><br><span>+++ b/tests/apps/voicemail/tests.yaml</span><br><span>@@ -30,3 +30,4 @@</span><br><span>     - test: 'leave_voicemail_nominal'</span><br><span>     - test: 'leave_voicemail_priority'</span><br><span>     - test: 'play_message'</span><br><span style="color: hsl(120, 100%, 40%);">+    - dir: 'polling'</span><br><span></span><br></pre><p>To view, visit <a href="https://gerrit.asterisk.org/c/testsuite/+/11285">change 11285</a>. To unsubscribe, or for help writing mail filters, visit <a href="https://gerrit.asterisk.org/settings">settings</a>.</p><div itemscope itemtype="http://schema.org/EmailMessage"><div itemscope itemprop="action" itemtype="http://schema.org/ViewAction"><link itemprop="url" href="https://gerrit.asterisk.org/c/testsuite/+/11285"/><meta itemprop="name" content="View Change"/></div></div>

<div style="display:none"> Gerrit-Project: testsuite </div>
<div style="display:none"> Gerrit-Branch: 16 </div>
<div style="display:none"> Gerrit-Change-Id: Id3a40527624c094e253d56ee2df5381b03b22169 </div>
<div style="display:none"> Gerrit-Change-Number: 11285 </div>
<div style="display:none"> Gerrit-PatchSet: 2 </div>
<div style="display:none"> Gerrit-Owner: Benjamin Keith Ford <bford@digium.com> </div>
<div style="display:none"> Gerrit-Reviewer: Friendly Automation </div>
<div style="display:none"> Gerrit-Reviewer: George Joseph <gjoseph@digium.com> </div>
<div style="display:none"> Gerrit-Reviewer: Joshua Colp <jcolp@digium.com> </div>
<div style="display:none"> Gerrit-MessageType: merged </div>