eventapi_tester.c 24.6 KB
Newer Older
1
/*
Simon Morlat's avatar
Simon Morlat committed
2 3
    liblinphone_tester - liblinphone test suite
    Copyright (C) 2013  Belledonne Communications SARL
4 5 6

    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
Simon Morlat's avatar
Simon Morlat committed
7
    the Free Software Foundation, either version 2 of the License, or
8 9 10 11 12 13 14 15 16 17 18
    (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, see <http://www.gnu.org/licenses/>.
*/

Simon Morlat's avatar
Simon Morlat committed
19

20

21 22
#include "linphone/core.h"
#include "linphone/lpconfig.h"
23
#include <linphone/event.h>
24
#include "liblinphone_tester.h"
Benjamin REIS's avatar
Benjamin REIS committed
25
#include "tester_utils.h"
26 27 28 29

static const char *subscribe_content="<somexml>blabla</somexml>";
static const char *notify_content="<somexml2>blabla</somexml2>";

Simon Morlat's avatar
Simon Morlat committed
30 31 32 33 34 35 36 37
const char *liblinphone_tester_get_subscribe_content(void){
	return subscribe_content;
}

const char *liblinphone_tester_get_notify_content(void){
	return notify_content;
}

38
void linphone_notify_received(LinphoneCore *lc, LinphoneEvent *lev, const char *eventname, const LinphoneContent *content){
39
	LinphoneCoreManager *mgr;
40
	const char * ua = linphone_event_get_custom_header(lev, "User-Agent");
41
	if (!BC_ASSERT_PTR_NOT_NULL(content)) return;
42
	if (!linphone_content_is_multipart(content) && (!ua ||  !strstr(ua, "flexisip"))) { /*disable check for full presence server support*/
43
		/*hack to disable content checking for list notify */
Ghislain MARY's avatar
Ghislain MARY committed
44 45
		BC_ASSERT_STRING_EQUAL(notify_content,(const char*)linphone_content_get_buffer(content));
	}
46
	mgr=get_manager(lc);
47
	mgr->stat.number_of_NotifyReceived++;
48 49 50
}

void linphone_subscription_state_change(LinphoneCore *lc, LinphoneEvent *lev, LinphoneSubscriptionState state) {
51 52
	stats* counters = get_stats(lc);
	LinphoneCoreManager *mgr=get_manager(lc);
53
	LinphoneContent* content;
54 55
	const LinphoneAddress* from_addr = linphone_event_get_from(lev);
	char* from = linphone_address_as_string(from_addr);
56 57 58
	content = linphone_core_create_content(lc);
	linphone_content_set_type(content,"application");
	linphone_content_set_subtype(content,"somexml2");
59
	linphone_content_set_buffer(content,(const uint8_t *)notify_content,strlen(notify_content));
60

61 62 63
	ms_message("Subscription state [%s] from [%s]",linphone_subscription_state_to_string(state),from);
	ms_free(from);

64 65 66 67 68
	switch(state){
		case LinphoneSubscriptionNone:
		break;
		case LinphoneSubscriptionIncomingReceived:
			counters->number_of_LinphoneSubscriptionIncomingReceived++;
69
			mgr->lev=lev;
70 71 72 73
			if (!mgr->decline_subscribe)
				linphone_event_accept_subscription(lev);
			else
				linphone_event_deny_subscription(lev, LinphoneReasonDeclined);
74
		break;
75 76
		case LinphoneSubscriptionOutgoingProgress:
			counters->number_of_LinphoneSubscriptionOutgoingProgress++;
77 78 79 80 81 82
		break;
		case LinphoneSubscriptionPending:
			counters->number_of_LinphoneSubscriptionPending++;
		break;
		case LinphoneSubscriptionActive:
			counters->number_of_LinphoneSubscriptionActive++;
Simon Morlat's avatar
Simon Morlat committed
83
			if (linphone_event_get_subscription_dir(lev)==LinphoneSubscriptionIncoming){
84
				mgr->lev=lev;
85
				if(strcmp(linphone_event_get_name(lev), "conference") == 0) {
86
					// TODO : Get LocalConfEventHandler and call handler->subscribeReceived(lev)
87 88 89
				} else {
					linphone_event_notify(lev,content);
				}
90
			}
91 92 93
		break;
		case LinphoneSubscriptionTerminated:
			counters->number_of_LinphoneSubscriptionTerminated++;
94
			mgr->lev=NULL;
95 96 97
		break;
		case LinphoneSubscriptionError:
			counters->number_of_LinphoneSubscriptionError++;
98
			mgr->lev=NULL;
99
		break;
100 101 102 103
		case LinphoneSubscriptionExpiring:
			counters->number_of_LinphoneSubscriptionExpiring++;
			mgr->lev=NULL;
		break;
104
	}
105
	linphone_content_unref(content);
106 107
}

108 109
void linphone_publish_state_changed(LinphoneCore *lc, LinphoneEvent *ev, LinphonePublishState state){
	stats* counters = get_stats(lc);
110 111 112 113
	const LinphoneAddress* from_addr = linphone_event_get_from(ev);
	char* from = linphone_address_as_string(from_addr);
	ms_message("Publish state [%s] from [%s]",linphone_publish_state_to_string(state),from);
	ms_free(from);
114 115
	switch(state){
		case LinphonePublishProgress: counters->number_of_LinphonePublishProgress++; break;
116
		case LinphonePublishOk:
117
			/*make sure custom header access API is working*/
118 119
			BC_ASSERT_PTR_NOT_NULL(linphone_event_get_custom_header(ev,"From"));
			counters->number_of_LinphonePublishOk++;
120
			break;
121 122 123 124 125 126
		case LinphonePublishError: counters->number_of_LinphonePublishError++; break;
		case LinphonePublishExpiring: counters->number_of_LinphonePublishExpiring++; break;
		case LinphonePublishCleared: counters->number_of_LinphonePublishCleared++;break;
		default:
		break;
	}
127

128 129
}

130
static void subscribe_test_declined(void) {
Simon Morlat's avatar
Simon Morlat committed
131
	LinphoneCoreManager* marie = linphone_core_manager_new( "marie_rc");
132
	LinphoneCoreManager* pauline = linphone_core_manager_new( "pauline_tcp_rc");
133
	LinphoneContent* content;
134 135
	LinphoneEvent *lev;
	const LinphoneErrorInfo *ei;
136 137
	bctbx_list_t* lcs=bctbx_list_append(NULL,marie->lc);
	lcs=bctbx_list_append(lcs,pauline->lc);
138

139 140 141
	content = linphone_core_create_content(marie->lc);
	linphone_content_set_type(content,"application");
	linphone_content_set_subtype(content,"somexml");
142
	linphone_content_set_buffer(content,(const uint8_t *)subscribe_content,strlen(subscribe_content));
143

144
	pauline->decline_subscribe=TRUE;
145 146

	lev=linphone_core_subscribe(marie->lc,pauline->identity,"dodo",600,content);
147
	linphone_event_ref(lev);
148

149
	BC_ASSERT_TRUE(wait_for_list(lcs,&marie->stat.number_of_LinphoneSubscriptionOutgoingProgress,1,1000));
150 151
	BC_ASSERT_TRUE(wait_for_list(lcs,&pauline->stat.number_of_LinphoneSubscriptionIncomingReceived,1,3000));
	BC_ASSERT_TRUE(wait_for_list(lcs,&marie->stat.number_of_LinphoneSubscriptionError,1,21000));/*yes flexisip may wait 20 secs in case of forking*/
152
	ei=linphone_event_get_error_info(lev);
153
	BC_ASSERT_PTR_NOT_NULL(ei);
154
	if (ei){
155 156
		BC_ASSERT_EQUAL(linphone_error_info_get_protocol_code(ei),603, int, "%d");
		BC_ASSERT_PTR_NOT_NULL(linphone_error_info_get_phrase(ei));
157
	}
158
	BC_ASSERT_TRUE(wait_for_list(lcs,&pauline->stat.number_of_LinphoneSubscriptionTerminated,1,1000));
159

160
	bctbx_list_free(lcs);
161
	linphone_content_unref(content);
162
	linphone_event_unref(lev);
163 164 165
	linphone_core_manager_destroy(marie);
	linphone_core_manager_destroy(pauline);
}
166

167 168 169 170 171
typedef enum RefreshTestType{
	NoRefresh,
	AutoRefresh,
	ManualRefresh
}RefreshTestType;
172

173
static void subscribe_test_with_args(bool_t terminated_by_subscriber, RefreshTestType refresh_type) {
Simon Morlat's avatar
Simon Morlat committed
174
	LinphoneCoreManager* marie = linphone_core_manager_new( "marie_rc");
175
	LinphoneCoreManager* pauline = linphone_core_manager_new( "pauline_tcp_rc");
176
	LinphoneContent* content;
177
	LinphoneEvent *lev;
178
	int expires= refresh_type!=NoRefresh ? 4 : 600;
179
	bctbx_list_t* lcs=bctbx_list_append(NULL,marie->lc);
180

181
	lcs=bctbx_list_append(lcs,pauline->lc);
182

183
	if (refresh_type==ManualRefresh){
184
		lp_config_set_int(linphone_core_get_config(marie->lc),"sip","refresh_generic_subscribe",0);
185
	}
186

187 188 189
	content = linphone_core_create_content(marie->lc);
	linphone_content_set_type(content,"application");
	linphone_content_set_subtype(content,"somexml");
190
	linphone_content_set_buffer(content,(const uint8_t *)subscribe_content,strlen(subscribe_content));
191 192

	lev=linphone_core_subscribe(marie->lc,pauline->identity,"dodo",expires,content);
193
	linphone_event_ref(lev);
194
	BC_ASSERT_TRUE(wait_for_list(lcs,&marie->stat.number_of_LinphoneSubscriptionOutgoingProgress,1,1000));
195 196 197
	BC_ASSERT_TRUE(wait_for_list(lcs,&pauline->stat.number_of_LinphoneSubscriptionIncomingReceived,1,3000));
	BC_ASSERT_TRUE(wait_for_list(lcs,&marie->stat.number_of_LinphoneSubscriptionActive,1,3000));
	BC_ASSERT_TRUE(wait_for_list(lcs,&pauline->stat.number_of_LinphoneSubscriptionActive,1,1000));
198

199
	/*make sure marie receives first notification before terminating*/
200
	BC_ASSERT_TRUE(wait_for_list(lcs,&marie->stat.number_of_NotifyReceived,1,1000));
201

202
	if (refresh_type==AutoRefresh){
203
		wait_for_list(lcs,NULL,0,6000);
204 205 206 207
		BC_ASSERT_PTR_NOT_NULL(pauline->lev);
		if (pauline->lev){
			BC_ASSERT_EQUAL(linphone_event_get_subscription_state(pauline->lev), LinphoneSubscriptionActive, int, "%d");
		}
208
	}else if (refresh_type==ManualRefresh){
209
		BC_ASSERT_TRUE(wait_for_list(lcs,&marie->stat.number_of_LinphoneSubscriptionExpiring,1,4000));
210
		linphone_event_update_subscribe(lev,NULL);
211
		BC_ASSERT_TRUE(wait_for_list(lcs,&marie->stat.number_of_LinphoneSubscriptionActive,2,2000));
212
	}
213

214 215 216
	if (terminated_by_subscriber){
		linphone_event_terminate(lev);
	}else{
217
		BC_ASSERT_PTR_NOT_NULL(pauline->lev);
218 219
		linphone_event_terminate(pauline->lev);
	}
220

221 222
	BC_ASSERT_TRUE(wait_for_list(lcs,&marie->stat.number_of_LinphoneSubscriptionTerminated,1,1000));
	BC_ASSERT_TRUE(wait_for_list(lcs,&pauline->stat.number_of_LinphoneSubscriptionTerminated,1,1000));
223

224
	bctbx_list_free(lcs);
225
	linphone_event_unref(lev);
226
	linphone_content_unref(content);
227 228 229 230
	linphone_core_manager_destroy(marie);
	linphone_core_manager_destroy(pauline);
}

231 232
static void subscribe_test_with_args2(bool_t terminated_by_subscriber, RefreshTestType refresh_type) {
	LinphoneCoreManager* marie = linphone_core_manager_new( "marie_rc");
233
	LinphoneCoreManager* pauline = linphone_core_manager_new( "pauline_tcp_rc");
234
	LinphoneContent* content;
235 236
	LinphoneEvent *lev;
	int expires= refresh_type!=NoRefresh ? 4 : 600;
237
	bctbx_list_t* lcs=bctbx_list_append(NULL,marie->lc);
238

239
	lcs=bctbx_list_append(lcs,pauline->lc);
240 241

	if (refresh_type==ManualRefresh){
242
		lp_config_set_int(linphone_core_get_config(marie->lc),"sip","refresh_generic_subscribe",0);
243 244
	}

245 246 247
	content = linphone_core_create_content(marie->lc);
	linphone_content_set_type(content,"application");
	linphone_content_set_subtype(content,"somexml");
248
	linphone_content_set_buffer(content,(const uint8_t *)subscribe_content,strlen(subscribe_content));
249

250 251 252
	lev=linphone_core_create_subscribe(marie->lc,pauline->identity,"dodo",expires);
	linphone_event_add_custom_header(lev,"My-Header","pouet");
	linphone_event_add_custom_header(lev,"My-Header2","pimpon");
253 254
	linphone_event_send_subscribe(lev,content);

255
	BC_ASSERT_TRUE(wait_for_list(lcs,&marie->stat.number_of_LinphoneSubscriptionOutgoingProgress,1,1000));
256
	BC_ASSERT_TRUE(wait_for_list(lcs,&pauline->stat.number_of_LinphoneSubscriptionIncomingReceived,1,3000));
257

258 259 260 261 262
	if (pauline->stat.number_of_LinphoneSubscriptionIncomingReceived == 1) {
		/*check good receipt of custom headers*/
		BC_ASSERT_STRING_EQUAL(linphone_event_get_custom_header(pauline->lev,"My-Header"),"pouet");
		BC_ASSERT_STRING_EQUAL(linphone_event_get_custom_header(pauline->lev,"My-Header2"),"pimpon");
	}
263 264
	BC_ASSERT_TRUE(wait_for_list(lcs,&marie->stat.number_of_LinphoneSubscriptionActive,1,5000));
	BC_ASSERT_TRUE(wait_for_list(lcs,&pauline->stat.number_of_LinphoneSubscriptionActive,1,5000));
265 266

	/*make sure marie receives first notification before terminating*/
267 268
	BC_ASSERT_TRUE(wait_for_list(lcs,&marie->stat.number_of_NotifyReceived,1,5000));

269 270
	if (refresh_type==AutoRefresh){
		wait_for_list(lcs,NULL,0,6000);
271
		BC_ASSERT_EQUAL(linphone_event_get_subscription_state(pauline->lev), LinphoneSubscriptionActive, int, "%d");
272
	}else if (refresh_type==ManualRefresh){
273
		BC_ASSERT_TRUE(wait_for_list(lcs,&marie->stat.number_of_LinphoneSubscriptionExpiring,1,4000));
274
		linphone_event_update_subscribe(lev,NULL);
275
		BC_ASSERT_TRUE(wait_for_list(lcs,&marie->stat.number_of_LinphoneSubscriptionActive,2,5000));
276 277 278 279 280
	}

	if (terminated_by_subscriber){
		linphone_event_terminate(lev);
	}else{
281
		BC_ASSERT_PTR_NOT_NULL(pauline->lev);
282 283
		linphone_event_terminate(pauline->lev);
	}
284

285 286
	BC_ASSERT_TRUE(wait_for_list(lcs,&marie->stat.number_of_LinphoneSubscriptionTerminated,1,5000));
	BC_ASSERT_TRUE(wait_for_list(lcs,&pauline->stat.number_of_LinphoneSubscriptionTerminated,1,5000));
287 288

	linphone_content_unref(content);
289 290
	linphone_core_manager_destroy(marie);
	linphone_core_manager_destroy(pauline);
291
	bctbx_list_free(lcs);
292 293
}

294
static void subscribe_test_terminated_by_subscriber(void){
295
	subscribe_test_with_args(TRUE,NoRefresh);
296 297 298
}

static void subscribe_test_terminated_by_notifier(void){
299
	subscribe_test_with_args(FALSE,NoRefresh);
300 301
}

302
/* Caution: this test does not really check that the subscribe are refreshed, because the core is not managing the expiration of
303 304 305
 * unrefreshed subscribe dialogs. So it is just checking that it is not crashing.
 */
static void subscribe_test_refreshed(void){
306 307 308
	subscribe_test_with_args(TRUE,AutoRefresh);
}

309 310 311 312
static void subscribe_test_with_custom_header(void){
	subscribe_test_with_args2(TRUE,NoRefresh);
}

313 314
static void subscribe_test_manually_refreshed(void){
	subscribe_test_with_args(TRUE,ManualRefresh);
315 316
}

317
static void subscribe_loosing_dialog(void) {
318 319 320 321 322 323
#ifdef WIN32
	/*Unfortunately this test doesn't work on windows due to the way closed TCP ports behave.
	 * Unlike linux and macOS, released TCP port don't send an ICMP error (or maybe at least for a period of time.
	 * This prevents this test from working, see comments below*/
	ms_warning("subscribe_loosing_dialog() skipped on windows.");
#else
324 325 326 327 328 329 330 331 332 333 334 335
	LinphoneCoreManager* marie = linphone_core_manager_new( "marie_rc");
	LinphoneCoreManager* pauline = linphone_core_manager_new( "pauline_tcp_rc");
	LinphoneContent* content;
	LinphoneEvent *lev;
	int expires= 4;
	bctbx_list_t* lcs=bctbx_list_append(NULL,marie->lc);

	lcs=bctbx_list_append(lcs,pauline->lc);

	content = linphone_core_create_content(marie->lc);
	linphone_content_set_type(content,"application");
	linphone_content_set_subtype(content,"somexml");
336
	linphone_content_set_buffer(content,(const uint8_t *)subscribe_content,strlen(subscribe_content));
337 338 339 340 341 342 343 344 345

	lev=linphone_core_create_subscribe(marie->lc,pauline->identity,"dodo",expires);
	linphone_event_add_custom_header(lev,"My-Header","pouet");
	linphone_event_add_custom_header(lev,"My-Header2","pimpon");
	linphone_event_send_subscribe(lev,content);

	BC_ASSERT_TRUE(wait_for_list(lcs,&marie->stat.number_of_LinphoneSubscriptionOutgoingProgress,1,1000));
	BC_ASSERT_TRUE(wait_for_list(lcs,&pauline->stat.number_of_LinphoneSubscriptionIncomingReceived,1,3000));

Benjamin REIS's avatar
Benjamin REIS committed
346

347 348 349 350 351 352 353 354 355 356 357 358 359 360
	BC_ASSERT_TRUE(wait_for_list(lcs,&marie->stat.number_of_LinphoneSubscriptionActive,1,5000));
	BC_ASSERT_TRUE(wait_for_list(lcs,&pauline->stat.number_of_LinphoneSubscriptionActive,1,5000));

	/*make sure marie receives first notification before terminating*/
	BC_ASSERT_TRUE(wait_for_list(lcs,&marie->stat.number_of_NotifyReceived,1,5000));

	/* now pauline looses internet connection and reboots */
	linphone_core_set_network_reachable(pauline->lc, FALSE);
	/*let expire the incoming subscribe received by pauline */
	BC_ASSERT_TRUE(wait_for_list(lcs,&pauline->stat.number_of_LinphoneSubscriptionTerminated,1,5000));
	lcs = bctbx_list_remove(lcs, pauline->lc);
	linphone_core_manager_destroy(pauline);
	pauline = linphone_core_manager_new( "pauline_tcp_rc");
	lcs = bctbx_list_append(lcs, pauline->lc);
Benjamin REIS's avatar
Benjamin REIS committed
361

362 363 364
	/* Marie will retry the subscription.
	 * She will first receive a 503 Service unavailable from flexisip thanks the ICMP error returned by the no longer existing Pauline.
	 * Then she will forge a new SUBSCRIBE in order to restart a new dialog, and this one will reach the new Pauline.*/
365 366 367 368
	BC_ASSERT_TRUE(wait_for_list(lcs,&marie->stat.number_of_LinphoneSubscriptionOutgoingProgress,2,8000));
	/*and get it accepted again*/
	BC_ASSERT_TRUE(wait_for_list(lcs,&marie->stat.number_of_LinphoneSubscriptionActive,2,5000));
	BC_ASSERT_TRUE(wait_for_list(lcs,&pauline->stat.number_of_LinphoneSubscriptionActive,1,5000));
369 370
	BC_ASSERT_PTR_NOT_NULL(pauline->lev);
	if (pauline->lev) BC_ASSERT_EQUAL(linphone_event_get_subscription_state(pauline->lev), LinphoneSubscriptionActive, int, "%d");
Benjamin REIS's avatar
Benjamin REIS committed
371

372 373
	BC_ASSERT_TRUE(wait_for_list(lcs,&marie->stat.number_of_NotifyReceived,2,5000));
	linphone_event_terminate(lev);
Benjamin REIS's avatar
Benjamin REIS committed
374

375 376 377 378 379 380 381 382

	BC_ASSERT_TRUE(wait_for_list(lcs,&marie->stat.number_of_LinphoneSubscriptionTerminated,1,5000));
	BC_ASSERT_TRUE(wait_for_list(lcs,&pauline->stat.number_of_LinphoneSubscriptionTerminated,1,5000));

	linphone_content_unref(content);
	linphone_core_manager_destroy(marie);
	linphone_core_manager_destroy(pauline);
	bctbx_list_free(lcs);
383
#endif
384 385 386 387 388 389 390 391 392 393 394 395 396 397 398
}

static void subscribe_with_io_error(void) {
	LinphoneCoreManager* marie = linphone_core_manager_new( "marie_rc");
	LinphoneCoreManager* pauline = linphone_core_manager_new( "pauline_tcp_rc");
	LinphoneContent* content;
	LinphoneEvent *lev;
	int expires= 4;
	bctbx_list_t* lcs=bctbx_list_append(NULL,marie->lc);

	lcs=bctbx_list_append(lcs,pauline->lc);

	content = linphone_core_create_content(marie->lc);
	linphone_content_set_type(content,"application");
	linphone_content_set_subtype(content,"somexml");
399
	linphone_content_set_buffer(content,(const uint8_t *)subscribe_content,strlen(subscribe_content));
400 401 402 403 404 405 406 407 408

	lev=linphone_core_create_subscribe(marie->lc,pauline->identity,"dodo",expires);
	linphone_event_add_custom_header(lev,"My-Header","pouet");
	linphone_event_add_custom_header(lev,"My-Header2","pimpon");
	linphone_event_send_subscribe(lev,content);

	BC_ASSERT_TRUE(wait_for_list(lcs,&marie->stat.number_of_LinphoneSubscriptionOutgoingProgress,1,1000));
	BC_ASSERT_TRUE(wait_for_list(lcs,&pauline->stat.number_of_LinphoneSubscriptionIncomingReceived,1,3000));

Benjamin REIS's avatar
Benjamin REIS committed
409

410 411 412 413 414 415 416
	BC_ASSERT_TRUE(wait_for_list(lcs,&marie->stat.number_of_LinphoneSubscriptionActive,1,5000));
	BC_ASSERT_TRUE(wait_for_list(lcs,&pauline->stat.number_of_LinphoneSubscriptionActive,1,5000));

	/*make sure marie receives first notification before terminating*/
	BC_ASSERT_TRUE(wait_for_list(lcs,&marie->stat.number_of_NotifyReceived,1,5000));

	/* now marie gets network errors when refreshing*/
417
	sal_set_send_error(linphone_core_get_sal(marie->lc), -1);
Benjamin REIS's avatar
Benjamin REIS committed
418

419 420
	/*marie will retry the subscription*/
	BC_ASSERT_TRUE(wait_for_list(lcs,&marie->stat.number_of_LinphoneSubscriptionOutgoingProgress,2,8000));
421
	sal_set_send_error(linphone_core_get_sal(marie->lc), 0);
Benjamin REIS's avatar
Benjamin REIS committed
422

423 424 425 426 427 428
	/*and get it accepted again*/
	BC_ASSERT_TRUE(wait_for_list(lcs,&marie->stat.number_of_LinphoneSubscriptionActive,2,10000));
	BC_ASSERT_TRUE(wait_for_list(lcs,&pauline->stat.number_of_LinphoneSubscriptionActive,2,5000));
	BC_ASSERT_EQUAL(linphone_event_get_subscription_state(pauline->lev), LinphoneSubscriptionActive, int, "%d");
	BC_ASSERT_TRUE(wait_for_list(lcs,&marie->stat.number_of_NotifyReceived,2,5000));
	linphone_event_terminate(lev);
Benjamin REIS's avatar
Benjamin REIS committed
429

430 431 432 433 434 435 436 437 438 439

	BC_ASSERT_TRUE(wait_for_list(lcs,&marie->stat.number_of_LinphoneSubscriptionTerminated,1,5000));
	BC_ASSERT_TRUE(wait_for_list(lcs,&pauline->stat.number_of_LinphoneSubscriptionTerminated,1,5000));

	linphone_content_unref(content);
	linphone_core_manager_destroy(marie);
	linphone_core_manager_destroy(pauline);
	bctbx_list_free(lcs);
}

440 441 442 443 444 445 446 447 448 449 450 451 452
static void subscribe_not_timely_responded(void) {
	LinphoneCoreManager* marie = linphone_core_manager_new( "marie_rc");
	LinphoneCoreManager* pauline = linphone_core_manager_new( "pauline_tcp_rc");
	LinphoneContent* content;
	LinphoneEvent *lev;
	int expires= 4;
	bctbx_list_t* lcs=bctbx_list_append(NULL,marie->lc);

	lcs=bctbx_list_append(lcs,pauline->lc);

	content = linphone_core_create_content(marie->lc);
	linphone_content_set_type(content,"application");
	linphone_content_set_subtype(content,"somexml");
453
	linphone_content_set_buffer(content,(const uint8_t *)subscribe_content,strlen(subscribe_content));
454 455 456 457 458 459 460 461 462

	lev=linphone_core_create_subscribe(marie->lc,pauline->identity,"dodo",expires);
	linphone_event_add_custom_header(lev,"My-Header","pouet");
	linphone_event_add_custom_header(lev,"My-Header2","pimpon");
	linphone_event_send_subscribe(lev,content);

	BC_ASSERT_TRUE(wait_for_list(lcs,&marie->stat.number_of_LinphoneSubscriptionOutgoingProgress,1,1000));
	BC_ASSERT_TRUE(wait_for_list(lcs,&pauline->stat.number_of_LinphoneSubscriptionIncomingReceived,1,3000));

Benjamin REIS's avatar
Benjamin REIS committed
463

464 465 466 467 468 469 470 471 472 473
	BC_ASSERT_TRUE(wait_for_list(lcs,&marie->stat.number_of_LinphoneSubscriptionActive,1,5000));
	BC_ASSERT_TRUE(wait_for_list(lcs,&pauline->stat.number_of_LinphoneSubscriptionActive,1,5000));

	/*make sure marie receives first notification before terminating*/
	BC_ASSERT_TRUE(wait_for_list(lcs,&marie->stat.number_of_NotifyReceived,1,5000));

	/* now pauline is no longer scheduled (simulating a very big latency in the network) */
	lcs = bctbx_list_remove(lcs, pauline->lc);
	/*marie's dialog will expire while the SUBSCRIBE refresh is in progress*/
	wait_for_list(lcs, NULL, 0, 8000);
Benjamin REIS's avatar
Benjamin REIS committed
474

475 476 477 478 479 480 481 482 483 484 485 486
	lcs = bctbx_list_append(lcs, pauline->lc);
	wait_for_list(lcs, NULL, 0, 3000);
	linphone_event_terminate(lev);
	BC_ASSERT_TRUE(wait_for_list(lcs,&marie->stat.number_of_LinphoneSubscriptionTerminated,1,5000));
	BC_ASSERT_TRUE(wait_for_list(lcs,&pauline->stat.number_of_LinphoneSubscriptionTerminated,1,5000));

	linphone_content_unref(content);
	linphone_core_manager_destroy(marie);
	linphone_core_manager_destroy(pauline);
	bctbx_list_free(lcs);
}

487

488
static void publish_test_with_args(bool_t refresh, int expires){
489
	LinphoneCoreManager* marie = linphone_core_manager_new( "marie_rc");
490
	LinphoneCoreManager* pauline = linphone_core_manager_new( "pauline_tcp_rc");
491
	LinphoneContent* content;
492
	LinphoneEvent *lev;
493 494
	bctbx_list_t* lcs=bctbx_list_append(NULL,marie->lc);
	lcs=bctbx_list_append(lcs,pauline->lc);
495

496 497 498
	content = linphone_core_create_content(marie->lc);
	linphone_content_set_type(content,"application");
	linphone_content_set_subtype(content,"somexml");
499
	linphone_content_set_buffer(content,(const uint8_t *)subscribe_content,strlen(subscribe_content));
500

501
	lp_config_set_int(linphone_core_get_config(marie->lc),"sip","refresh_generic_publish",refresh);
502

503
	lev=linphone_core_create_publish(marie->lc,pauline->identity,"dodo",expires);
504
	linphone_event_add_custom_header(lev,"CustomHeader","someValue");
505
	linphone_event_ref(lev);
506
	linphone_event_send_publish(lev,content);
Benjamin REIS's avatar
Benjamin REIS committed
507

508

509 510
	BC_ASSERT_TRUE(wait_for_list(lcs,&marie->stat.number_of_LinphonePublishProgress,1,1000));
	BC_ASSERT_TRUE(wait_for_list(lcs,&marie->stat.number_of_LinphonePublishOk,1,3000));
511

512
	if (!refresh){
513
		BC_ASSERT_TRUE(wait_for_list(lcs,&marie->stat.number_of_LinphonePublishExpiring,1,5000));
514
		linphone_event_update_publish(lev,content);
515 516
		BC_ASSERT_TRUE(wait_for_list(lcs,&marie->stat.number_of_LinphonePublishProgress,1,1000));
		BC_ASSERT_TRUE(wait_for_list(lcs,&marie->stat.number_of_LinphonePublishOk,1,3000));
517
	}else{
518

519 520 521
	}

	linphone_event_terminate(lev);
522

523
	BC_ASSERT_TRUE(wait_for_list(lcs,&marie->stat.number_of_LinphonePublishCleared,1,3000));
524

525
	linphone_event_unref(lev);
526 527

	linphone_content_unref(content);
528 529 530 531
	linphone_core_manager_destroy(marie);
	linphone_core_manager_destroy(pauline);
}

532
static void publish_test(void){
533
	publish_test_with_args(TRUE,5);
534 535
}

536
static void publish_no_auto_test(void){
537 538 539
	publish_test_with_args(FALSE,5);
}

540
static void publish_without_expires(void){
541
	publish_test_with_args(TRUE,-1);
542 543
}

544 545 546 547 548
static void out_of_dialog_notify(void){
	LinphoneCoreManager* marie = linphone_core_manager_new( "marie_rc");
	LinphoneCoreManager* pauline = linphone_core_manager_new( "pauline_tcp_rc");
	LinphoneContent* content;
	LinphoneEvent *lev;
549 550
	bctbx_list_t* lcs=bctbx_list_append(NULL,marie->lc);
	lcs=bctbx_list_append(lcs,pauline->lc);
551 552 553 554

	content = linphone_core_create_content(marie->lc);
	linphone_content_set_type(content,"application");
	linphone_content_set_subtype(content,"somexml");
555
	linphone_content_set_buffer(content,(const uint8_t *)notify_content,strlen(notify_content));
556 557 558 559 560

	lev = linphone_core_create_notify(marie->lc,pauline->identity,"dodo");
	linphone_event_ref(lev);
	linphone_event_add_custom_header(lev,"CustomHeader","someValue");
	linphone_event_notify(lev,content);
Benjamin REIS's avatar
Benjamin REIS committed
561

562 563 564 565 566 567 568 569 570 571 572

	BC_ASSERT_TRUE(wait_for_list(lcs,&pauline->stat.number_of_NotifyReceived,1,3000));
	BC_ASSERT_TRUE(wait_for_list(lcs,&marie->stat.number_of_LinphoneSubscriptionTerminated,1,3000));

	linphone_event_unref(lev);

	linphone_content_unref(content);
	linphone_core_manager_destroy(marie);
	linphone_core_manager_destroy(pauline);
}

573
test_t event_tests[] = {
574
	TEST_ONE_TAG("Subscribe declined", subscribe_test_declined, "presence"),
jehan's avatar
jehan committed
575
	TEST_ONE_TAG("Subscribe terminated by subscriber", subscribe_test_terminated_by_subscriber, "presence"),
576
	TEST_ONE_TAG("Subscribe with custom headers", subscribe_test_with_custom_header, "presence"),
jehan's avatar
jehan committed
577
	TEST_ONE_TAG("Subscribe refreshed", subscribe_test_refreshed, "presence"),
578 579
	TEST_ONE_TAG("Subscribe loosing dialog", subscribe_loosing_dialog, "presence"),
	TEST_ONE_TAG("Subscribe with io error", subscribe_with_io_error, "presence"),
jehan's avatar
jehan committed
580
	TEST_ONE_TAG("Subscribe manually refreshed", subscribe_test_manually_refreshed, "presence"),
581
	TEST_ONE_TAG("Subscribe terminated by notifier", subscribe_test_terminated_by_notifier, "presence"),
582
	TEST_ONE_TAG("Subscribe not timely responded", subscribe_not_timely_responded, "presence"),
583 584
	TEST_ONE_TAG("Publish", publish_test, "presence"),
	TEST_ONE_TAG("Publish without expires", publish_without_expires, "presence"),
585 586
	TEST_ONE_TAG("Publish without automatic refresh",publish_no_auto_test, "presence"),
	TEST_ONE_TAG("Out of dialog notify", out_of_dialog_notify, "presence")
587 588
};

589
test_suite_t event_test_suite = {"Event", NULL, NULL, liblinphone_tester_before_each, liblinphone_tester_after_each,
590
								 sizeof(event_tests) / sizeof(event_tests[0]), event_tests};