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