1 /* $NetBSD: driver.h,v 1.4 2014/12/10 04:37:53 christos Exp $ */ 2 3 /* 4 * Copyright (C) 2004, 2007 Internet Systems Consortium, Inc. ("ISC") 5 * Copyright (C) 2000, 2001 Internet Software Consortium. 6 * 7 * Permission to use, copy, modify, and/or distribute this software for any 8 * purpose with or without fee is hereby granted, provided that the above 9 * copyright notice and this permission notice appear in all copies. 10 * 11 * THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES WITH 12 * REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY 13 * AND FITNESS. IN NO EVENT SHALL ISC BE LIABLE FOR ANY SPECIAL, DIRECT, 14 * INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM 15 * LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE 16 * OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR 17 * PERFORMANCE OF THIS SOFTWARE. 18 */ 19 20 /* Id: driver.h,v 1.8 2007/06/19 23:47:00 tbox Exp */ 21 22 /* 23 * PASSED and FAILED mean the particular test passed or failed. 24 * 25 * UNKNOWN means that for one reason or another, the test process itself 26 * failed. For instance, missing files, error when parsing files or 27 * IP addresses, etc. That is, the test itself is broken, not what is 28 * being tested. 29 * 30 * UNTESTED means the test was unable to be run because a prerequisite test 31 * failed, the test is disabled, or the test needs a system component 32 * (for instance, Perl) and cannot run. 33 */ 34 typedef enum { 35 PASSED = 0, 36 FAILED = 1, 37 UNKNOWN = 2, 38 UNTESTED = 3 39 } test_result_t; 40 41 typedef test_result_t (*test_func_t)(void); 42 43 typedef struct { 44 const char *tag; 45 const char *description; 46 test_func_t func; 47 } test_t; 48 49 #define TESTDECL(name) test_result_t name(void) 50 51