From e0d54adf61d3d7c6eff9c5b4037c02c1735c9beb Mon Sep 17 00:00:00 2001 From: Michael Jerris Date: Wed, 11 Feb 2009 16:56:57 +0000 Subject: [PATCH] Tue Jan 13 15:19:59 CST 2009 Pekka Pessi * check_session.c: added a test case for sending re-INVITE w/o offer git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@11817 d0543943-73ff-0310-b7d9-9358b9ac24b2 --- .../libsofia-sip-ua/nua/check_session.c | 38 +++++++++++++++++++ 1 file changed, 38 insertions(+) diff --git a/libs/sofia-sip/libsofia-sip-ua/nua/check_session.c b/libs/sofia-sip/libsofia-sip-ua/nua/check_session.c index b405ec530e..aec882ee9d 100644 --- a/libs/sofia-sip/libsofia-sip-ua/nua/check_session.c +++ b/libs/sofia-sip/libsofia-sip-ua/nua/check_session.c @@ -1605,6 +1605,43 @@ START_TEST(call_2_6_3) } END_TEST +START_TEST(call_2_6_4) +{ + nua_handle_t *nh; + struct message *invite, *ack; + + s2_case("2.6.4", "re-INVITEs w/o SDP", + "NUA sends re-INVITE w/o SDP, " + "receives SDP w/ offer, " + "sends ACK w/ answer, " + "sends BYE."); + + /* Bug reported by Liu Yang 2009-01-11 */ + nh = invite_to_nua(TAG_END()); + + nua_invite(nh, SIPTAG_PAYLOAD_STR(""), TAG_END()); + fail_unless(s2_check_callstate(nua_callstate_calling)); + invite = s2_wait_for_request(SIP_METHOD_INVITE); + fail_if(!invite); + fail_if(invite->sip->sip_content_type); + soa_generate_offer(soa, 1, NULL); + respond_with_sdp(invite, dialog, SIP_200_OK, TAG_END()); + s2_free_message(invite); + + ack = s2_wait_for_request(SIP_METHOD_ACK); + fail_if(!ack); + process_answer(ack); + s2_free_message(ack); + + fail_unless(s2_check_event(nua_r_invite, 200)); + fail_unless(s2_check_callstate(nua_callstate_ready)); + + bye_by_nua(nh, TAG_END()); + + nua_handle_destroy(nh); +} +END_TEST + TCase *reinvite_tcase(void) { TCase *tc = tcase_create("2.6 - re-INVITEs"); @@ -1614,6 +1651,7 @@ TCase *reinvite_tcase(void) tcase_add_test(tc, call_2_6_1); tcase_add_test(tc, call_2_6_2); tcase_add_test(tc, call_2_6_3); + tcase_add_test(tc, call_2_6_4); } return tc; }