📄 test_nua.c
字号:
TEST_S(sip_header_as_string(tmphome, (void *)from), Alice); TEST_S(from_str, Alice); TEST(retry_count, 5); TEST(max_subscriptions, 6); TEST(invite_enable, 0); TEST(auto_alert, 1); TEST(early_media, 1); TEST(auto_answer, 1); TEST(auto_ack, 0); TEST(invite_timeout, 60); TEST(session_timer, 600); TEST(min_se, 35); TEST(refresher, nua_remote_refresher); TEST(update_refresh, 1); TEST(message_enable, 0); TEST(win_messenger_enable, 1); TEST(message_auto_respond, -1); /* XXX */ TEST(callee_caps, 1); TEST(media_features, 1); TEST(service_route_enable, 0); TEST(path_enable, 0); TEST(substate, nua_substate_pending); TEST_S(sip_header_as_string(tmphome, (void *)allow), "OPTIONS, INFO"); TEST_S(allow_str, "OPTIONS, INFO"); TEST_S(sip_header_as_string(tmphome, (void *)supported), "humppaa, kuole"); TEST_S(supported_str, "humppaa, kuole"); TEST_S(sip_header_as_string(tmphome, (void *)user_agent), "test_nua"); TEST_S(user_agent_str, "test_nua"); TEST_S(sip_header_as_string(tmphome, (void *)organization), "Pussy Galore's Flying Circus"); TEST_S(organization_str, "Pussy Galore's Flying Circus"); TEST(keepalive, 66); TEST(keepalive_stream, 33); TEST_S(outbound, "foo"); TEST_S(instance, "urn:uuid:97701ad9-39df-1229-1083-dbc0a85f029c"); TEST_S(url_as_string(tmphome, registrar->us_url), "sip:sip.wonderland.org"); free_events_in_list(ctx, ctx->a.events); } /* Test that only those tags that have been set per handle are returned by nua_get_hparams() */ { sip_from_t const *from = NONE; char const *from_str = "NONE"; unsigned retry_count = -1; unsigned max_subscriptions = -1; int invite_enable = -1; int auto_alert = -1; int early_media = -1; int auto_answer = -1; int auto_ack = -1; unsigned invite_timeout = -1; unsigned session_timer = -1; unsigned min_se = -1; int refresher = -1; int update_refresh = -1; int message_enable = -1; int win_messenger_enable = -1; int message_auto_respond = -1; int callee_caps = -1; int media_features = -1; int service_route_enable = -1; int path_enable = -1; int substate = -1; sip_allow_t const *allow = NONE; char const *allow_str = "NONE"; sip_supported_t const *supported = NONE; char const *supported_str = "NONE"; sip_user_agent_t const *user_agent = NONE; char const *user_agent_str = "NONE"; sip_organization_t const *organization = NONE; char const *organization_str = "NONE"; url_string_t const *registrar = NONE; int n; struct event *e; nua_get_hparams(nh, TAG_ANY(), TAG_END()); run_a_until(ctx, nua_r_get_params, save_until_final_response); TEST_1(e = ctx->a.events->head); TEST_E(e->data->e_event, nua_r_get_params); n = tl_gets(e->data->e_tags, SIPTAG_FROM_REF(from), SIPTAG_FROM_STR_REF(from_str), NUTAG_RETRY_COUNT_REF(retry_count), NUTAG_MAX_SUBSCRIPTIONS_REF(max_subscriptions), NUTAG_ENABLEINVITE_REF(invite_enable), NUTAG_AUTOALERT_REF(auto_alert), NUTAG_EARLY_MEDIA_REF(early_media), NUTAG_AUTOANSWER_REF(auto_answer), NUTAG_AUTOACK_REF(auto_ack), NUTAG_INVITE_TIMER_REF(invite_timeout), NUTAG_SESSION_TIMER_REF(session_timer), NUTAG_MIN_SE_REF(min_se), NUTAG_SESSION_REFRESHER_REF(refresher), NUTAG_UPDATE_REFRESH_REF(update_refresh), NUTAG_ENABLEMESSAGE_REF(message_enable), NUTAG_ENABLEMESSENGER_REF(win_messenger_enable), /* NUTAG_MESSAGE_AUTOANSWER(message_auto_respond), */ NUTAG_CALLEE_CAPS_REF(callee_caps), NUTAG_MEDIA_FEATURES_REF(media_features), NUTAG_SERVICE_ROUTE_ENABLE_REF(service_route_enable), NUTAG_PATH_ENABLE_REF(path_enable), NUTAG_SUBSTATE_REF(substate), SIPTAG_SUPPORTED_REF(supported), SIPTAG_SUPPORTED_STR_REF(supported_str), SIPTAG_ALLOW_REF(allow), SIPTAG_ALLOW_STR_REF(allow_str), SIPTAG_USER_AGENT_REF(user_agent), SIPTAG_USER_AGENT_STR_REF(user_agent_str), SIPTAG_ORGANIZATION_REF(organization), SIPTAG_ORGANIZATION_STR_REF(organization_str), NUTAG_REGISTRAR_REF(registrar), TAG_END()); TEST(n, 3); TEST(invite_timeout, 90); TEST_1(from != NULL && from != NONE); TEST_1(strcmp(from_str, "NONE")); /* Nothing else should be set */ TEST(retry_count, (unsigned)-1); TEST(max_subscriptions, (unsigned)-1); TEST(invite_enable, -1); TEST(auto_alert, -1); TEST(early_media, -1); TEST(auto_answer, -1); TEST(auto_ack, -1); TEST(session_timer, (unsigned)-1); TEST(min_se, (unsigned)-1); TEST(refresher, -1); TEST(update_refresh, -1); TEST(message_enable, -1); TEST(win_messenger_enable, -1); TEST(message_auto_respond, -1); /* XXX */ TEST(callee_caps, -1); TEST(media_features, -1); TEST(service_route_enable, -1); TEST(path_enable, -1); TEST(substate, -1); TEST(allow, NONE); TEST_S(allow_str, "NONE"); TEST(supported, NONE); TEST_S(supported_str, "NONE"); TEST(user_agent, NONE); TEST_S(user_agent_str, "NONE"); TEST(organization, NONE); TEST_S(organization_str, "NONE"); TEST(registrar->us_url, NONE); free_events_in_list(ctx, ctx->a.events); } nua_handle_destroy(nh); nua_shutdown(ctx->a.nua); run_a_until(ctx, nua_r_shutdown, until_final_response); nua_destroy(ctx->a.nua), ctx->a.nua = NULL; su_root_destroy(ctx->root), ctx->root = NULL; su_home_deinit(tmphome); if (print_headings) printf("TEST NUA-1.1: PASSED\n"); END();}/* ======================================================================== */int test_stack_errors(struct context *ctx){ BEGIN(); struct endpoint *a = &ctx->a, *b = &ctx->b; struct call *a_call = a->call; struct event *e; int internal_error = 900; if (print_headings) printf("TEST NUA-1.2: Stack error handling\n"); if (print_headings) printf("TEST NUA-1.2.1: CANCEL without INVITE\n"); TEST_1(a_call->nh = nua_handle(a->nua, a_call, SIPTAG_TO(b->to), TAG_END())); CANCEL(a, a_call, a_call->nh, TAG_END()); run_a_until(ctx, -1, save_until_final_response); TEST_1(e = a->events->head); TEST_E(e->data->e_event, nua_r_cancel); TEST(e->data->e_status, 481); TEST_1(!e->next); free_events_in_list(ctx, a->events); nua_handle_destroy(a_call->nh), a_call->nh = NULL; if (print_headings) printf("TEST NUA-1.2.1: PASSED\n"); /* -BYE without INVITE--------------------------------------------------- */ if (print_headings) printf("TEST NUA-1.2.2: BYE without INVITE\n"); TEST_1(a_call->nh = nua_handle(a->nua, a_call, SIPTAG_TO(b->to), TAG_END())); BYE(a, a_call, a_call->nh, TAG_END()); run_a_until(ctx, -1, save_until_final_response); TEST_1(e = a->events->head); TEST_E(e->data->e_event, nua_r_bye); TEST(e->data->e_status, internal_error); TEST_1(!e->next); free_events_in_list(ctx, a->events); nua_handle_destroy(a_call->nh), a_call->nh = NULL; if (print_headings) printf("TEST NUA-1.2.2: PASSED\n"); /* -Un-register without REGISTER--------------------------------------- */ if (print_headings) printf("TEST NUA-1.2.3: unregister without register\n"); TEST_1(a_call->nh = nua_handle(a->nua, a_call, SIPTAG_TO(a->to), TAG_END())); UNREGISTER(a, a_call, a_call->nh, TAG_END()); run_a_until(ctx, -1, save_until_final_response); TEST_1(e = a->events->head); TEST_E(e->data->e_event, nua_r_unregister); TEST(e->data->e_status, 401); TEST_1(!e->next); free_events_in_list(ctx, a->events); nua_handle_destroy(a_call->nh), a_call->nh = NULL; if (print_headings) printf("TEST NUA-1.2.3: PASSED\n"); /* -Un-publish without publish--------------------------------------- */ if (print_headings) printf("TEST NUA-1.2.4: unpublish without publish\n"); TEST_1(a_call->nh = nua_handle(a->nua, a_call, SIPTAG_TO(b->to), TAG_END())); UNPUBLISH(a, a_call, a_call->nh, TAG_END()); run_a_until(ctx, -1, save_until_final_response); TEST_1(e = a->events->head); TEST_E(e->data->e_event, nua_r_unpublish); TEST(e->data->e_status, 404); TEST_1(!e->next); free_events_in_list(ctx, a->events); nua_handle_destroy(a_call->nh), a_call->nh = NULL; if (print_headings) printf("TEST NUA-1.2.4: PASSED\n"); /* -terminate without notifier--------------------------------------- */ if (print_headings) printf("TEST NUA-1.2.5: unpublish without publish\n"); TEST_1(a_call->nh = nua_handle(a->nua, a_call, SIPTAG_TO(b->to), TAG_END())); TERMINATE(a, a_call, a_call->nh, TAG_END()); run_a_until(ctx, -1, save_until_final_response); TEST_1(e = a->events->head); TEST_E(e->data->e_event, nua_r_terminate); TEST(e->data->e_status, internal_error); TEST_1(!e->next); free_events_in_list(ctx, a->events); AUTHORIZE(a, a_call, a_call->nh, TAG_END()); run_a_until(ctx, -1, save_until_final_response); TEST_1(e = a->events->head); TEST_E(e->data->e_event, nua_r_authorize); TEST(e->data->e_status, internal_error); TEST_1(!e->next); free_events_in_list(ctx, a->events); nua_handle_destroy(a_call->nh), a_call->nh = NULL; if (print_headings) printf("TEST NUA-1.2.5: PASSED\n"); if (print_headings) printf("TEST NUA-1.2: PASSED\n"); END();}/* ======================================================================== */static char passwd_name[] = "tmp_sippasswd.XXXXXX";static void remove_tmp(void){ if (passwd_name[0]) unlink(passwd_name);}static char const passwd[] = "alice:secret:\n" "bob:secret:\n" "charlie:secret:\n";int test_nua_init(struct context *ctx, int start_proxy, url_t const *o_proxy, int start_nat, tag_type_t tag, tag_value_t value, ...){ BEGIN(); struct event *e; sip_contact_t const *m = NULL; sip_from_t const *sipaddress = NULL; url_t const *p_uri, *a_uri; /* Proxy URI */ char const *a_bind, *a_bind2; a_bind = a_bind2 = "sip:0.0.0.0:*"; ctx->root = su_root_create(NULL); TEST_1(ctx->root); /* Disable threading by command line switch? */ su_root_threading(ctx->root, ctx->threading); if (start_proxy && !o_proxy) { int temp; if (print_headings) printf("TEST NUA-2.1.1: init proxy P\n");#ifndef _WIN32 temp = mkstemp(passwd_name);#else temp = open(passwd_name, O_WRONLY|O_CREAT|O_TRUNC, 666);#endif TEST_1(temp != -1); atexit(remove_tmp); /* Make sure temp file is unlinked */ TEST(write(temp, passwd, strlen(passwd)), strlen(passwd)); TEST_1(close(temp) == 0); ctx->p = test_proxy_create(ctx->root, AUTHTAG_METHOD("Digest"), AUTHTAG_REALM("test-proxy"), AUTHTAG_OPAQUE("kuik"), AUTHTAG_DB(passwd_name), AUTHTAG_QOP("auth-int"), AUTHTAG_ALGORITHM("md5-sess"), TAG_END()); ctx->proxy_tests = ctx->p != NULL; if (print_headings) printf("TEST NUA-2.1.1: PASSED\n"); } p_uri = a_uri = test_proxy_uri(ctx->p); if (start_nat && p_uri == NULL) p_uri = url_hdup(ctx->home, (void *)o_proxy); if (start_nat && p_uri != NULL) { int family = 0; su_sockaddr_t su[1]; socklen_t sulen = sizeof su; char b[64]; int len; ta_list ta; if (print_headings) printf("TEST NUA-2.1.2: creating test NAT\n"); /* Try to use different family than proxy. */ if (p_uri->url_host[0] == '[') family = AF_INET;#if defined(SU_HAVE_IN6) else family = AF_INET6;#endif ta_start(ta, tag, value); ctx->nat = test_nat_create(ctx->root, family, ta_tags(ta)); ta_end(ta); /* * NAT thingy works so that we set the outgoing proxy URI to point * towards its "private" address and give the real address of the proxy * as its "public" address. If we use different IP families here, we may * even manage to test real connectivity problems as proxy and endpoint * can not talk to each other. */ if (test_nat_private(ctx->nat, su, &sulen) < 0) { printf("%s:%u: NUA-2.1.2: failed to get private NAT address\n", __FILE__, __LINE__); }#if defined(SU_HAVE_IN6) else if (su->su_family == AF_INET6) { a_uri = (void *) su_sprintf(ctx->home, "sip:[%s]:%u", inet_ntop(su->su_family, SU_ADDR(su), b, sizeof b), ntohs(su->su_port)); a_bind = "sip:[::]:*"; }#endif else if (su->su_family == AF_INET) { a_uri = (void *) su_sprintf(ctx->home, "sip:%s:%u", inet_ntop(su->su_family, SU_ADDR(su), b, sizeof b), ntohs(su->su_port)); }#if defined(SU_HAVE_IN6) if (p_uri->url_host[0] == '[') { su->su_len = sulen = (sizeof su->su_sin6), su->su_family = AF_INET6; len = strcspn(p_uri->url_host + 1, "]"); assert(len < sizeof b); memcpy(b, p_uri->url_host + 1, len); b[len] = '\0'; inet_pton(su->su_family, b, SU_ADDR(su)); } else { su->su_len = sulen = (sizeof su->su_sin), su->su_family = AF_INET; inet_pton(su->su_family, p_uri->url_host, SU_ADDR(su)); }#else su->su_len = sulen = (sizeof su->su_sin), su->su_family = AF_INET; inet_pton(su->su_family, p_uri->url_host, SU_ADDR(su));#endif su->su_port = htons(strtoul(url_port(p_uri), NULL, 10)); if (test_nat_public(ctx->nat, su, sulen) < 0) { printf("%s:%u: NUA-2.1.2: failed to set public address\n",
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -