Thu Apr 16 12:11:33 CDT 2009 Pekka Pessi <first.last@nokia.com>

* check_session.c: added yet another test case for re-INVITE glare

  S2_CASE("2.6.5", "Re-INVITE glare and 500 Retry-After",
         "NUA receives re-INVITE, replies with 200, "
         "sends re-INVITE, gets 500, gets ACK, retrys INVITE,"
         "sends BYE.");

test case for SFSIP-135 and SFSIP-137



git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@13063 d0543943-73ff-0310-b7d9-9358b9ac24b2
This commit is contained in:
Michael Jerris 2009-04-16 17:21:54 +00:00
parent 59478dd599
commit 0ed0ef9e5e
2 changed files with 71 additions and 6 deletions

View File

@ -1 +1 @@
Thu Apr 16 12:18:30 CDT 2009
Thu Apr 16 12:20:45 CDT 2009

View File

@ -1710,7 +1710,7 @@ START_TEST(call_2_6_2)
invite = s2_sip_wait_for_request(SIP_METHOD_INVITE);
fail_if(!invite);
respond_with_sdp(invite, dialog, SIP_500_INTERNAL_SERVER_ERROR,
s2_sip_respond_to(invite, dialog, SIP_500_INTERNAL_SERVER_ERROR,
SIPTAG_RETRY_AFTER_STR("8"),
TAG_END());
s2_sip_free_message(invite);
@ -1851,6 +1851,70 @@ START_TEST(call_2_6_4)
}
END_TEST
START_TEST(call_2_6_5)
{
nua_handle_t *nh;
struct event *reinvite;
struct message *invite, *ack, *response;
/* Test case for FreeSwitch bugs #SFSIP-135, #SFSIP-137 */
S2_CASE("2.6.5", "Re-INVITE glare and 500 Retry-After",
"NUA receives re-INVITE, replies with 200, "
"sends re-INVITE, gets 500, gets ACK, retrys INVITE,"
"sends BYE.");
nh = invite_to_nua(TAG_END());
soa_generate_offer(soa, 1, NULL);
request_with_sdp(dialog, SIP_METHOD_INVITE, NULL, TAG_END());
reinvite = s2_wait_for_event(nua_i_invite, 200); fail_unless(reinvite != NULL);
fail_unless(s2_check_callstate(nua_callstate_completed));
response = s2_sip_wait_for_response(200, SIP_METHOD_INVITE);
fail_if(!response);
s2_sip_update_dialog(dialog, response);
process_answer(response);
s2_sip_free_message(response);
nua_invite(nh, TAG_END());
fail_unless(s2_check_callstate(nua_callstate_calling));
invite = s2_sip_wait_for_request(SIP_METHOD_INVITE);
fail_if(!invite);
s2_sip_respond_to(invite, dialog, SIP_500_INTERNAL_SERVER_ERROR,
SIPTAG_RETRY_AFTER_STR("7"),
TAG_END());
s2_sip_free_message(invite);
ack = s2_sip_wait_for_request(SIP_METHOD_ACK);
fail_if(!ack);
s2_sip_free_message(ack);
/* We get nua_r_invite with 100 trying (and 500 in sip->sip_status) */
fail_unless_event(nua_r_invite, 100);
fail_if(s2_sip_request_to(dialog, SIP_METHOD_ACK, NULL, TAG_END()));
fail_unless_event(nua_i_ack, 200);
fail_unless(s2_check_callstate(nua_callstate_ready));
s2_nua_fast_forward(10, s2base->root);
fail_unless(s2_check_callstate(nua_callstate_calling));
invite = s2_sip_wait_for_request(SIP_METHOD_INVITE);
process_offer(invite);
respond_with_sdp(invite, dialog, SIP_200_OK, TAG_END());
fail_unless_event(nua_r_invite, 200);
fail_unless(s2_check_callstate(nua_callstate_ready));
ack = s2_sip_wait_for_request(SIP_METHOD_ACK);
fail_if(!ack);
s2_sip_free_message(ack);
bye_by_nua(nh, TAG_END());
nua_handle_destroy(nh);
}
END_TEST
TCase *reinvite_tcase(int threading)
{
TCase *tc = tcase_create("2.6 - re-INVITEs");
@ -1861,6 +1925,7 @@ TCase *reinvite_tcase(int threading)
tcase_add_test(tc, call_2_6_2);
tcase_add_test(tc, call_2_6_3);
tcase_add_test(tc, call_2_6_4);
tcase_add_test(tc, call_2_6_5);
}
return tc;
}