[Freeswitch-svn] [commit] r9508 - freeswitch/trunk/libs/sofia-sip/libsofia-sip-ua/nua

Freeswitch SVN mikej at freeswitch.org
Wed Sep 10 12:21:28 EDT 2008


Author: mikej
Date: Wed Sep 10 12:21:28 2008
New Revision: 9508

Modified:
   freeswitch/trunk/libs/sofia-sip/libsofia-sip-ua/nua/check_session.c

Log:
Wed Sep 10 09:39:03 EDT 2008  Pekka Pessi <first.last at nokia.com>
  * check_session.c: added case 2.1.8, Call using NUTAG_PROXY().



Modified: freeswitch/trunk/libs/sofia-sip/libsofia-sip-ua/nua/check_session.c
==============================================================================
--- freeswitch/trunk/libs/sofia-sip/libsofia-sip-ua/nua/check_session.c	(original)
+++ freeswitch/trunk/libs/sofia-sip/libsofia-sip-ua/nua/check_session.c	Wed Sep 10 12:21:28 2008
@@ -47,6 +47,9 @@
 #include <string.h>
 #include <assert.h>
 
+/* define XXX as 1 in order to see all failing test cases */
+#define XXX (0)
+
 /* ====================================================================== */
 /* Call cases */
 
@@ -230,9 +233,7 @@
   ta_list ta;
 
   ta_start(ta, tag, value);
-  invite = invite_sent_by_nua(
-    nh, SOATAG_USER_SDP_STR("m=audio 5004 RTP/AVP 0 8"),
-    ta_tags(ta));
+  invite = invite_sent_by_nua(nh, ta_tags(ta));
   ta_end(ta);
 
   process_offer(invite);
@@ -588,6 +589,43 @@
 END_TEST
 
 
+START_TEST(call_2_1_8)
+{
+  nua_handle_t *nh;
+  struct message *invite, *ack;
+
+  s2_case("2.1.8", "Call using NUTAG_PROXY()",
+	  "Test handle-specific NUTAG_PROXY().");
+
+  nh = nua_handle(nua, NULL, SIPTAG_TO(s2->local), TAG_END());
+
+  invite = invite_sent_by_nua(
+    nh, SOATAG_USER_SDP_STR("m=audio 5004 RTP/AVP 0 8"),
+    NUTAG_PROXY(s2->tcp.contact->m_url), TAG_END());
+
+  process_offer(invite);
+  respond_with_sdp(
+    invite, dialog, SIP_180_RINGING,
+    SIPTAG_CONTENT_DISPOSITION_STR("session;handling=optional"),
+    TAG_END());
+
+  fail_unless(s2_check_event(nua_r_invite, 180));
+  fail_unless(s2_check_callstate(nua_callstate_proceeding));
+
+  respond_with_sdp(invite, dialog, SIP_200_OK, TAG_END());
+  s2_free_message(invite);
+  fail_unless(s2_check_event(nua_r_invite, 200));
+  fail_unless(s2_check_callstate(nua_callstate_ready));
+  ack = s2_wait_for_request(SIP_METHOD_ACK);
+  fail_unless(ack && tport_is_tcp(ack->tport));
+
+  bye_by_nua(nh, TAG_END());
+
+  nua_handle_destroy(nh);
+}
+END_TEST
+
+
 TCase *invite_tcase(void)
 {
   TCase *tc = tcase_create("2.1 - Basic INVITE");
@@ -600,6 +638,7 @@
     tcase_add_test(tc, call_2_1_5);
     tcase_add_test(tc, call_2_1_6);
     tcase_add_test(tc, call_2_1_7);
+    tcase_add_test(tc, call_2_1_8);
   }
   return tc;
 }



More information about the Freeswitch-svn mailing list