2006-12-21 06:30:28 +00:00
|
|
|
/*
|
|
|
|
* This file is part of the Sofia-SIP package
|
|
|
|
*
|
|
|
|
* Copyright (C) 2005 Nokia Corporation.
|
|
|
|
*
|
|
|
|
* Contact: Pekka Pessi <pekka.pessi@nokia.com>
|
|
|
|
*
|
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU Lesser General Public License
|
|
|
|
* as published by the Free Software Foundation; either version 2.1 of
|
|
|
|
* the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This library is distributed in the hope that it will be useful, but
|
|
|
|
* WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* Lesser General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
|
|
* License along with this library; if not, write to the Free Software
|
|
|
|
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
|
|
|
|
* 02110-1301 USA
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**@CFILE test_nua.c
|
|
|
|
* @brief High-level tester for Sofia SIP User Agent Engine
|
|
|
|
*
|
|
|
|
* @author Pekka Pessi <Pekka.Pessi@nokia.com>
|
|
|
|
* @author Martti Mela <Martti Mela@nokia.com>
|
|
|
|
*
|
|
|
|
* @date Created: Wed Aug 17 12:12:12 EEST 2005 ppessi
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "config.h"
|
|
|
|
|
|
|
|
#include "test_nua.h"
|
|
|
|
|
|
|
|
#if HAVE_ALARM
|
|
|
|
#include <signal.h>
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(_WIN32)
|
|
|
|
#include <fcntl.h>
|
|
|
|
#endif
|
|
|
|
|
|
|
|
SOFIAPUBVAR su_log_t nua_log[];
|
|
|
|
SOFIAPUBVAR su_log_t soa_log[];
|
|
|
|
SOFIAPUBVAR su_log_t nea_log[];
|
|
|
|
SOFIAPUBVAR su_log_t nta_log[];
|
|
|
|
SOFIAPUBVAR su_log_t tport_log[];
|
|
|
|
SOFIAPUBVAR su_log_t su_log_default[];
|
|
|
|
|
|
|
|
char const name[] = "test_nua";
|
|
|
|
int print_headings = 1;
|
|
|
|
int tstflags = 0;
|
|
|
|
|
|
|
|
#if HAVE_FUNC
|
|
|
|
#elif HAVE_FUNCTION
|
|
|
|
#define __func__ __FUNCTION__
|
|
|
|
#else
|
|
|
|
#define __func__ name
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if HAVE_ALARM
|
|
|
|
static RETSIGTYPE sig_alarm(int s)
|
|
|
|
{
|
|
|
|
fprintf(stderr, "%s: FAIL! test timeout!\n", name);
|
|
|
|
exit(1);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
static char const options_usage[] =
|
|
|
|
" -v | --verbose be verbose\n"
|
|
|
|
" -q | --quiet be quiet\n"
|
2007-04-15 02:03:41 +00:00
|
|
|
" -a | --abort abort on error\n"
|
2006-12-21 06:30:28 +00:00
|
|
|
" -s use only single thread\n"
|
|
|
|
" -l level set logging level (0 by default)\n"
|
|
|
|
" -e | --events print nua events\n"
|
|
|
|
" -A print nua events for A\n"
|
|
|
|
" -B print nua events for B\n"
|
|
|
|
" -C print nua events for C\n"
|
2007-04-15 02:03:41 +00:00
|
|
|
" --log=a log messages for A\n"
|
|
|
|
" --log=b log messages for B\n"
|
|
|
|
" --log=c log messages for C\n"
|
|
|
|
" --log=proxy log messages for proxy\n"
|
2006-12-21 06:30:28 +00:00
|
|
|
" --attach print pid, wait for a debugger to be attached\n"
|
|
|
|
" --no-proxy do not use internal proxy\n"
|
|
|
|
" --no-nat do not use internal \"nat\"\n"
|
|
|
|
" --symmetric run internal \"nat\" in symmetric mode\n"
|
|
|
|
" -N print events from internal \"nat\"\n"
|
2007-04-15 02:03:41 +00:00
|
|
|
" --loop loop main tests for ever\n"
|
2006-12-21 06:30:28 +00:00
|
|
|
" --no-alarm don't ask for guard ALARM\n"
|
|
|
|
" -p uri specify uri of outbound proxy (implies --no-proxy)\n"
|
|
|
|
" --proxy-tests run tests involving proxy, too\n"
|
2007-04-15 02:03:41 +00:00
|
|
|
#if SU_HAVE_OSX_CF_API /* If compiled with CoreFoundation events */
|
|
|
|
" --osx-runloop use OSX CoreFoundation runloop instead of poll() loop\n"
|
|
|
|
#endif
|
2006-12-21 06:30:28 +00:00
|
|
|
" -k do not exit after first error\n"
|
|
|
|
;
|
|
|
|
|
|
|
|
void usage(int exitcode)
|
|
|
|
{
|
|
|
|
fprintf(stderr, "usage: %s OPTIONS\n where OPTIONS are\n%s",
|
|
|
|
name, options_usage);
|
|
|
|
exit(exitcode);
|
|
|
|
}
|
|
|
|
|
|
|
|
int main(int argc, char *argv[])
|
|
|
|
{
|
|
|
|
int retval = 0;
|
2007-04-15 02:03:41 +00:00
|
|
|
int i, o_quiet = 0, o_attach = 0, o_alarm = 1, o_loop = 0;
|
2006-12-21 06:30:28 +00:00
|
|
|
int o_events_init = 0, o_events_a = 0, o_events_b = 0, o_events_c = 0;
|
|
|
|
int o_iproxy = 1, o_inat = 1;
|
|
|
|
int o_inat_symmetric = 0, o_inat_logging = 0, o_expensive = 0;
|
|
|
|
url_t const *o_proxy = NULL;
|
|
|
|
int level = 0;
|
|
|
|
|
|
|
|
struct context ctx[1] = {{{ SU_HOME_INIT(ctx) }}};
|
|
|
|
|
2007-08-06 19:24:10 +00:00
|
|
|
#if HAVE_OPEN_C
|
|
|
|
dup2(1, 2);
|
|
|
|
#endif
|
|
|
|
|
2006-12-21 06:30:28 +00:00
|
|
|
if (getenv("EXPENSIVE_CHECKS"))
|
|
|
|
o_expensive = 1;
|
|
|
|
|
|
|
|
ctx->threading = 1;
|
|
|
|
ctx->quit_on_single_failure = 1;
|
|
|
|
|
|
|
|
endpoint_init(ctx, &ctx->a, 'a');
|
|
|
|
endpoint_init(ctx, &ctx->b, 'b');
|
|
|
|
endpoint_init(ctx, &ctx->c, 'c');
|
|
|
|
|
|
|
|
for (i = 1; argv[i]; i++) {
|
|
|
|
if (strcmp(argv[i], "-v") == 0 || strcmp(argv[i], "--verbose") == 0)
|
|
|
|
tstflags |= tst_verbatim;
|
|
|
|
else if (strcmp(argv[i], "-a") == 0 || strcmp(argv[i], "--abort") == 0)
|
|
|
|
tstflags |= tst_abort;
|
|
|
|
else if (strcmp(argv[i], "-q") == 0 || strcmp(argv[i], "--quiet") == 0)
|
|
|
|
tstflags &= ~tst_verbatim, o_quiet = 1;
|
|
|
|
else if (strcmp(argv[i], "-k") == 0)
|
|
|
|
ctx->quit_on_single_failure = 0;
|
|
|
|
else if (strncmp(argv[i], "-l", 2) == 0) {
|
|
|
|
char *rest = NULL;
|
|
|
|
|
|
|
|
if (argv[i][2])
|
|
|
|
level = strtol(argv[i] + 2, &rest, 10);
|
|
|
|
else if (argv[i + 1])
|
|
|
|
level = strtol(argv[i + 1], &rest, 10), i++;
|
|
|
|
else
|
|
|
|
level = 3, rest = "";
|
|
|
|
|
|
|
|
if (rest == NULL || *rest)
|
|
|
|
usage(1);
|
|
|
|
|
|
|
|
su_log_set_level(nua_log, level);
|
|
|
|
su_log_soft_set_level(soa_log, level);
|
|
|
|
su_log_soft_set_level(nea_log, level);
|
|
|
|
su_log_soft_set_level(nta_log, level);
|
|
|
|
su_log_soft_set_level(tport_log, level);
|
|
|
|
}
|
|
|
|
else if (strcmp(argv[i], "-e") == 0 || strcmp(argv[i], "--events") == 0) {
|
|
|
|
o_events_init = o_events_a = o_events_b = o_events_c = 1;
|
|
|
|
}
|
|
|
|
else if (strcmp(argv[i], "-I") == 0) {
|
|
|
|
o_events_init = 1;
|
|
|
|
}
|
|
|
|
else if (strcmp(argv[i], "-A") == 0) {
|
|
|
|
o_events_a = 1;
|
|
|
|
}
|
|
|
|
else if (strcmp(argv[i], "-B") == 0) {
|
|
|
|
o_events_b = 1;
|
|
|
|
}
|
|
|
|
else if (strcmp(argv[i], "-C") == 0) {
|
|
|
|
o_events_c = 1;
|
|
|
|
}
|
|
|
|
else if (strcmp(argv[i], "-s") == 0) {
|
|
|
|
ctx->threading = 0;
|
|
|
|
}
|
|
|
|
else if (strcmp(argv[i], "--attach") == 0) {
|
|
|
|
o_attach = 1;
|
|
|
|
}
|
|
|
|
else if (strncmp(argv[i], "-p", 2) == 0) {
|
|
|
|
if (argv[i][2])
|
|
|
|
o_proxy = URL_STRING_MAKE(argv[i] + 2)->us_url;
|
|
|
|
else if (!argv[++i] || argv[i][0] == '-')
|
|
|
|
usage(1);
|
|
|
|
else
|
|
|
|
o_proxy = URL_STRING_MAKE(argv[i])->us_url;
|
|
|
|
}
|
|
|
|
else if (strcmp(argv[i], "--proxy-tests") == 0) {
|
|
|
|
ctx->proxy_tests = 1;
|
|
|
|
}
|
|
|
|
else if (strcmp(argv[i], "--no-proxy") == 0) {
|
|
|
|
o_iproxy = 0;
|
|
|
|
}
|
|
|
|
else if (strcmp(argv[i], "--no-nat") == 0) {
|
|
|
|
o_inat = 0;
|
|
|
|
}
|
|
|
|
else if (strcmp(argv[i], "--nat") == 0) {
|
|
|
|
o_inat = 1;
|
|
|
|
}
|
|
|
|
else if (strcmp(argv[i], "--symmetric") == 0) {
|
|
|
|
o_inat_symmetric = 1;
|
|
|
|
}
|
|
|
|
else if (strcmp(argv[i], "-N") == 0) {
|
|
|
|
o_inat_logging = 1;
|
|
|
|
}
|
|
|
|
else if (strcmp(argv[i], "--expensive") == 0) {
|
|
|
|
o_expensive = 1;
|
|
|
|
}
|
|
|
|
else if (strcmp(argv[i], "--no-alarm") == 0) {
|
|
|
|
o_alarm = 0;
|
|
|
|
}
|
2007-04-15 02:03:41 +00:00
|
|
|
else if (strcmp(argv[i], "--loop") == 0) {
|
|
|
|
o_alarm = 0, o_loop = 1;
|
|
|
|
}
|
Update sofia-sip from darcs:
Mon May 14 12:43:07 EDT 2007 martti.mela@nokia.com
* su_base_port.c: fixed a double free in su_base_port_start_shared().
Fri May 25 13:56:23 EDT 2007 Pekka.Pessi@nokia.com
* soa: added SOATAG_ORDERED_USER(), SOATAG_REUSE_REJECTED().
Allow replacing existing m=lines.
Sun May 27 14:52:13 EDT 2007 Pekka.Pessi@nokia.com
* msg_parser.c: fixed bug #1726034
Mon May 28 04:57:08 EDT 2007 Pekka.Pessi@nokia.com
* test_nth.c: using non-blocking connect in test program, too.
Mon May 28 04:58:05 EDT 2007 Pekka.Pessi@nokia.com
* su.c: making all sockets non-blocking by default.
Mon May 28 04:59:28 EDT 2007 Pekka.Pessi@nokia.com
* m4/sac-su.m4: moved contents into sac-s2.m4
Mon May 28 05:32:26 EDT 2007 Pekka.Pessi@nokia.com
* RELEASE: updated.
Wed May 30 10:37:53 EDT 2007 Pekka.Pessi@nokia.com
* m4/sac-su2.m4: added configure option --disable-tag-cast.
Added SU_INLINE_TAG_CAST into sofia-sip/su_configure.h{,.in}.
Using SU_INLINE_TAG_CAST in
sofia-sip/sip_tag.h{,.in}
sofia-sip/http_tag.h{,.in}
sofia-sip/su_tag.h
sofia-sip/su_tag_io.h
sofia-sip/auth_module.h
sofia-sip/nth_tag.h
sofia-sip/nua_tag.h
Fri Jun 1 15:11:52 EDT 2007 Pekka.Pessi@nokia.com
* tport.c: fixed tport_set_params() with secondary transports
Fri Jun 1 15:13:23 EDT 2007 Pekka.Pessi@nokia.com
* tport_type_tcp.c: checking for end-of-stream even if su_getmsgsize() promised more data
Fri Jun 1 15:15:34 EDT 2007 Pekka.Pessi@nokia.com
* tport: added tport_is_clear_to_send(), allow use of tport_pending() without msg
The error callback from tport can now be registered even if there is no
request pending on transport (e.g., when keeping a transport connection open
for inbound messages).
Fri Jun 1 15:16:43 EDT 2007 Pekka.Pessi@nokia.com
* nta: not retrying after an transport error if application provided the transport
Fri Jun 1 15:17:23 EDT 2007 Pekka.Pessi@nokia.com
* sip: do not accept empty URIs (<>) in From, To, and other headers expecting name-addr format
Fri Jun 1 15:17:43 EDT 2007 Pekka.Pessi@nokia.com
* torture_url.c: added test for parsing empty URLs.
Fri Jun 1 15:19:27 EDT 2007 Pekka.Pessi@nokia.com
* nua/test_proxy.[hc]: use registered connections for outbound with TCP.
Added test_proxy_close_tports() used testing recovering from TCP failures.
Fri Jun 1 15:20:33 EDT 2007 Pekka.Pessi@nokia.com
* test_nua.c: added --print-tags and --tags-a, --tags=b and --tags=c options
Added more functions for handling events
Fri Jun 1 15:22:08 EDT 2007 Pekka.Pessi@nokia.com
* test_nua: fixed some tests depending on delivery of responses in correct order
Reordering might happen if some messages are sent over TCP, other over UDP.
Fri Jun 1 15:27:55 EDT 2007 Pekka.Pessi@nokia.com
* nua_register.c: re-registering in case the TCP connection towards proxy is closed
In test_nua, Mr. B is now using TCP with the test proxy.
Fri Jun 1 15:35:39 EDT 2007 Pekka.Pessi@nokia.com
* nua/test_refer.c: fixed SIP payload checks
Fri Jun 1 15:36:08 EDT 2007 Pekka.Pessi@nokia.com
* nta_internal.h: added orq_user_tport field
Tue Jun 5 06:16:43 EDT 2007 Pekka.Pessi@nokia.com
* hide_email.sh: now fixing links, too.
Fri Jun 15 05:34:29 EDT 2007 Pekka.Pessi@nokia.com
* nua: fixed documentation entries for API functions left out from doxygen
Thanks for Jerry Ricahrds for pointing this out.
Wed May 23 10:26:26 EDT 2007 Mikhail Zabaluev <mikhail.zabaluev@nokia.com>
* Correct documentation for parameter type of NUTAG_WITH_SAVED
Mon Jun 18 12:34:58 EDT 2007 Mikhail Zabaluev <mikhail.zabaluev@nokia.com>
* Make nua_saved_event_request() and hence NUTAG_WITH_SAVED resilient to a NULL event content
git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@5413 d0543943-73ff-0310-b7d9-9358b9ac24b2
2007-06-20 10:41:15 +00:00
|
|
|
else if (strcmp(argv[i], "--print-tags") == 0) {
|
|
|
|
ctx->print_tags = 1;
|
|
|
|
}
|
|
|
|
else if (strcmp(argv[i], "--tags=a") == 0) {
|
|
|
|
ctx->a.print_tags = 1;
|
|
|
|
}
|
|
|
|
else if (strcmp(argv[i], "--tags=b") == 0) {
|
|
|
|
ctx->b.print_tags = 1;
|
|
|
|
}
|
|
|
|
else if (strcmp(argv[i], "--tags=c") == 0) {
|
|
|
|
ctx->c.print_tags = 1;
|
|
|
|
}
|
2007-04-15 02:03:41 +00:00
|
|
|
else if (strcmp(argv[i], "--log=a") == 0) {
|
|
|
|
ctx->a.logging = 1;
|
|
|
|
}
|
|
|
|
else if (strcmp(argv[i], "--log=b") == 0) {
|
|
|
|
ctx->b.logging = 1;
|
|
|
|
}
|
|
|
|
else if (strcmp(argv[i], "--log=c") == 0) {
|
|
|
|
ctx->c.logging = 1;
|
|
|
|
}
|
|
|
|
else if (strcmp(argv[i], "--log=proxy") == 0) {
|
|
|
|
ctx->proxy_logging = 1;
|
|
|
|
}
|
2006-12-21 06:30:28 +00:00
|
|
|
#if SU_HAVE_OSX_CF_API /* If compiled with CoreFoundation events */
|
|
|
|
else if (strcmp(argv[i], "--osx-runloop") == 0) {
|
|
|
|
ctx->osx_runloop = 1;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
else if (strcmp(argv[i], "-") == 0) {
|
|
|
|
i++; break;
|
|
|
|
}
|
|
|
|
else if (argv[i][0] != '-') {
|
|
|
|
break;
|
|
|
|
}
|
2007-04-15 02:03:41 +00:00
|
|
|
else {
|
|
|
|
fprintf(stderr, "test_nua: unknown argument \"%s\"\n\n", argv[i]);
|
2006-12-21 06:30:28 +00:00
|
|
|
usage(1);
|
2007-04-15 02:03:41 +00:00
|
|
|
}
|
2006-12-21 06:30:28 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if (o_attach) {
|
|
|
|
char line[10], *l;
|
|
|
|
printf("%s: pid %lu\n", name, (unsigned long)getpid());
|
|
|
|
printf("<Press RETURN to continue>\n");
|
|
|
|
l = fgets(line, sizeof line, stdin);
|
|
|
|
}
|
|
|
|
#if HAVE_ALARM
|
|
|
|
else if (o_alarm) {
|
|
|
|
signal(SIGALRM, sig_alarm);
|
2007-04-15 02:03:41 +00:00
|
|
|
if (o_expensive) {
|
|
|
|
printf("%s: extending timeout to %u because expensive tests\n",
|
|
|
|
name, 240);
|
|
|
|
alarm(240);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
alarm(120);
|
|
|
|
}
|
2006-12-21 06:30:28 +00:00
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2007-08-06 19:24:10 +00:00
|
|
|
#if HAVE_OPEN_C
|
|
|
|
tstflags |= tst_verbatim;
|
|
|
|
level = 9;
|
|
|
|
o_inat = 1; /* No NATs */
|
|
|
|
ctx->threading = 1;
|
|
|
|
ctx->quit_on_single_failure = 1;
|
|
|
|
su_log_soft_set_level(nua_log, level);
|
|
|
|
su_log_soft_set_level(soa_log, level);
|
|
|
|
su_log_soft_set_level(su_log_default, level);
|
|
|
|
su_log_soft_set_level(nea_log, level);
|
|
|
|
su_log_soft_set_level(nta_log, level);
|
|
|
|
su_log_soft_set_level(tport_log, level);
|
|
|
|
setenv("SU_DEBUG", "9", 1);
|
|
|
|
setenv("NUA_DEBUG", "9", 1);
|
|
|
|
setenv("NTA_DEBUG", "9", 1);
|
|
|
|
setenv("TPORT_DEBUG", "9", 1);
|
|
|
|
o_events_a = o_events_b = 1;
|
|
|
|
#endif
|
|
|
|
|
2006-12-21 06:30:28 +00:00
|
|
|
su_init();
|
|
|
|
|
|
|
|
if (!(TSTFLAGS & tst_verbatim)) {
|
|
|
|
if (level == 0 && !o_quiet)
|
|
|
|
level = 1;
|
|
|
|
su_log_soft_set_level(nua_log, level);
|
|
|
|
su_log_soft_set_level(soa_log, level);
|
2007-08-06 19:24:10 +00:00
|
|
|
su_log_soft_set_level(su_log_default, level);
|
2006-12-21 06:30:28 +00:00
|
|
|
su_log_soft_set_level(nea_log, level);
|
|
|
|
su_log_soft_set_level(nta_log, level);
|
|
|
|
su_log_soft_set_level(tport_log, level);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!o_quiet || (TSTFLAGS & tst_verbatim)
|
|
|
|
|| o_events_a || o_events_b || o_events_c)
|
|
|
|
print_headings = 1;
|
|
|
|
|
2007-08-06 19:24:10 +00:00
|
|
|
#if !HAVE_OPEN_C
|
2006-12-21 06:30:28 +00:00
|
|
|
#define SINGLE_FAILURE_CHECK() \
|
|
|
|
do { fflush(stdout); \
|
|
|
|
if (retval && ctx->quit_on_single_failure) { \
|
|
|
|
su_deinit(); return retval; } \
|
|
|
|
} while(0)
|
2007-08-06 19:24:10 +00:00
|
|
|
#else
|
|
|
|
#define SINGLE_FAILURE_CHECK() \
|
|
|
|
do { fflush(stdout); \
|
|
|
|
if (retval && ctx->quit_on_single_failure) { \
|
|
|
|
su_deinit(); sleep(10); return retval; } \
|
|
|
|
} while(0)
|
|
|
|
#endif
|
2006-12-21 06:30:28 +00:00
|
|
|
|
|
|
|
ctx->a.printer = o_events_init ? print_event : NULL;
|
|
|
|
|
2007-08-06 19:24:10 +00:00
|
|
|
sleep(2);
|
|
|
|
|
2006-12-21 06:30:28 +00:00
|
|
|
retval |= test_nua_api_errors(ctx); SINGLE_FAILURE_CHECK();
|
2007-08-06 19:24:10 +00:00
|
|
|
|
2006-12-21 06:30:28 +00:00
|
|
|
retval |= test_tag_filter(); SINGLE_FAILURE_CHECK();
|
2007-08-06 19:24:10 +00:00
|
|
|
|
2006-12-21 06:30:28 +00:00
|
|
|
retval |= test_nua_params(ctx); SINGLE_FAILURE_CHECK();
|
|
|
|
|
|
|
|
retval |= test_nua_init(ctx, o_iproxy, o_proxy, o_inat,
|
|
|
|
TESTNATTAG_SYMMETRIC(o_inat_symmetric),
|
|
|
|
TESTNATTAG_LOGGING(o_inat_logging),
|
|
|
|
TAG_END());
|
|
|
|
|
|
|
|
ctx->expensive = o_expensive;
|
|
|
|
|
|
|
|
if (retval == 0) {
|
|
|
|
ctx->a.printer = o_events_a ? print_event : NULL;
|
|
|
|
if (o_events_b)
|
|
|
|
ctx->b.printer = print_event;
|
|
|
|
if (o_events_c)
|
|
|
|
ctx->c.printer = print_event;
|
|
|
|
|
|
|
|
retval |= test_stack_errors(ctx); SINGLE_FAILURE_CHECK();
|
|
|
|
|
|
|
|
retval |= test_register(ctx);
|
|
|
|
|
|
|
|
if (retval == 0)
|
|
|
|
retval |= test_connectivity(ctx);
|
|
|
|
|
|
|
|
if (retval == 0 && o_inat)
|
|
|
|
retval |= test_nat_timeout(ctx);
|
|
|
|
|
2007-04-15 02:03:41 +00:00
|
|
|
while (retval == 0) {
|
2006-12-21 06:30:28 +00:00
|
|
|
retval |= test_basic_call(ctx); SINGLE_FAILURE_CHECK();
|
2007-04-15 02:03:41 +00:00
|
|
|
retval |= test_rejects(ctx); SINGLE_FAILURE_CHECK();
|
2006-12-21 06:30:28 +00:00
|
|
|
retval |= test_call_cancel(ctx); SINGLE_FAILURE_CHECK();
|
|
|
|
retval |= test_call_destroy(ctx); SINGLE_FAILURE_CHECK();
|
|
|
|
retval |= test_early_bye(ctx); SINGLE_FAILURE_CHECK();
|
Update sofia-sip from darcs:
Mon May 14 12:43:07 EDT 2007 martti.mela@nokia.com
* su_base_port.c: fixed a double free in su_base_port_start_shared().
Fri May 25 13:56:23 EDT 2007 Pekka.Pessi@nokia.com
* soa: added SOATAG_ORDERED_USER(), SOATAG_REUSE_REJECTED().
Allow replacing existing m=lines.
Sun May 27 14:52:13 EDT 2007 Pekka.Pessi@nokia.com
* msg_parser.c: fixed bug #1726034
Mon May 28 04:57:08 EDT 2007 Pekka.Pessi@nokia.com
* test_nth.c: using non-blocking connect in test program, too.
Mon May 28 04:58:05 EDT 2007 Pekka.Pessi@nokia.com
* su.c: making all sockets non-blocking by default.
Mon May 28 04:59:28 EDT 2007 Pekka.Pessi@nokia.com
* m4/sac-su.m4: moved contents into sac-s2.m4
Mon May 28 05:32:26 EDT 2007 Pekka.Pessi@nokia.com
* RELEASE: updated.
Wed May 30 10:37:53 EDT 2007 Pekka.Pessi@nokia.com
* m4/sac-su2.m4: added configure option --disable-tag-cast.
Added SU_INLINE_TAG_CAST into sofia-sip/su_configure.h{,.in}.
Using SU_INLINE_TAG_CAST in
sofia-sip/sip_tag.h{,.in}
sofia-sip/http_tag.h{,.in}
sofia-sip/su_tag.h
sofia-sip/su_tag_io.h
sofia-sip/auth_module.h
sofia-sip/nth_tag.h
sofia-sip/nua_tag.h
Fri Jun 1 15:11:52 EDT 2007 Pekka.Pessi@nokia.com
* tport.c: fixed tport_set_params() with secondary transports
Fri Jun 1 15:13:23 EDT 2007 Pekka.Pessi@nokia.com
* tport_type_tcp.c: checking for end-of-stream even if su_getmsgsize() promised more data
Fri Jun 1 15:15:34 EDT 2007 Pekka.Pessi@nokia.com
* tport: added tport_is_clear_to_send(), allow use of tport_pending() without msg
The error callback from tport can now be registered even if there is no
request pending on transport (e.g., when keeping a transport connection open
for inbound messages).
Fri Jun 1 15:16:43 EDT 2007 Pekka.Pessi@nokia.com
* nta: not retrying after an transport error if application provided the transport
Fri Jun 1 15:17:23 EDT 2007 Pekka.Pessi@nokia.com
* sip: do not accept empty URIs (<>) in From, To, and other headers expecting name-addr format
Fri Jun 1 15:17:43 EDT 2007 Pekka.Pessi@nokia.com
* torture_url.c: added test for parsing empty URLs.
Fri Jun 1 15:19:27 EDT 2007 Pekka.Pessi@nokia.com
* nua/test_proxy.[hc]: use registered connections for outbound with TCP.
Added test_proxy_close_tports() used testing recovering from TCP failures.
Fri Jun 1 15:20:33 EDT 2007 Pekka.Pessi@nokia.com
* test_nua.c: added --print-tags and --tags-a, --tags=b and --tags=c options
Added more functions for handling events
Fri Jun 1 15:22:08 EDT 2007 Pekka.Pessi@nokia.com
* test_nua: fixed some tests depending on delivery of responses in correct order
Reordering might happen if some messages are sent over TCP, other over UDP.
Fri Jun 1 15:27:55 EDT 2007 Pekka.Pessi@nokia.com
* nua_register.c: re-registering in case the TCP connection towards proxy is closed
In test_nua, Mr. B is now using TCP with the test proxy.
Fri Jun 1 15:35:39 EDT 2007 Pekka.Pessi@nokia.com
* nua/test_refer.c: fixed SIP payload checks
Fri Jun 1 15:36:08 EDT 2007 Pekka.Pessi@nokia.com
* nta_internal.h: added orq_user_tport field
Tue Jun 5 06:16:43 EDT 2007 Pekka.Pessi@nokia.com
* hide_email.sh: now fixing links, too.
Fri Jun 15 05:34:29 EDT 2007 Pekka.Pessi@nokia.com
* nua: fixed documentation entries for API functions left out from doxygen
Thanks for Jerry Ricahrds for pointing this out.
Wed May 23 10:26:26 EDT 2007 Mikhail Zabaluev <mikhail.zabaluev@nokia.com>
* Correct documentation for parameter type of NUTAG_WITH_SAVED
Mon Jun 18 12:34:58 EDT 2007 Mikhail Zabaluev <mikhail.zabaluev@nokia.com>
* Make nua_saved_event_request() and hence NUTAG_WITH_SAVED resilient to a NULL event content
git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@5413 d0543943-73ff-0310-b7d9-9358b9ac24b2
2007-06-20 10:41:15 +00:00
|
|
|
retval |= test_offer_answer(ctx); SINGLE_FAILURE_CHECK();
|
2006-12-21 06:30:28 +00:00
|
|
|
retval |= test_reinvites(ctx); SINGLE_FAILURE_CHECK();
|
|
|
|
retval |= test_session_timer(ctx); SINGLE_FAILURE_CHECK();
|
|
|
|
retval |= test_refer(ctx); SINGLE_FAILURE_CHECK();
|
|
|
|
retval |= test_100rel(ctx); SINGLE_FAILURE_CHECK();
|
2007-02-07 21:59:38 +00:00
|
|
|
retval |= test_simple(ctx); SINGLE_FAILURE_CHECK();
|
2007-02-17 06:25:21 +00:00
|
|
|
retval |= test_events(ctx); SINGLE_FAILURE_CHECK();
|
2007-04-15 02:03:41 +00:00
|
|
|
retval |= test_extension(ctx); SINGLE_FAILURE_CHECK();
|
|
|
|
if (!o_loop)
|
|
|
|
break;
|
2006-12-21 06:30:28 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if (ctx->proxy_tests && (retval == 0 || !ctx->p))
|
|
|
|
retval |= test_unregister(ctx); SINGLE_FAILURE_CHECK();
|
|
|
|
}
|
|
|
|
retval |= test_deinit(ctx);
|
|
|
|
|
|
|
|
su_home_deinit(ctx->home);
|
|
|
|
|
|
|
|
su_deinit();
|
|
|
|
|
2007-08-06 19:24:10 +00:00
|
|
|
#if HAVE_OPEN_C
|
|
|
|
sleep(7);
|
|
|
|
#endif
|
|
|
|
|
2006-12-21 06:30:28 +00:00
|
|
|
return retval;
|
|
|
|
}
|