[asterisk-commits] mjordan: testsuite/asterisk/trunk r5434 - in /asterisk/trunk/tests/rest_api/b...

SVN commits to the Asterisk project asterisk-commits at lists.digium.com
Tue Aug 12 15:17:30 CDT 2014


Author: mjordan
Date: Tue Aug 12 15:17:22 2014
New Revision: 5434

URL: http://svnview.digium.com/svn/testsuite?view=rev&rev=5434
Log:
rest_api/bridges: Add tests for accountcode/linkedid propagation in ARI

This patch adds two tests:
(1) The first test (id_propagate) checks that when two channels with
    accountcodes are stored in a mixing bridge, that the accountcode of one
    channel is stored in the other's peeraccount, and that the LinkedId of the
    channel that entered the bridge first replaces the LinkedId of the bridge
    that entered last.
(2) The second test (no_id_propagate) checks the same conditions of the first
    test, but verfies that they do NOT happen when the two channels enter a
    holding bridge.

Review: https://reviewboard.asterisk.org/r/3796

ASTERISK-24003 #close
Reported by: Matt Jordan
patches:
  diffPropagate.diff uploaded by cwolfe (License 6609)

Added:
    asterisk/trunk/tests/rest_api/bridges/id_propagate/
    asterisk/trunk/tests/rest_api/bridges/id_propagate/configs/
    asterisk/trunk/tests/rest_api/bridges/id_propagate/configs/ast1/
    asterisk/trunk/tests/rest_api/bridges/id_propagate/configs/ast1/extensions.conf   (with props)
    asterisk/trunk/tests/rest_api/bridges/id_propagate/test-config.yaml   (with props)
    asterisk/trunk/tests/rest_api/bridges/no_id_propagate/
    asterisk/trunk/tests/rest_api/bridges/no_id_propagate/configs/
    asterisk/trunk/tests/rest_api/bridges/no_id_propagate/configs/ast1/
    asterisk/trunk/tests/rest_api/bridges/no_id_propagate/configs/ast1/extensions.conf   (with props)
    asterisk/trunk/tests/rest_api/bridges/no_id_propagate/test-config.yaml   (with props)
Modified:
    asterisk/trunk/tests/rest_api/bridges/tests.yaml

Added: asterisk/trunk/tests/rest_api/bridges/id_propagate/configs/ast1/extensions.conf
URL: http://svnview.digium.com/svn/testsuite/asterisk/trunk/tests/rest_api/bridges/id_propagate/configs/ast1/extensions.conf?view=auto&rev=5434
==============================================================================
--- asterisk/trunk/tests/rest_api/bridges/id_propagate/configs/ast1/extensions.conf (added)
+++ asterisk/trunk/tests/rest_api/bridges/id_propagate/configs/ast1/extensions.conf Tue Aug 12 15:17:22 2014
@@ -1,0 +1,5 @@
+[default]
+
+exten => s,1,NoOp()
+	same => n,Answer()
+	same => n,Echo()

Propchange: asterisk/trunk/tests/rest_api/bridges/id_propagate/configs/ast1/extensions.conf
------------------------------------------------------------------------------
    svn:eol-style = native

Propchange: asterisk/trunk/tests/rest_api/bridges/id_propagate/configs/ast1/extensions.conf
------------------------------------------------------------------------------
    svn:keywords = Author Date Id Revision

Propchange: asterisk/trunk/tests/rest_api/bridges/id_propagate/configs/ast1/extensions.conf
------------------------------------------------------------------------------
    svn:mime-type = text/plain

Added: asterisk/trunk/tests/rest_api/bridges/id_propagate/test-config.yaml
URL: http://svnview.digium.com/svn/testsuite/asterisk/trunk/tests/rest_api/bridges/id_propagate/test-config.yaml?view=auto&rev=5434
==============================================================================
--- asterisk/trunk/tests/rest_api/bridges/id_propagate/test-config.yaml (added)
+++ asterisk/trunk/tests/rest_api/bridges/id_propagate/test-config.yaml Tue Aug 12 15:17:22 2014
@@ -1,0 +1,206 @@
+testinfo:
+    summary: Test checks whether in a mixing two party bridge, the bridge propagates
+             linkedids and accountcodes.
+    description: |
+             Two channels are created, named alice and bob.  Their accountcodes are set
+             to the same name of their respective channelIds, as are their linkedIds.
+             They both enter a mixing bridge, and their accountcodes should be stored
+             in the other's respective peeraccount.  The channel that entered first also
+             replaces the other's linkedId with its own.  If these events occur, the
+             test passes.
+
+
+test-modules:
+    add-test-to-search-path: True
+    test-object:
+        config-section: test-object-config
+        typename: ari.AriOriginateTestObject
+    modules:
+        -   config-section: ari-config
+            typename: ari.WebSocketEventModule
+        -
+            config-section: cel-config
+            typename: ami.AMIEventModule
+
+test-object-config:
+    test-iterations:
+        -
+            endpoint: 'Local/s at default'
+            channelId: 'alice'
+            app: 'testsuite'
+
+
+
+ari-config:
+    apps: testsuite
+    events:
+        -
+            conditions:
+                match:
+                    type: StasisStart
+                    application: testsuite
+                    channel:
+                        id: 'alice'
+            count: 1
+            requests:
+                -
+                    method: 'post'
+                    uri: 'channels/alice/variable'
+                    params:
+                        variable: 'CHANNEL(accountcode)'
+                        value: 'alice'
+                -
+                    method: 'post'
+                    uri: 'channels'
+                    params:
+                        endpoint: 'Local/s at default'
+                        app: 'testsuite'
+                        channelId: 'bob'
+        -
+            conditions:
+                match:
+                    type: StasisStart
+                    application: testsuite
+                    channel:
+                        id: 'bob'
+            count: 1
+            requests:
+                -
+                    method: 'post'
+                    uri: 'channels/bob/variable'
+                    params:
+                        variable: 'CHANNEL(accountcode)'
+                        value: 'bob'
+                -
+                    method: 'post'
+                    uri: 'bridges'
+                    params:
+                        bridgeId: 'TheBridge'
+                        type: 'mixing'
+                -
+                    method: 'post'
+                    uri: 'bridges/TheBridge/addChannel'
+                    params:
+                        channel: 'alice'
+        -
+            conditions:
+                match:
+                    type: ChannelEnteredBridge
+                    application: testsuite
+                    channel:
+                        id: 'alice'
+            count: 1
+            requests:
+                method: 'post'
+                uri: 'bridges/TheBridge/addChannel'
+                params:
+                    channel: 'bob'
+        -
+            conditions:
+                match:
+                    type: ChannelEnteredBridge
+                    application: testsuite
+                    channel:
+                        id: 'bob'
+            count: 1
+            requests:
+                method: 'post'
+                uri: 'bridges/TheBridge/removeChannel'
+                params:
+                    channel: 'alice'
+        -
+            conditions:
+                match:
+                    type: ChannelLeftBridge
+                    application: testsuite
+                    channel:
+                        id: 'alice'
+            count: 1
+            requests:
+                method: 'post'
+                uri: 'bridges/TheBridge/removeChannel'
+                params:
+                    channel: 'bob'
+        -
+            conditions:
+                match:
+                    type: ChannelLeftBridge
+                    application: testsuite
+                    channel:
+                        id: 'bob'
+            count: 1
+            requests:
+                -
+                    method: 'delete'
+                    uri: 'bridges/TheBridge'
+                -
+                    method: 'delete'
+                    uri: 'channels/bob'
+                -
+                    method: 'delete'
+                    uri: 'channels/alice'
+
+
+cel-config:
+    -
+        type: 'cel'
+        conditions:
+            match:
+                Channel: 'Local/s at default-.{7}0;1'
+        requirements:
+            -
+                match:
+                    EventName: 'CHAN_START'
+                    UniqueID: 'alice'
+                    PeerAccount: ''
+                    LinkedID: 'alice'
+    -
+        type: 'cel'
+        conditions:
+            match:
+                Channel: 'Local/s at default-.{7}1;1'
+        requirements:
+            -
+                match:
+                    EventName: 'CHAN_START'
+                    UniqueID: 'bob'
+                    PeerAccount: ''
+                    LinkedID: 'bob'
+    -
+        type: 'cel'
+        conditions:
+            match:
+                Channel: 'Local/s at default-.{7}0;1'
+        requirements:
+            -
+                match:
+                    EventName: 'BRIDGE_EXIT'
+                    UniqueID: 'alice'
+                    PeerAccount: 'bob'
+                    LinkedID: 'alice'
+    -
+        type: 'cel'
+        conditions:
+            match:
+                Channel: 'Local/s at default-.{7}1;1'
+        requirements:
+            -
+                match:
+                     EventName: 'BRIDGE_EXIT'
+                     UniqueID: 'bob'
+                     PeerAccount: 'alice'
+                     LinkedID: 'alice'
+
+
+
+properties:
+    minversion: '13.0.0'
+    dependencies:
+        - python : autobahn.websocket
+        - python : requests
+        - python : twisted
+        - python : starpy
+        - asterisk : res_ari_channels
+    tags:
+        - ARI
+        - accountcode

Propchange: asterisk/trunk/tests/rest_api/bridges/id_propagate/test-config.yaml
------------------------------------------------------------------------------
    svn:eol-style = native

Propchange: asterisk/trunk/tests/rest_api/bridges/id_propagate/test-config.yaml
------------------------------------------------------------------------------
    svn:keywords = Author Date Id Revision

Propchange: asterisk/trunk/tests/rest_api/bridges/id_propagate/test-config.yaml
------------------------------------------------------------------------------
    svn:mime-type = text/plain

Added: asterisk/trunk/tests/rest_api/bridges/no_id_propagate/configs/ast1/extensions.conf
URL: http://svnview.digium.com/svn/testsuite/asterisk/trunk/tests/rest_api/bridges/no_id_propagate/configs/ast1/extensions.conf?view=auto&rev=5434
==============================================================================
--- asterisk/trunk/tests/rest_api/bridges/no_id_propagate/configs/ast1/extensions.conf (added)
+++ asterisk/trunk/tests/rest_api/bridges/no_id_propagate/configs/ast1/extensions.conf Tue Aug 12 15:17:22 2014
@@ -1,0 +1,6 @@
+[default]
+
+exten => s,1,NoOp()
+	same => n,Answer()
+	same => n,Echo()
+

Propchange: asterisk/trunk/tests/rest_api/bridges/no_id_propagate/configs/ast1/extensions.conf
------------------------------------------------------------------------------
    svn:eol-style = native

Propchange: asterisk/trunk/tests/rest_api/bridges/no_id_propagate/configs/ast1/extensions.conf
------------------------------------------------------------------------------
    svn:keywords = Author Date Id Revision

Propchange: asterisk/trunk/tests/rest_api/bridges/no_id_propagate/configs/ast1/extensions.conf
------------------------------------------------------------------------------
    svn:mime-type = text/plain

Added: asterisk/trunk/tests/rest_api/bridges/no_id_propagate/test-config.yaml
URL: http://svnview.digium.com/svn/testsuite/asterisk/trunk/tests/rest_api/bridges/no_id_propagate/test-config.yaml?view=auto&rev=5434
==============================================================================
--- asterisk/trunk/tests/rest_api/bridges/no_id_propagate/test-config.yaml (added)
+++ asterisk/trunk/tests/rest_api/bridges/no_id_propagate/test-config.yaml Tue Aug 12 15:17:22 2014
@@ -1,0 +1,199 @@
+testinfo:
+    summary: Test checks whether in a holding two party bridge, the bridge does NOT
+             propagate linkedids and accountcodes.
+    description: |
+             Two channels, labelled as alice and bob, both enter a holding bridge. One
+             channel, alice, has an accountcode, while the other one doesn't. When they
+             enter the bridge, the accountcode of one channel should NOT be stored in
+             in the other's peeraccount.  The LinkedId of the channel that entered the
+             bridge first should not replace the LinkedId of the channel that entered
+             last. Fails if conditions aren't met.
+
+
+test-modules:
+    add-test-to-search-path: True
+    test-object:
+        config-section: test-object-config
+        typename: ari.AriOriginateTestObject
+    modules:
+        -   config-section: ari-config
+            typename: ari.WebSocketEventModule
+        -
+            config-section: cel-config
+            typename: ami.AMIEventModule
+
+test-object-config:
+    test-iterations:
+        -
+            endpoint: 'Local/s at default'
+            channelId: 'alice'
+            app: 'testsuite'
+
+
+ari-config:
+    apps: testsuite
+    events:
+        -
+            conditions:
+                match:
+                    type: StasisStart
+                    application: testsuite
+                    channel:
+                        id: 'alice'
+            count: 1
+            requests:
+                -
+                    method: 'post'
+                    uri: 'channels/alice/variable'
+                    params:
+                        variable: 'CHANNEL(accountcode)'
+                        value: 'alice'
+                -
+                    method: 'post'
+                    uri: 'channels'
+                    params:
+                        endpoint: 'Local/s at default'
+                        app: 'testsuite'
+                        channelId: 'bob'
+        -
+            conditions:
+                match:
+                    type: StasisStart
+                    application: testsuite
+                    channel:
+                        id: 'bob'
+            count: 1
+            requests:
+                -
+                    method: 'post'
+                    uri: 'bridges'
+                    params:
+                        bridgeId: 'TheBridge'
+                        type: 'holding'
+                -
+                    method: 'post'
+                    uri: 'bridges/TheBridge/addChannel'
+                    params:
+                        channel: 'alice'
+        -
+            conditions:
+                match:
+                    type: ChannelEnteredBridge
+                    application: testsuite
+                    channel:
+                        id: 'alice'
+            count: 1
+            requests:
+                method: 'post'
+                uri: 'bridges/TheBridge/addChannel'
+                params:
+                    channel: 'bob'
+        -
+            conditions:
+                match:
+                    type: ChannelEnteredBridge
+                    application: testsuite
+                    channel:
+                        id: 'bob'
+            count: 1
+            requests:
+                method: 'post'
+                uri: 'bridges/TheBridge/removeChannel'
+                params:
+                    channel: 'alice'
+        -
+            conditions:
+                match:
+                    type: ChannelLeftBridge
+                    application: testsuite
+                    channel:
+                        id: 'alice'
+            count: 1
+            requests:
+                method: 'post'
+                uri: 'bridges/TheBridge/removeChannel'
+                params:
+                    channel: 'bob'
+        -
+            conditions:
+                match:
+                    type: ChannelLeftBridge
+                    application: testsuite
+                    channel:
+                        id: 'bob'
+            count: 1
+            requests:
+                -
+                    method: 'delete'
+                    uri: 'bridges/TheBridge'
+                -
+                    method: 'delete'
+                    uri: 'channels/bob'
+                -
+                    method: 'delete'
+                    uri: 'channels/alice'
+
+
+cel-config:
+    -
+        type: 'cel'
+        conditions:
+            match:
+                Channel: 'Local/s at default-.{7}0;1'
+        requirements:
+            -
+                match:
+                    EventName: 'CHAN_START'
+                    UniqueID: 'alice'
+                    PeerAccount: ''
+                    LinkedID: 'alice'
+    -
+        type: 'cel'
+        conditions:
+            match:
+                Channel: 'Local/s at default-.{7}1;1'
+        requirements:
+            -
+                match:
+                    EventName: 'CHAN_START'
+                    UniqueID: 'bob'
+                    PeerAccount: ''
+                    LinkedID: 'bob'
+    -
+        type: 'cel'
+        conditions:
+            match:
+                Channel: 'Local/s at default-.{7}0;1'
+        requirements:
+            -
+                match:
+                     EventName: 'BRIDGE_EXIT'
+                     UniqueID: 'alice'
+                     PeerAccount: ''
+                     LinkedID: 'alice'
+    -
+        type: 'cel'
+        conditions:
+            match:
+                Channel: 'Local/s at default-.{7}1;1'
+        requirements:
+            -
+                match:
+                     EventName: 'BRIDGE_EXIT'
+                     UniqueID: 'bob'
+                     PeerAccount: ''
+                     LinkedID: 'bob'
+
+
+
+properties:
+    minversion: '13.0.0'
+    dependencies:
+        - python : autobahn.websocket
+        - python : requests
+        - python : twisted
+        - python : starpy
+        - asterisk : res_ari_channels
+    tags:
+        - ARI
+        - accountcode

Propchange: asterisk/trunk/tests/rest_api/bridges/no_id_propagate/test-config.yaml
------------------------------------------------------------------------------
    svn:eol-style = native

Propchange: asterisk/trunk/tests/rest_api/bridges/no_id_propagate/test-config.yaml
------------------------------------------------------------------------------
    svn:keywords = Author Date Id Revision

Propchange: asterisk/trunk/tests/rest_api/bridges/no_id_propagate/test-config.yaml
------------------------------------------------------------------------------
    svn:mime-type = text/plain

Modified: asterisk/trunk/tests/rest_api/bridges/tests.yaml
URL: http://svnview.digium.com/svn/testsuite/asterisk/trunk/tests/rest_api/bridges/tests.yaml?view=diff&rev=5434&r1=5433&r2=5434
==============================================================================
--- asterisk/trunk/tests/rest_api/bridges/tests.yaml (original)
+++ asterisk/trunk/tests/rest_api/bridges/tests.yaml Tue Aug 12 15:17:22 2014
@@ -9,4 +9,6 @@
     - test: 'attended_transfer'
     - test: 'bridge_by_id'
     - test: 'bridge_record'
+    - test: 'id_propagate'
+    - test: 'no_id_propagate'
     - dir: 'playback'




More information about the asterisk-commits mailing list