Tue Jul 7 15:41:36 CDT 2009 Pekka Pessi <first.last@nokia.com>

* check_session.c: testcase for INVITE forked with 100rel terminating properly



git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@14168 d0543943-73ff-0310-b7d9-9358b9ac24b2
This commit is contained in:
Michael Jerris 2009-07-09 16:01:56 +00:00
parent 5dabbe8635
commit 275bef5b98
3 changed files with 96 additions and 10 deletions

View File

@ -1 +1 @@
Thu Jul 9 10:56:15 CDT 2009 Thu Jul 9 11:00:14 CDT 2009

View File

@ -64,7 +64,7 @@ static void usage(int exitcode)
int main(int argc, char *argv[]) int main(int argc, char *argv[])
{ {
int i, failed = 0, selected = 0; int i, failed = 0, selected = 0;
int threading; int threading, single_thread, multi_thread;
char const *xml = NULL; char const *xml = NULL;
Suite *suite = suite_create("Unit tests for Sofia-SIP UA Engine"); Suite *suite = suite_create("Unit tests for Sofia-SIP UA Engine");
SRunner *runner; SRunner *runner;
@ -100,15 +100,27 @@ int main(int argc, char *argv[])
if (!selected) if (!selected)
s2_select_tests(getenv("CHECK_NUA_CASES")); s2_select_tests(getenv("CHECK_NUA_CASES"));
check_register_cases(suite, threading = 0); if (getenv("CHECK_NUA_THREADING")) {
check_simple_cases(suite, threading = 0); single_thread = strcmp(getenv("CHECK_NUA_THREADING"), "no");
check_session_cases(suite, threading = 0); multi_thread = !single_thread;
check_etsi_cases(suite, threading = 0); }
else {
single_thread = multi_thread = 1;
}
check_register_cases(suite, threading = 1); if (single_thread) {
check_session_cases(suite, threading = 1); check_register_cases(suite, threading = 0);
check_etsi_cases(suite, threading = 1); check_simple_cases(suite, threading = 0);
check_simple_cases(suite, threading = 1); check_session_cases(suite, threading = 0);
check_etsi_cases(suite, threading = 0);
}
if (multi_thread) {
check_register_cases(suite, threading = 1);
check_session_cases(suite, threading = 1);
check_etsi_cases(suite, threading = 1);
check_simple_cases(suite, threading = 1);
}
runner = srunner_create(suite); runner = srunner_create(suite);

View File

@ -1496,6 +1496,79 @@ START_TEST(call_2_4_4)
} }
END_TEST END_TEST
START_TEST(call_2_4_5)
{
nua_handle_t *nh;
struct message *invite, *prack, *cancel;
int i;
int with_sdp;
sip_from_t *branch1, *branch2;
/* Testcase for bug FSCORE-338 -
forked transactions getting canceled and terminated properly. */
S2_CASE("2.4.5", "Destroy proceeding call with 100rel",
"NUA sends INVITE, "
"receives 183, sends PRACK, receives 200 for it, "
"receives 180, sends PRACK, receives 200 for it, "
"handle is destroyed.");
nh = nua_handle(nua, NULL, SIPTAG_TO(s2sip->aor), TAG_END());
invite = invite_sent_by_nua(
nh,
NUTAG_PROXY(s2sip->tcp.contact->m_url),
NUTAG_MEDIA_ENABLE(0),
NUTAG_AUTOACK(0),
SIPTAG_CONTENT_TYPE_STR("application/sdp"),
SIPTAG_PAYLOAD_STR(
"v=0" CRLF
"o=- 6805647540234172778 5821668777690722690 IN IP4 127.0.0.1" CRLF
"s=-" CRLF
"c=IN IP4 127.0.0.1" CRLF
"m=audio 5004 RTP/AVP 0 8" CRLF),
TAG_END());
prack = respond_with_100rel(invite, dialog, with_sdp = 0,
SIP_183_SESSION_PROGRESS,
SIPTAG_CONTACT(s2sip->tcp.contact),
TAG_END());
s2_sip_respond_to(prack, dialog, SIP_200_OK, TAG_END());
s2_sip_free_message(prack), prack = NULL;
fail_unless(s2_check_callstate(nua_callstate_proceeding));
fail_unless_event(nua_r_prack, 200);
prack = respond_with_100rel(invite, dialog, with_sdp = 0,
SIP_180_RINGING,
SIPTAG_CONTACT(s2sip->tcp.contact),
TAG_END());
s2_sip_respond_to(prack, dialog, SIP_200_OK, TAG_END());
s2_sip_free_message(prack), prack = NULL;
fail_unless(s2_check_callstate(nua_callstate_proceeding));
fail_unless_event(nua_r_prack, 200);
branch1 = dialog->local;
branch2 = dialog->local = sip_from_dup(dialog->home, invite->sip->sip_to);
sip_from_tag(dialog->home, dialog->local, s2_sip_generate_tag(dialog->home));
nua_handle_destroy(nh), nh = NULL;
cancel = s2_sip_wait_for_request(SIP_METHOD_CANCEL);
s2_sip_respond_to(cancel, dialog, SIP_200_OK, TAG_END());
for (i = 1; i < 4; i++) {
s2_nua_fast_forward(1, s2base->root);
}
s2_sip_respond_to(invite, dialog, SIP_487_REQUEST_CANCELLED, TAG_END());
fail_unless(s2_sip_check_request(SIP_METHOD_ACK));
/* Time out requests */
for (i = 1; i < 128; i++) {
s2_nua_fast_forward(1, s2base->root);
}
}
END_TEST
TCase *invite_100rel_tcase(int threading) TCase *invite_100rel_tcase(int threading)
{ {
@ -1506,6 +1579,7 @@ TCase *invite_100rel_tcase(int threading)
tcase_add_test(tc, call_2_4_2); tcase_add_test(tc, call_2_4_2);
tcase_add_test(tc, call_2_4_3); tcase_add_test(tc, call_2_4_3);
tcase_add_test(tc, call_2_4_4); tcase_add_test(tc, call_2_4_4);
tcase_add_test(tc, call_2_4_5);
} }
return tc; return tc;
} }