xref: /minix3/external/bsd/libevent/dist/test/regress_minheap.c (revision e985b929927b5932e3b68f4b50587d458900107a)
1*e985b929SDavid van Moolenbroek /*	$NetBSD: regress_minheap.c,v 1.1.1.1 2013/04/11 16:43:33 christos Exp $	*/
2*e985b929SDavid van Moolenbroek /*
3*e985b929SDavid van Moolenbroek  * Copyright (c) 2009-2012 Niels Provos and Nick Mathewson
4*e985b929SDavid van Moolenbroek  *
5*e985b929SDavid van Moolenbroek  * Redistribution and use in source and binary forms, with or without
6*e985b929SDavid van Moolenbroek  * modification, are permitted provided that the following conditions
7*e985b929SDavid van Moolenbroek  * are met:
8*e985b929SDavid van Moolenbroek  * 1. Redistributions of source code must retain the above copyright
9*e985b929SDavid van Moolenbroek  *    notice, this list of conditions and the following disclaimer.
10*e985b929SDavid van Moolenbroek  * 2. Redistributions in binary form must reproduce the above copyright
11*e985b929SDavid van Moolenbroek  *    notice, this list of conditions and the following disclaimer in the
12*e985b929SDavid van Moolenbroek  *    documentation and/or other materials provided with the distribution.
13*e985b929SDavid van Moolenbroek  * 3. The name of the author may not be used to endorse or promote products
14*e985b929SDavid van Moolenbroek  *    derived from this software without specific prior written permission.
15*e985b929SDavid van Moolenbroek  *
16*e985b929SDavid van Moolenbroek  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
17*e985b929SDavid van Moolenbroek  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
18*e985b929SDavid van Moolenbroek  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
19*e985b929SDavid van Moolenbroek  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
20*e985b929SDavid van Moolenbroek  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
21*e985b929SDavid van Moolenbroek  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
22*e985b929SDavid van Moolenbroek  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
23*e985b929SDavid van Moolenbroek  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
24*e985b929SDavid van Moolenbroek  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
25*e985b929SDavid van Moolenbroek  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26*e985b929SDavid van Moolenbroek  */
27*e985b929SDavid van Moolenbroek 
28*e985b929SDavid van Moolenbroek #include <stdlib.h>
29*e985b929SDavid van Moolenbroek #include "event2/event_struct.h"
30*e985b929SDavid van Moolenbroek 
31*e985b929SDavid van Moolenbroek #include "tinytest.h"
32*e985b929SDavid van Moolenbroek #include "tinytest_macros.h"
33*e985b929SDavid van Moolenbroek #include "../minheap-internal.h"
34*e985b929SDavid van Moolenbroek 
35*e985b929SDavid van Moolenbroek static void
set_random_timeout(struct event * ev)36*e985b929SDavid van Moolenbroek set_random_timeout(struct event *ev)
37*e985b929SDavid van Moolenbroek {
38*e985b929SDavid van Moolenbroek 	ev->ev_timeout.tv_sec = rand();
39*e985b929SDavid van Moolenbroek 	ev->ev_timeout.tv_usec = rand() & 0xfffff;
40*e985b929SDavid van Moolenbroek 	ev->ev_timeout_pos.min_heap_idx = -1;
41*e985b929SDavid van Moolenbroek }
42*e985b929SDavid van Moolenbroek 
43*e985b929SDavid van Moolenbroek static void
check_heap(struct min_heap * heap)44*e985b929SDavid van Moolenbroek check_heap(struct min_heap *heap)
45*e985b929SDavid van Moolenbroek {
46*e985b929SDavid van Moolenbroek 	unsigned i;
47*e985b929SDavid van Moolenbroek 	for (i = 1; i < heap->n; ++i) {
48*e985b929SDavid van Moolenbroek 		unsigned parent_idx = (i-1)/2;
49*e985b929SDavid van Moolenbroek 		tt_want(evutil_timercmp(&heap->p[i]->ev_timeout,
50*e985b929SDavid van Moolenbroek 			&heap->p[parent_idx]->ev_timeout, >=));
51*e985b929SDavid van Moolenbroek 	}
52*e985b929SDavid van Moolenbroek }
53*e985b929SDavid van Moolenbroek 
54*e985b929SDavid van Moolenbroek static void
test_heap_randomized(void * ptr)55*e985b929SDavid van Moolenbroek test_heap_randomized(void *ptr)
56*e985b929SDavid van Moolenbroek {
57*e985b929SDavid van Moolenbroek 	struct min_heap heap;
58*e985b929SDavid van Moolenbroek 	struct event *inserted[1024];
59*e985b929SDavid van Moolenbroek 	struct event *e, *last_e;
60*e985b929SDavid van Moolenbroek 	int i;
61*e985b929SDavid van Moolenbroek 
62*e985b929SDavid van Moolenbroek 	min_heap_ctor(&heap);
63*e985b929SDavid van Moolenbroek 
64*e985b929SDavid van Moolenbroek 	for (i = 0; i < 1024; ++i) {
65*e985b929SDavid van Moolenbroek 		inserted[i] = malloc(sizeof(struct event));
66*e985b929SDavid van Moolenbroek 		set_random_timeout(inserted[i]);
67*e985b929SDavid van Moolenbroek 		min_heap_push(&heap, inserted[i]);
68*e985b929SDavid van Moolenbroek 	}
69*e985b929SDavid van Moolenbroek 	check_heap(&heap);
70*e985b929SDavid van Moolenbroek 
71*e985b929SDavid van Moolenbroek 	tt_assert(min_heap_size(&heap) == 1024);
72*e985b929SDavid van Moolenbroek 
73*e985b929SDavid van Moolenbroek 	for (i = 0; i < 512; ++i) {
74*e985b929SDavid van Moolenbroek 		min_heap_erase(&heap, inserted[i]);
75*e985b929SDavid van Moolenbroek 		if (0 == (i % 32))
76*e985b929SDavid van Moolenbroek 			check_heap(&heap);
77*e985b929SDavid van Moolenbroek 	}
78*e985b929SDavid van Moolenbroek 	tt_assert(min_heap_size(&heap) == 512);
79*e985b929SDavid van Moolenbroek 
80*e985b929SDavid van Moolenbroek 	last_e = min_heap_pop(&heap);
81*e985b929SDavid van Moolenbroek 	while (1) {
82*e985b929SDavid van Moolenbroek 		e = min_heap_pop(&heap);
83*e985b929SDavid van Moolenbroek 		if (!e)
84*e985b929SDavid van Moolenbroek 			break;
85*e985b929SDavid van Moolenbroek 		tt_want(evutil_timercmp(&last_e->ev_timeout,
86*e985b929SDavid van Moolenbroek 			&e->ev_timeout, <=));
87*e985b929SDavid van Moolenbroek 	}
88*e985b929SDavid van Moolenbroek 	tt_assert(min_heap_size(&heap) == 0);
89*e985b929SDavid van Moolenbroek end:
90*e985b929SDavid van Moolenbroek 	for (i = 0; i < 1024; ++i)
91*e985b929SDavid van Moolenbroek 		free(inserted[i]);
92*e985b929SDavid van Moolenbroek 
93*e985b929SDavid van Moolenbroek 	min_heap_dtor(&heap);
94*e985b929SDavid van Moolenbroek }
95*e985b929SDavid van Moolenbroek 
96*e985b929SDavid van Moolenbroek struct testcase_t minheap_testcases[] = {
97*e985b929SDavid van Moolenbroek 	{ "randomized", test_heap_randomized, 0, NULL, NULL },
98*e985b929SDavid van Moolenbroek 	END_OF_TESTCASES
99*e985b929SDavid van Moolenbroek };
100