Harald Welte has submitted this change and it was merged.

Change subject: test: Add a manual test to simulate DTMF handling in 
osmo-sip-connector
......................................................................


test: Add a manual test to simulate DTMF handling in osmo-sip-connector

Add a manul test to the contrib folder that helped and can help during
the development of osmo-sip-connector or similar software. This avoids
having to create a separate mncc module.

It can be started like:

$ PYTHONPATH=$PWD/../ python manual_test_server.py

Change-Id: I7f62efbc62455e6fcb1f091afb5fa120099834f0
---
A contrib/manual_test_server.py
1 file changed, 126 insertions(+), 0 deletions(-)

Approvals:
  Harald Welte: Looks good to me, approved; Verified



diff --git a/contrib/manual_test_server.py b/contrib/manual_test_server.py
new file mode 100644
index 0000000..5625670
--- /dev/null
+++ b/contrib/manual_test_server.py
@@ -0,0 +1,126 @@
+import mncc
+import mncc_sock
+import ctypes
+import socket
+
+GSM340_PLAN_ISDN = 1
+GSM340_TYPE_NATIONAL = 2
+
+class MnccMessageBuilder(object):
+    """
+    I help in creating messages...
+    """
+    @staticmethod
+    def build_hello():
+        hello = mncc.gsm_mncc_hello()
+        hello.msg_type = mncc.MNCC_SOCKET_HELLO
+        hello.version = mncc.MNCC_SOCK_VERSION
+        hello.mncc_size = ctypes.sizeof(mncc.gsm_mncc)
+        hello.data_frame_size = ctypes.sizeof(mncc.gsm_data_frame)
+        hello.called_offset = mncc.gsm_mncc.called.offset
+        hello.signal_offset = mncc.gsm_mncc.signal.offset
+        hello.emergency_offset = mncc.gsm_mncc.emergency.offset
+        hello.lchan_type_offset = mncc.gsm_mncc.lchan_type.offset
+        return hello
+
+    @staticmethod
+    def build_mncc_number(number):
+        return mncc.gsm_mncc_number(
+                type=GSM340_TYPE_NATIONAL,
+                plan=GSM340_PLAN_ISDN,
+                number=number)
+
+    @staticmethod
+    def build_setup_ind(calling, called, callref=1):
+        setup = mncc.gsm_mncc()
+        setup.msg_type = mncc.MNCC_SETUP_IND
+        setup.callref = callref
+        setup.fields = mncc.MNCC_F_CALLED | mncc.MNCC_F_CALLING
+        setup.called = MnccMessageBuilder.build_mncc_number(called)
+        setup.calling = MnccMessageBuilder.build_mncc_number(calling)
+        return setup
+
+    @staticmethod
+    def build_setup_cmpl_ind(callref=1):
+        setup = mncc.gsm_mncc()
+        setup.msg_type = mncc.MNCC_SETUP_COMPL_IND
+        setup.callref = callref
+        return setup
+
+    @staticmethod
+    def build_rtp_msg(msg_type, callref, addr, port):
+        return mncc.gsm_mncc_rtp(
+                    msg_type=msg_type, callref=callref,
+                    ip=addr, port=port,
+                    #payload_type=3,
+                    #payload_msg_type=mncc.GSM_TCHF_FRAME)
+                    payload_type=98,
+                    payload_msg_type=mncc.GSM_TCH_FRAME_AMR)
+
+    @staticmethod
+    def build_dtmf_start(callref, data):
+        return mncc.gsm_mncc(
+                    msg_type=mncc.MNCC_START_DTMF_IND,
+                    callref=callref,
+                    fields=mncc.MNCC_F_KEYPAD,
+                    keypad=ord(data))
+
+    @staticmethod
+    def build_dtmf_stop(callref, data):
+        return mncc.gsm_mncc(
+                    callref=callref,
+                    msg_type=mncc.MNCC_STOP_DTMF_IND)
+
+def send_dtmf(callref):
+    global conn
+
+    conn.send_msg(MnccMessageBuilder.build_dtmf_start(callref, '1'))
+    conn.send_msg(MnccMessageBuilder.build_dtmf_stop(callref, '1'))
+    conn.send_msg(MnccMessageBuilder.build_dtmf_start(callref, '2'))
+    conn.send_msg(MnccMessageBuilder.build_dtmf_stop(callref, '2'))
+
+
+server = mncc_sock.MnccSocketServer()
+conn = server.accept()
+
+# Say hello and set-up a call
+conn.send_msg(MnccMessageBuilder.build_hello())
+conn.send_msg(MnccMessageBuilder.build_setup_ind("1234", "5000"))
+print("=> Sent hello + setup indication")
+
+# Wait for the RTP crate.. and actknowledge it..
+msg = conn.recv()
+assert msg.msg_type == mncc.MNCC_RTP_CREATE
+print("<= Received request to create a RTP socket")
+conn.send_msg(MnccMessageBuilder.build_rtp_msg(mncc.MNCC_RTP_CREATE,
+                                                msg.callref,
+                                                #socket.INADDR_LOOPBACK, 4000))
+                                                socket.INADDR_ANY, 4000))
+print("=> Claimed socket was created...")
+
+msg = conn.recv()
+assert msg.msg_type == mncc.MNCC_CALL_PROC_REQ
+print("<= Received proceeding...")
+
+
+
+while True:
+    msg = conn.recv()
+    if msg.msg_type == mncc.MNCC_ALERT_REQ:
+        print("=> I should alert...")
+        continue
+    if msg.msg_type == mncc.MNCC_RTP_CONNECT:
+        conn.send_msg(MnccMessageBuilder.build_rtp_msg(mncc.MNCC_RTP_CONNECT,
+                                                msg.callref,
+                                                socket.INADDR_LOOPBACK, 4000))
+        print("=> I needed to connect RTP...")
+        continue
+    if msg.msg_type == mncc.MNCC_SETUP_RSP:
+        print("=> Call is connected?")
+        conn.send_msg(MnccMessageBuilder.build_setup_cmpl_ind(msg.callref))
+        send_dtmf(msg.callref)
+        continue
+
+    print(msg)
+    print(msg.msg_type)
+print(type(msg))

-- 
To view, visit https://gerrit.osmocom.org/2452
To unsubscribe, visit https://gerrit.osmocom.org/settings

Gerrit-MessageType: merged
Gerrit-Change-Id: I7f62efbc62455e6fcb1f091afb5fa120099834f0
Gerrit-PatchSet: 1
Gerrit-Project: mncc-python
Gerrit-Branch: master
Gerrit-Owner: Holger Freyther <hol...@freyther.de>
Gerrit-Reviewer: Harald Welte <lafo...@gnumonks.org>
Gerrit-Reviewer: Holger Freyther <hol...@freyther.de>
Gerrit-Reviewer: Neels Hofmeyr <nhofm...@sysmocom.de>

Reply via email to