|  | @@ -46,10 +46,13 @@
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  static int
 | 
	
		
			
				|  |  | -action(void *arg)
 | 
	
		
			
				|  |  | +action1(void *arg)
 | 
	
		
			
				|  |  |  {
 | 
	
		
			
				|  |  |  	int *p = (int *)arg;
 | 
	
		
			
				|  |  |  	(*p)--;
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	ck_assert_int_ge(*p, -1);
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  |  	return 1;
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
	
		
			
				|  | @@ -67,17 +70,18 @@ START_TEST(test_timer1)
 | 
	
		
			
				|  |  |  	mark_point();
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	c[0] = 10;
 | 
	
		
			
				|  |  | -	timer_add(&ctx, 0, 0.1, 1, action, c + 0);
 | 
	
		
			
				|  |  | +	timer_add(&ctx, 0, 0.1, 1, action1, c + 0);
 | 
	
		
			
				|  |  |  	c[2] = 2;
 | 
	
		
			
				|  |  | -	timer_add(&ctx, 0, 0.5, 1, action, c + 2);
 | 
	
		
			
				|  |  | +	timer_add(&ctx, 0, 0.5, 1, action1, c + 2);
 | 
	
		
			
				|  |  |  	c[1] = 5;
 | 
	
		
			
				|  |  | -	timer_add(&ctx, 0, 0.2, 1, action, c + 1);
 | 
	
		
			
				|  |  | +	timer_add(&ctx, 0, 0.2, 1, action1, c + 1);
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	mg_sleep(1000);
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	ctx.stop_flag = 99;
 | 
	
		
			
				|  |  |  	mg_sleep(100);
 | 
	
		
			
				|  |  |  	timers_exit(&ctx);
 | 
	
		
			
				|  |  | +	mg_sleep(100);
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  #ifdef LOCAL_TEST
 | 
	
		
			
				|  |  |  	ck_assert_int_eq(c[0], 0);
 | 
	
	
		
			
				|  | @@ -95,16 +99,62 @@ START_TEST(test_timer1)
 | 
	
		
			
				|  |  |  END_TEST
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | +static int
 | 
	
		
			
				|  |  | +action2(void *arg)
 | 
	
		
			
				|  |  | +{
 | 
	
		
			
				|  |  | +	int *p = (int *)arg;
 | 
	
		
			
				|  |  | +	(*p)--;
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	ck_assert_int_ge(*p, -1);
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	return 0;
 | 
	
		
			
				|  |  | +}
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +START_TEST(test_timer2)
 | 
	
		
			
				|  |  | +{
 | 
	
		
			
				|  |  | +	struct mg_context ctx;
 | 
	
		
			
				|  |  | +	int c[10];
 | 
	
		
			
				|  |  | +	memset(&ctx, 0, sizeof(ctx));
 | 
	
		
			
				|  |  | +	memset(c, 0, sizeof(c));
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	mark_point();
 | 
	
		
			
				|  |  | +	timers_init(&ctx);
 | 
	
		
			
				|  |  | +	mg_sleep(100);
 | 
	
		
			
				|  |  | +	mark_point();
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	c[0] = 10;
 | 
	
		
			
				|  |  | +	timer_add(&ctx, 0, 0.1, 1, action2, c + 0);
 | 
	
		
			
				|  |  | +	c[2] = 2;
 | 
	
		
			
				|  |  | +	timer_add(&ctx, 0, 0.5, 1, action2, c + 2);
 | 
	
		
			
				|  |  | +	c[1] = 5;
 | 
	
		
			
				|  |  | +	timer_add(&ctx, 0, 0.2, 1, action2, c + 1);
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	mg_sleep(1000);
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	ctx.stop_flag = 99;
 | 
	
		
			
				|  |  | +	mg_sleep(100);
 | 
	
		
			
				|  |  | +	timers_exit(&ctx);
 | 
	
		
			
				|  |  | +	mg_sleep(100);
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	ck_assert_int_eq(c[0], 9);
 | 
	
		
			
				|  |  | +	ck_assert_int_eq(c[1], 4);
 | 
	
		
			
				|  |  | +	ck_assert_int_eq(c[2], 1);
 | 
	
		
			
				|  |  | +}
 | 
	
		
			
				|  |  | +END_TEST
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  |  Suite *
 | 
	
		
			
				|  |  |  make_timertest_suite(void)
 | 
	
		
			
				|  |  |  {
 | 
	
		
			
				|  |  |  	Suite *const suite = suite_create("Timer");
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -	TCase *const tcase_timer1 = tcase_create("Timer1");
 | 
	
		
			
				|  |  | +	TCase *const tcase_timer = tcase_create("Timer1");
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -	tcase_add_test(tcase_timer1, test_timer1);
 | 
	
		
			
				|  |  | -	tcase_set_timeout(tcase_timer1, civetweb_min_test_timeout);
 | 
	
		
			
				|  |  | -	suite_add_tcase(suite, tcase_timer1);
 | 
	
		
			
				|  |  | +	tcase_add_test(tcase_timer, test_timer1);
 | 
	
		
			
				|  |  | +	tcase_add_test(tcase_timer, test_timer2);
 | 
	
		
			
				|  |  | +	tcase_set_timeout(tcase_timer, civetweb_min_test_timeout);
 | 
	
		
			
				|  |  | +	suite_add_tcase(suite, tcase_timer);
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	return suite;
 | 
	
		
			
				|  |  |  }
 | 
	
	
		
			
				|  | @@ -122,6 +172,7 @@ TIMER_PRIVATE(void)
 | 
	
		
			
				|  |  |  #endif
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	test_timer1(0);
 | 
	
		
			
				|  |  | +	test_timer2(0);
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  #if defined(_WIN32)
 | 
	
		
			
				|  |  |  	WSACleanup();
 |