浏览代码

- add a test for the pike module

git-svn-id: https://openser.svn.sourceforge.net/svnroot/openser/trunk@5181 689a6050-402a-0410-94f2-e92a70836424
Henning Westerholt 17 年之前
父节点
当前提交
f84d91ff9c
共有 2 个文件被更改,包括 100 次插入0 次删除
  1. 32 0
      test/unit/40.cfg
  2. 68 0
      test/unit/40.sh

+ 32 - 0
test/unit/40.cfg

@@ -0,0 +1,32 @@
+mpath="../modules"
+
+loadmodule "sl/sl.so"
+loadmodule "tm/tm.so"
+loadmodule "db_mysql/db_mysql.so"
+loadmodule "usrloc/usrloc.so"
+loadmodule "registrar/registrar.so"
+loadmodule "pike/pike.so"
+loadmodule "xlog/xlog.so"
+
+modparam("usrloc", "db_mode", 3)
+modparam("usrloc", "db_url", "mysql://openser:openserrw@localhost/openser")
+
+modparam("pike", "sampling_time_unit", 5)
+modparam("pike", "reqs_density_per_unit", 25)
+modparam("pike", "remove_latency", 5)
+modparam("pike", "pike_log_level", 2)
+ 
+route{
+	if (!pike_check_req()) {
+		xlog("drop request");
+		sl_send_reply("500", "overloaded");
+	}
+
+	if(!lookup ("location")){
+		sl_send_reply("404", "Not Found");
+	}
+
+	if (!t_relay()) {
+		sl_reply_error();
+	}
+}

+ 68 - 0
test/unit/40.sh

@@ -0,0 +1,68 @@
+#!/bin/bash
+# check pike module
+
+# Copyright (C) 2008 1&1 Internet AG
+#
+# This file is part of Kamailio, a free SIP server.
+#
+# Kamailio 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
+#
+# Kamailio 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., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
+
+# Needs a default kamailio database setup for mysql
+
+source include/common
+source include/database
+
+CFG=40.cfg
+SRV=5060
+UAS=5070
+UAC=5080
+
+# add an registrar entry to the db;
+$MYSQL "INSERT INTO location (username,contact,socket,user_agent,cseq,q) VALUES (\"foo\",\"sip:foo@localhost:$UAS\",\"udp:127.0.0.1:$UAS\",\"ser_test\",1,-1);"
+
+# start
+../$BIN -w . -f $CFG &> /dev/null
+ret=$?
+
+# this should work
+if [ "$ret" -eq 0 ]; then
+	sipp -sn uas -bg -i localhost -m 10 -p $UAS &> /dev/null
+	sipp -sn uac -s foo 127.0.0.1:$SRV -i localhost -m 10 -p $UAC &> /dev/null
+	ret=$?
+fi;
+
+# this should be trigger the blocking
+if [ "$ret" -eq 0 ]; then
+	killall -9 sipp > /dev/null 2>&1
+	sipp -sn uas -bg -i localhost -m 11 -p $UAS &> /dev/null
+	sipp -sn uac -s foo 127.0.0.1:$SRV -i localhost -m 11 -p $UAC &> /dev/null
+	ret=$?
+fi;
+
+# this should work again after the timeout
+if [ "$ret" -eq 1 ]; then
+	sleep 7
+	killall -9 sipp > /dev/null 2>&1
+	sipp -sn uas -bg -i localhost -m 10 -p $UAS &> /dev/null
+	sipp -sn uac -s foo 127.0.0.1:$SRV -i localhost -m 10 -p $UAC &> /dev/null
+	ret=$?
+fi;
+
+sleep 1
+$KILL
+killall -9 sipp > /dev/null 2>&1
+
+$MYSQL "DELETE FROM location WHERE ((contact = \"sip:foo@localhost:$UAS\") and (user_agent = \"ser_test\"));"
+exit $ret