xref: /freebsd-src/contrib/netbsd-tests/lib/libc/gen/t_randomid.c (revision c22165b4f1f5d38b681921797a44b3ba8c13b7e0)
1*640235e2SEnji Cooper /* $NetBSD: t_randomid.c,v 1.5 2015/03/07 09:59:15 isaki Exp $ */
257718be8SEnji Cooper 
357718be8SEnji Cooper /*-
457718be8SEnji Cooper  * Copyright (c) 2010 The NetBSD Foundation, Inc.
557718be8SEnji Cooper  * All rights reserved.
657718be8SEnji Cooper  *
757718be8SEnji Cooper  * Redistribution and use in source and binary forms, with or without
857718be8SEnji Cooper  * modification, are permitted provided that the following conditions
957718be8SEnji Cooper  * are met:
1057718be8SEnji Cooper  * 1. Redistributions of source code must retain the above copyright
1157718be8SEnji Cooper  *    notice, this list of conditions and the following disclaimer.
1257718be8SEnji Cooper  * 2. Redistributions in binary form must reproduce the above copyright
1357718be8SEnji Cooper  *    notice, this list of conditions and the following disclaimer in the
1457718be8SEnji Cooper  *    documentation and/or other materials provided with the distribution.
1557718be8SEnji Cooper  *
1657718be8SEnji Cooper  * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
1757718be8SEnji Cooper  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
1857718be8SEnji Cooper  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
1957718be8SEnji Cooper  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
2057718be8SEnji Cooper  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
2157718be8SEnji Cooper  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
2257718be8SEnji Cooper  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
2357718be8SEnji Cooper  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
2457718be8SEnji Cooper  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
2557718be8SEnji Cooper  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
2657718be8SEnji Cooper  * POSSIBILITY OF SUCH DAMAGE.
2757718be8SEnji Cooper  */
2857718be8SEnji Cooper 
2957718be8SEnji Cooper #include <atf-c.h>
3057718be8SEnji Cooper 
3157718be8SEnji Cooper #include <sys/types.h>
3257718be8SEnji Cooper 
3357718be8SEnji Cooper #include <assert.h>
3457718be8SEnji Cooper #include <inttypes.h>
3557718be8SEnji Cooper #include <randomid.h>
3657718be8SEnji Cooper #include <stdio.h>
3757718be8SEnji Cooper #include <string.h>
3857718be8SEnji Cooper 
3957718be8SEnji Cooper #define	PERIOD		30000
4057718be8SEnji Cooper 
41*640235e2SEnji Cooper uint32_t last[65536];
4257718be8SEnji Cooper 
4357718be8SEnji Cooper ATF_TC(randomid_basic);
ATF_TC_HEAD(randomid_basic,tc)4457718be8SEnji Cooper ATF_TC_HEAD(randomid_basic, tc)
4557718be8SEnji Cooper {
4657718be8SEnji Cooper 
4757718be8SEnji Cooper 	atf_tc_set_md_var(tc, "descr", "Check randomid(3)");
4857718be8SEnji Cooper }
4957718be8SEnji Cooper 
ATF_TC_BODY(randomid_basic,tc)5057718be8SEnji Cooper ATF_TC_BODY(randomid_basic, tc)
5157718be8SEnji Cooper {
5257718be8SEnji Cooper 	static randomid_t ctx = NULL;
53*640235e2SEnji Cooper 	uint32_t lowest, n, diff;
5457718be8SEnji Cooper 	uint16_t id;
5557718be8SEnji Cooper 
5657718be8SEnji Cooper 	memset(last, 0, sizeof(last));
5757718be8SEnji Cooper 	ctx = randomid_new(16, (long)3600);
5857718be8SEnji Cooper 
59*640235e2SEnji Cooper 	lowest = UINT32_MAX;
6057718be8SEnji Cooper 
61*640235e2SEnji Cooper 	for (n = 0; n < 100000; n++) {
6257718be8SEnji Cooper 		id = randomid(ctx);
6357718be8SEnji Cooper 
6457718be8SEnji Cooper 		if (last[id] > 0) {
6557718be8SEnji Cooper 			diff = n - last[id];
6657718be8SEnji Cooper 
6757718be8SEnji Cooper 			if (diff <= lowest) {
68*640235e2SEnji Cooper 				if (lowest != UINT32_MAX)
69*640235e2SEnji Cooper 					printf("id %5d: last call at %9"PRIu32
70*640235e2SEnji Cooper 					    ", current call %9"PRIu32
71*640235e2SEnji Cooper 					    " (diff %5"PRIu32"), "
72*640235e2SEnji Cooper 					    "lowest %"PRIu32"\n",
7357718be8SEnji Cooper 					    id, last[id], n, diff, lowest);
7457718be8SEnji Cooper 
7557718be8SEnji Cooper 				ATF_REQUIRE_MSG(diff >= PERIOD,
76*640235e2SEnji Cooper 				    "diff (%"PRIu32") less than minimum "
7757718be8SEnji Cooper 				    "period (%d)", diff, PERIOD);
7857718be8SEnji Cooper 
7957718be8SEnji Cooper 				lowest = diff;
8057718be8SEnji Cooper 			}
8157718be8SEnji Cooper 		}
8257718be8SEnji Cooper 
8357718be8SEnji Cooper 		last[id] = n;
8457718be8SEnji Cooper 	}
8557718be8SEnji Cooper }
8657718be8SEnji Cooper 
ATF_TP_ADD_TCS(tp)8757718be8SEnji Cooper ATF_TP_ADD_TCS(tp)
8857718be8SEnji Cooper {
8957718be8SEnji Cooper 
9057718be8SEnji Cooper 	ATF_TP_ADD_TC(tp, randomid_basic);
9157718be8SEnji Cooper 
9257718be8SEnji Cooper 	return atf_no_error();
9357718be8SEnji Cooper }
94