📄 test.c
字号:
/* $Id: test.c 1158 2007-04-06 10:25:23Z bennylp $ *//* * Copyright (C) 2003-2007 Benny Prijono <benny@prijono.org> * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program 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 General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */#include "test.h"#include <pjlib.h>#include <pjlib-util.h>#include <pjsip.h>#define THIS_FILE "test.c"#define DO_TEST(test) do { \ PJ_LOG(3, (THIS_FILE, "Running %s...", #test)); \ rc = test; \ PJ_LOG(3, (THIS_FILE, \ "%s(%d)", \ (rc ? "..ERROR" : "..success"), rc)); \ if (rc!=0) goto on_return; \ } while (0)#define DO_TSX_TEST(test, param) \ do { \ PJ_LOG(3, (THIS_FILE, "Running %s(%s)...", #test, (param)->tp_type)); \ rc = test(param); \ PJ_LOG(3, (THIS_FILE, \ "%s(%d)", \ (rc ? "..ERROR" : "..success"), rc)); \ if (rc!=0) goto on_return; \ } while (0)pjsip_endpoint *endpt;int log_level = 3;static pj_oshandle_t fd_report;const char *system_name = "Unknown";static char buf[1024];void app_perror(const char *msg, pj_status_t rc){ char errbuf[256]; PJ_CHECK_STACK(); pj_strerror(rc, errbuf, sizeof(errbuf)); PJ_LOG(3,(THIS_FILE, "%s: [pj_status_t=%d] %s", msg, rc, errbuf));}void flush_events(unsigned duration){ pj_time_val stop_time; pj_gettimeofday(&stop_time); stop_time.msec += duration; pj_time_val_normalize(&stop_time); /* Process all events for the specified duration. */ for (;;) { pj_time_val timeout = {0, 1}, now; pjsip_endpt_handle_events(endpt, &timeout); pj_gettimeofday(&now); if (PJ_TIME_VAL_GTE(now, stop_time)) break; }}pj_status_t register_static_modules(pj_size_t *count, pjsip_module **modules){ *count = 0; return PJ_SUCCESS;}static pj_status_t init_report(void){ char tmp[80]; pj_time_val timestamp; pj_parsed_time date_time; pj_ssize_t len; pj_status_t status; pj_ansi_sprintf(tmp, "pjsip-static-bench-%s-%s.htm", PJ_OS_NAME, PJ_CC_NAME); status = pj_file_open(NULL, tmp, PJ_O_WRONLY, &fd_report); if (status != PJ_SUCCESS) return status; /* Title */ len = pj_ansi_sprintf(buf, "<HTML>\n" " <HEAD>\n" " <TITLE>PJSIP %s (%s) - Static Benchmark</TITLE>\n" " </HEAD>\n" "<BODY>\n" "\n", PJ_VERSION, (PJ_DEBUG ? "Debug" : "Release")); pj_file_write(fd_report, buf, &len); /* Title */ len = pj_ansi_sprintf(buf, "<H1>PJSIP %s (%s) - Static Benchmark</H1>\n", PJ_VERSION, (PJ_DEBUG ? "Debug" : "Release")); pj_file_write(fd_report, buf, &len); len = pj_ansi_sprintf(buf, "<P>Below is the benchmark result generated " "by <b>test-pjsip</b> program. The program " "is single-threaded only.</P>\n"); pj_file_write(fd_report, buf, &len); /* Write table heading */ len = pj_ansi_sprintf(buf, "<TABLE border=\"1\" cellpadding=\"4\">\n" " <TR><TD bgColor=\"aqua\" align=\"center\">Variable</TD>\n" " <TD bgColor=\"aqua\" align=\"center\">Value</TD>\n" " <TD bgColor=\"aqua\" align=\"center\">Description</TD>\n" " </TR>\n"); pj_file_write(fd_report, buf, &len); /* Write version */ report_sval("version", PJ_VERSION, "", "PJLIB/PJSIP version"); /* Debug or release */ report_sval("build-type", (PJ_DEBUG ? "Debug" : "Release"), "", "Build type"); /* Write timestamp */ pj_gettimeofday(×tamp); report_ival("timestamp", timestamp.sec, "", "System timestamp of the test"); /* Write time of day */ pj_time_decode(×tamp, &date_time); len = pj_ansi_sprintf(tmp, "%04d-%02d-%02d %02d:%02d:%02d", date_time.year, date_time.mon+1, date_time.day, date_time.hour, date_time.min, date_time.sec); report_sval("date-time", tmp, "", "Date/time of the test"); /* Write System */ report_sval("system", system_name, "", "System description"); /* Write OS type */ report_sval("os-family", PJ_OS_NAME, "", "Operating system family"); /* Write CC name */ len = pj_ansi_sprintf(tmp, "%s-%d.%d.%d", PJ_CC_NAME, PJ_CC_VER_1, PJ_CC_VER_2, PJ_CC_VER_2); report_sval("cc-name", tmp, "", "Compiler name and version"); return PJ_SUCCESS;}void report_sval(const char *name, const char* value, const char *valname, const char *desc){ pj_ssize_t len; len = pj_ansi_sprintf(buf, " <TR><TD><TT>%s</TT></TD>\n" " <TD align=\"right\"><B>%s %s</B></TD>\n" " <TD>%s</TD>\n" " </TR>\n", name, value, valname, desc); pj_file_write(fd_report, buf, &len);}void report_ival(const char *name, int value, const char *valname, const char *desc){ pj_ssize_t len; len = pj_ansi_sprintf(buf, " <TR><TD><TT>%s</TT></TD>\n" " <TD align=\"right\"><B>%d %s</B></TD>\n" " <TD>%s</TD>\n" " </TR>\n", name, value, valname, desc); pj_file_write(fd_report, buf, &len);}static void close_report(void){ pj_ssize_t len; if (fd_report) { len = pj_ansi_sprintf(buf, "</TABLE>\n</BODY>\n</HTML>\n"); pj_file_write(fd_report, buf, &len); pj_file_close(fd_report); }}int test_main(void){ pj_status_t rc; pj_caching_pool caching_pool; const char *filename; unsigned tsx_test_cnt=0; struct tsx_test_param tsx_test[10]; pj_status_t status;#if INCLUDE_TSX_TEST unsigned i; pjsip_transport *tp;#if PJ_HAS_TCP pjsip_tpfactory *tpfactory;#endif /* PJ_HAS_TCP */#endif /* INCLUDE_TSX_TEST */ int line; pj_log_set_level(log_level); /* pj_log_set_decor(PJ_LOG_HAS_NEWLINE | PJ_LOG_HAS_TIME | PJ_LOG_HAS_MICRO_SEC); */ if ((rc=pj_init()) != PJ_SUCCESS) { app_perror("pj_init", rc); return rc; } if ((rc=pjlib_util_init()) != PJ_SUCCESS) { app_perror("pj_init", rc); return rc; } status = init_report(); if (status != PJ_SUCCESS) return status; pj_dump_config(); pj_caching_pool_init( &caching_pool, &pj_pool_factory_default_policy, PJSIP_TEST_MEM_SIZE ); rc = pjsip_endpt_create(&caching_pool.factory, "endpt", &endpt); if (rc != PJ_SUCCESS) { app_perror("pjsip_endpt_create", rc); pj_caching_pool_destroy(&caching_pool); return rc; } PJ_LOG(3,(THIS_FILE,"")); /* Init logger module. */ init_msg_logger(); msg_logger_set_enabled(1); /* Start transaction layer module. */ rc = pjsip_tsx_layer_init_module(endpt); if (rc != PJ_SUCCESS) { app_perror(" Error initializing transaction module", rc); goto on_return; } /* Create loop transport. */ rc = pjsip_loop_start(endpt, NULL); if (rc != PJ_SUCCESS) { app_perror(" error: unable to create datagram loop transport", rc); goto on_return; } tsx_test[tsx_test_cnt].port = 5060; tsx_test[tsx_test_cnt].tp_type = "loop-dgram"; tsx_test[tsx_test_cnt].type = PJSIP_TRANSPORT_LOOP_DGRAM; ++tsx_test_cnt;#if INCLUDE_URI_TEST DO_TEST(uri_test());#endif#if INCLUDE_MSG_TEST DO_TEST(msg_test()); DO_TEST(msg_err_test());#endif#if INCLUDE_TXDATA_TEST DO_TEST(txdata_test());#endif#if INCLUDE_TSX_BENCH DO_TEST(tsx_bench());#endif#if INCLUDE_UDP_TEST DO_TEST(transport_udp_test());#endif#if INCLUDE_LOOP_TEST DO_TEST(transport_loop_test());#endif#if INCLUDE_TCP_TEST DO_TEST(transport_tcp_test());#endif#if INCLUDE_RESOLVE_TEST DO_TEST(resolve_test());#endif#if INCLUDE_TSX_TEST status = pjsip_udp_transport_start(endpt, NULL, NULL, 1, &tp); if (status == PJ_SUCCESS) { tsx_test[tsx_test_cnt].port = tp->local_name.port; tsx_test[tsx_test_cnt].tp_type = "udp"; tsx_test[tsx_test_cnt].type = PJSIP_TRANSPORT_UDP; ++tsx_test_cnt; }#if PJ_HAS_TCP status = pjsip_tcp_transport_start(endpt, NULL, 1, &tpfactory); if (status == PJ_SUCCESS) { tsx_test[tsx_test_cnt].port = tpfactory->addr_name.port; tsx_test[tsx_test_cnt].tp_type = "tcp"; tsx_test[tsx_test_cnt].type = PJSIP_TRANSPORT_TCP; ++tsx_test_cnt; } else { app_perror("Unable to create TCP", status); rc = -4; goto on_return; }#endif for (i=0; i<tsx_test_cnt; ++i) { DO_TSX_TEST(tsx_basic_test, &tsx_test[i]); DO_TSX_TEST(tsx_uac_test, &tsx_test[i]); DO_TSX_TEST(tsx_uas_test, &tsx_test[i]); }#endifon_return: flush_events(500); /* Dumping memory pool usage */ PJ_LOG(3,(THIS_FILE, "Peak memory size=%u MB", caching_pool.peak_used_size / 1000000)); pjsip_endpt_destroy(endpt); pj_caching_pool_destroy(&caching_pool); PJ_LOG(3,(THIS_FILE, "")); pj_thread_get_stack_info(pj_thread_this(), &filename, &line); PJ_LOG(3,(THIS_FILE, "Stack max usage: %u, deepest: %s:%u", pj_thread_get_stack_max_usage(pj_thread_this()), filename, line)); if (rc == 0) PJ_LOG(3,(THIS_FILE, "Looks like everything is okay!..")); else PJ_LOG(3,(THIS_FILE, "Test completed with error(s)")); report_ival("test-status", rc, "", "Overall test status/result (0==success)"); close_report(); return rc;}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -