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:
parent
5dabbe8635
commit
275bef5b98
|
@ -1 +1 @@
|
||||||
Thu Jul 9 10:56:15 CDT 2009
|
Thu Jul 9 11:00:14 CDT 2009
|
||||||
|
|
|
@ -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);
|
||||||
|
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue