[svn-commits] mmichelson: branch mmichelson/queue_tests r217 - in /asterisk/team/mmichelson...
SVN commits to the Digium repositories
svn-commits at lists.digium.com
Thu Apr 8 16:32:02 CDT 2010
Author: mmichelson
Date: Thu Apr 8 16:32:00 2010
New Revision: 217
URL: http://svnview.digium.com/svn/testsuite?view=rev&rev=217
Log:
Test 1 of 19. Queue baseline.
Simple test where I put one caller through a queue to be sure that
it executes as expected. If this test fails, there's no possible way
any of the other tests are going to pass.
Added:
asterisk/team/mmichelson/queue_tests/tests/queues/
asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/
asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/configs/
asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/configs/extensions.conf (with props)
asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/configs/queues.conf (with props)
asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/configs/sip.conf (with props)
asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/run-test (with props)
asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/sipp/
asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/sipp/uas.xml (with props)
asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/test-config.yaml (with props)
asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/test.lua (with props)
Added: asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/configs/extensions.conf
URL: http://svnview.digium.com/svn/testsuite/asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/configs/extensions.conf?view=auto&rev=217
==============================================================================
--- asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/configs/extensions.conf (added)
+++ asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/configs/extensions.conf Thu Apr 8 16:32:00 2010
@@ -1,0 +1,8 @@
+[test_context]
+
+exten => test,1,Answer
+exten => test,n,Wait(1)
+exten => test,n,Hangup
+
+exten => queue,1,Queue(test_queue)
+exten => queue,n,Hangup
Propchange: asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/configs/extensions.conf
------------------------------------------------------------------------------
svn:eol-style = native
Propchange: asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/configs/extensions.conf
------------------------------------------------------------------------------
svn:keywords = Author Date Id Revision
Propchange: asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/configs/extensions.conf
------------------------------------------------------------------------------
svn:mime-type = text/plain
Added: asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/configs/queues.conf
URL: http://svnview.digium.com/svn/testsuite/asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/configs/queues.conf?view=auto&rev=217
==============================================================================
--- asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/configs/queues.conf (added)
+++ asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/configs/queues.conf Thu Apr 8 16:32:00 2010
@@ -1,0 +1,5 @@
+[general]
+
+[test_queue]
+eventwhencalled = yes
+member => SIP/peer
Propchange: asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/configs/queues.conf
------------------------------------------------------------------------------
svn:eol-style = native
Propchange: asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/configs/queues.conf
------------------------------------------------------------------------------
svn:keywords = Author Date Id Revision
Propchange: asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/configs/queues.conf
------------------------------------------------------------------------------
svn:mime-type = text/plain
Added: asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/configs/sip.conf
URL: http://svnview.digium.com/svn/testsuite/asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/configs/sip.conf?view=auto&rev=217
==============================================================================
--- asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/configs/sip.conf (added)
+++ asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/configs/sip.conf Thu Apr 8 16:32:00 2010
@@ -1,0 +1,6 @@
+[general]
+
+[peer]
+type=friend
+host=127.0.0.1
+port=5061
Propchange: asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/configs/sip.conf
------------------------------------------------------------------------------
svn:eol-style = native
Propchange: asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/configs/sip.conf
------------------------------------------------------------------------------
svn:keywords = Author Date Id Revision
Propchange: asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/configs/sip.conf
------------------------------------------------------------------------------
svn:mime-type = text/plain
Added: asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/run-test
URL: http://svnview.digium.com/svn/testsuite/asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/run-test?view=auto&rev=217
==============================================================================
--- asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/run-test (added)
+++ asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/run-test Thu Apr 8 16:32:00 2010
@@ -1,0 +1,3 @@
+#!/bin/bash -e
+
+asttest -a / -s tests/queues/queue_baseline
Propchange: asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/run-test
------------------------------------------------------------------------------
svn:eol-style = native
Propchange: asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/run-test
------------------------------------------------------------------------------
svn:executable = *
Propchange: asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/run-test
------------------------------------------------------------------------------
svn:keywords = Author Date Id Revision
Propchange: asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/run-test
------------------------------------------------------------------------------
svn:mime-type = text/plain
Added: asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/sipp/uas.xml
URL: http://svnview.digium.com/svn/testsuite/asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/sipp/uas.xml?view=auto&rev=217
==============================================================================
--- asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/sipp/uas.xml (added)
+++ asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/sipp/uas.xml Thu Apr 8 16:32:00 2010
@@ -1,0 +1,117 @@
+<?xml version="1.0" encoding="ISO-8859-1" ?>
+<!DOCTYPE scenario SYSTEM "sipp.dtd">
+
+<!-- This program is free software; you can redistribute it and/or -->
+<!-- modify it under the terms of the GNU General Public License as -->
+<!-- published by the Free Software Foundation; either version 2 of the -->
+<!-- License, or (at your option) any later version. -->
+<!-- -->
+<!-- This program is distributed in the hope that it will be useful, -->
+<!-- but WITHOUT ANY WARRANTY; without even the implied warranty of -->
+<!-- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -->
+<!-- GNU General Public License for more details. -->
+<!-- -->
+<!-- You should have received a copy of the GNU General Public License -->
+<!-- along with this program; if not, write to the -->
+<!-- Free Software Foundation, Inc., -->
+<!-- 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA -->
+<!-- -->
+<!-- Sipp default 'uas' scenario. -->
+<!-- -->
+
+<scenario name="Basic UAS responder">
+ <!-- By adding rrs="true" (Record Route Sets), the route sets -->
+ <!-- are saved and used for following messages sent. Useful to test -->
+ <!-- against stateful SIP proxies/B2BUAs. -->
+ <recv request="INVITE" crlf="true">
+ </recv>
+
+ <!-- The '[last_*]' keyword is replaced automatically by the -->
+ <!-- specified header if it was present in the last message received -->
+ <!-- (except if it was a retransmission). If the header was not -->
+ <!-- present or if no message has been received, the '[last_*]' -->
+ <!-- keyword is discarded, and all bytes until the end of the line -->
+ <!-- are also discarded. -->
+ <!-- -->
+ <!-- If the specified header was present several times in the -->
+ <!-- message, all occurences are concatenated (CRLF seperated) -->
+ <!-- to be used in place of the '[last_*]' keyword. -->
+
+ <send>
+ <![CDATA[
+
+ SIP/2.0 180 Ringing
+ [last_Via:]
+ [last_From:]
+ [last_To:];tag=[pid]SIPpTag01[call_number]
+ [last_Call-ID:]
+ [last_CSeq:]
+ Contact: <sip:[local_ip]:[local_port];transport=[transport]>
+ Content-Length: 0
+
+ ]]>
+ </send>
+
+ <send retrans="500">
+ <![CDATA[
+
+ SIP/2.0 200 OK
+ [last_Via:]
+ [last_From:]
+ [last_To:];tag=[pid]SIPpTag01[call_number]
+ [last_Call-ID:]
+ [last_CSeq:]
+ Contact: <sip:[local_ip]:[local_port];transport=[transport]>
+ Content-Type: application/sdp
+ Content-Length: [len]
+
+ v=0
+ o=user1 53655765 2353687637 IN IP[local_ip_type] [local_ip]
+ s=-
+ c=IN IP[media_ip_type] [media_ip]
+ t=0 0
+ m=audio [media_port] RTP/AVP 0 101
+ a=rtpmap:0 PCMU/8000
+ a=rtpmap:101 telephone-event/8000
+ a=fmtp:101 0-16
+ a=sendrecv
+
+ ]]>
+ </send>
+
+ <recv request="ACK"
+ rtd="true"
+ crlf="true">
+ </recv>
+
+ <recv request="BYE">
+ </recv>
+
+ <send>
+ <![CDATA[
+
+ SIP/2.0 200 OK
+ [last_Via:]
+ [last_From:]
+ [last_To:]
+ [last_Call-ID:]
+ [last_CSeq:]
+ Contact: <sip:[local_ip]:[local_port];transport=[transport]>
+ Content-Length: 0
+
+ ]]>
+ </send>
+
+ <!-- Keep the call open for a while in case the 200 is lost to be -->
+ <!-- able to retransmit it if we receive the BYE again. -->
+ <pause milliseconds="4000"/>
+
+
+ <!-- definition of the response time repartition table (unit is ms) -->
+ <ResponseTimeRepartition value="10, 20, 30, 40, 50, 100, 150, 200"/>
+
+ <!-- definition of the call length repartition table (unit is ms) -->
+ <CallLengthRepartition value="10, 50, 100, 500, 1000, 5000, 10000"/>
+
+</scenario>
+
Propchange: asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/sipp/uas.xml
------------------------------------------------------------------------------
svn:eol-style = native
Propchange: asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/sipp/uas.xml
------------------------------------------------------------------------------
svn:keywords = Author Date Id Revision
Propchange: asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/sipp/uas.xml
------------------------------------------------------------------------------
svn:mime-type = text/plain
Added: asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/test-config.yaml
URL: http://svnview.digium.com/svn/testsuite/asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/test-config.yaml?view=auto&rev=217
==============================================================================
--- asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/test-config.yaml (added)
+++ asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/test-config.yaml Thu Apr 8 16:32:00 2010
@@ -1,0 +1,12 @@
+testinfo:
+ summary: 'Get a baseline for Queue operations'
+ description: |
+ 'This test runs a single call to a single queue that has a single
+ member in it. We monitor the manager events for five specific events
+ that let us know that the call went through the queue as expected.'
+
+properties:
+ minversion: '1.4'
+ dependencies:
+ - app: 'asttest'
+ - app: 'sipp'
Propchange: asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/test-config.yaml
------------------------------------------------------------------------------
svn:eol-style = native
Propchange: asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/test-config.yaml
------------------------------------------------------------------------------
svn:keywords = Author Date Id Revision
Propchange: asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/test-config.yaml
------------------------------------------------------------------------------
svn:mime-type = text/plain
Added: asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/test.lua
URL: http://svnview.digium.com/svn/testsuite/asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/test.lua?view=auto&rev=217
==============================================================================
--- asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/test.lua (added)
+++ asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/test.lua Thu Apr 8 16:32:00 2010
@@ -1,0 +1,132 @@
+function sipp_exec(scenario, local_port)
+ return proc.exec_io("sipp",
+ "127.0.0.1",
+ "-m", "1",
+ "-sf", scenario,
+ "-i", "127.0.0.1",
+ "-p", local_port,
+ "-timeout", "30",
+ "-trace_err"
+ )
+end
+
+function sipp_exec_and_wait(scenario, name, local_port)
+ return sipp_check_error(sipp_exec(scenario, name, local_port), scenario)
+end
+
+function sipp_check_error(p, scenario)
+ local res, err = p:wait()
+
+ if not res then error(err) end
+ if res ~= 0 then
+ error("error while executing " .. scenario .. " sipp scenario (sipp exited with status " .. res .. ")\n" .. p.stderr:read("*a"))
+ end
+
+ return res, err
+end
+
+function setup_uas()
+ local t1 = sipp_exec("sipp/uas.xml", "5061")
+ return t1
+end
+
+function kill_uas(t1)
+ t1:term_or_kill()
+end
+
+function manager_setup(a)
+ local m,err = a:manager_connect()
+ if not m then
+ fail("error connecting to asterisk: " .. err)
+ end
+
+ login = ast.manager.action.login()
+ if not login then
+ fail("Couldn't create login?")
+ end
+
+ local r = m(login)
+ if not r then
+ fail("error logging in to the manager: " .. err)
+ end
+
+ if r["Response"] ~= "Success" then
+ fail("error authenticating: " .. r["Message"])
+ end
+ return m
+end
+
+join = nil
+function join_event(event)
+ join = 1
+end
+
+called = nil
+function called_event(event)
+ called = 1
+end
+
+connect = nil
+function connect_event(event)
+ connect = 1
+end
+
+leave = nil
+function leave_event(event)
+ leave = 1
+end
+
+complete = nil
+function complete_event(event)
+ complete = 1
+end
+
+function do_call(man)
+ local uas = setup_uas()
+ local orig = ast.manager.action:new("Originate")
+ orig["Channel"] = "Local/test at test_context"
+ orig["Exten"] = "queue"
+ orig["Context"] = "test_context"
+ orig["Priority"] = "1"
+ man:register_event("Join", join_event)
+ man:register_event("AgentCalled", called_event)
+ man:register_event("AgentConnect", connect_event)
+ man:register_event("Leave", leave_event)
+ man:register_event("AgentComplete", complete_event)
+ local res, err = man(orig)
+ if not res then
+ fail("Error originating call: " .. err)
+ end
+ if res["Response"] ~= "Success" then
+ fail("Response failure for Originate: " .. res["Message"])
+ end
+ posix.sleep(2)
+ res, err = man:pump_messages()
+ if not res then
+ fail("Error pumping messages: " .. err)
+ end
+ man:process_events()
+ man:unregister_event("Join", join_event)
+ man:unregister_event("AgentCalled", called_event)
+ man:unregister_event("AgentConnect", connect_event)
+ man:unregister_event("Leave", leave_event)
+ man:unregister_event("AgentComplete", complete_event)
+ kill_uas(uas)
+end
+
+instance = ast.new()
+instance:load_config("configs/extensions.conf")
+instance:load_config("configs/sip.conf")
+instance:load_config("configs/queues.conf")
+instance:generate_manager_conf()
+instance:spawn()
+
+man = manager_setup(instance)
+do_call(man)
+logoff = ast.manager.action.logoff()
+man(logoff)
+instance:term_or_kill()
+
+if not join or not called or not connect or not leave or not complete then
+ fail ("Failed to capture one of our expected events")
+end
Propchange: asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/test.lua
------------------------------------------------------------------------------
svn:eol-style = native
Propchange: asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/test.lua
------------------------------------------------------------------------------
svn:keywords = Author Date Id Revision
Propchange: asterisk/team/mmichelson/queue_tests/tests/queues/queue_baseline/test.lua
------------------------------------------------------------------------------
svn:mime-type = text/plain
More information about the svn-commits
mailing list