On Tue, 2014-09-23 at 15:32 -0600, Shuah Khan wrote: > Add kselftest framework for tests to use. This is a light > weight framework provides a set of interfaces to report test > results. Tests can use these interfaces to report pass, and > fail cases as well as when failure is due to configuration > problems such as missing modules, or when a test that is should > fail, fails as expected, and a test that should fail, passes. > The framework uses POSIX standard return codes for reporting > results to address the needs of users that want to run the kernel > selftests from their user-space test suites and want to know why a > test failed. In addition, the framework includes interfaces to use > to report test statistics on number of tests passed and failed. > > Signed-off-by: Shuah Khan <shuahkh@xxxxxxxxxxxxxxx> > --- > tools/testing/selftests/kselftest.h | 41 +++++++++++++++++++++++++++++++++++++ > 1 file changed, 41 insertions(+) > create mode 100644 tools/testing/selftests/kselftest.h > > diff --git a/tools/testing/selftests/kselftest.h b/tools/testing/selftests/kselftest.h > new file mode 100644 > index 0000000..c73fc2c > --- /dev/null > +++ b/tools/testing/selftests/kselftest.h > @@ -0,0 +1,41 @@ > +/* > + * kselftest.h: kselftest framework return codes to include from > + * selftests. > + * > + * Copyright (c) 2014 Shuah Khan <shuahkh@xxxxxxxxxxxxxxx> > + * Copyright (c) 2014 Samsung Electronics Co., Ltd. > + * > + * This file is released under the GPLv2. > + */ > +#ifndef __KSELFTEST_H > +#define __KSELFTEST_H > + > +#include <stdlib.h> > +#include <unistd.h> > + > +/* counters */ > +static int ksft_pass; > +static int ksft_fail; > +static int ksft_xfail; > +static int ksft_xpass; > +static int ksft_xskip; unsigned int? > +static inline void ksft_inc_pass_cnt(void) { ksft_pass++; } > +static inline void ksft_inc_fail_cnt(void) { ksft_fail++; } > +static inline void ksft_inc_xfail_cnt(void) { ksft_xfail++; } > +static inline void ksft_inc_xpass_cnt(void) { ksft_xpass++; } > +static inline void ksft_inc_xskip_cnt(void) { ksft_xskip++; } It would probably make sense to have the counters in a structures, something like: struct ksft_counter { ... } ksft_cnt; Then just pass it around the proposed functions as arguments. That also minimizes a bit the global variables and would allow you to easily change it in the future. > +static inline void ksft_print_cnts(void) > +{ > + printf("Pass: %d Fail: %d Xfail: %d Xpass: %d, Xskip: %d\n", > + ksft_pass, ksft_fail, ksft_xfail, ksft_xpass, ksft_xskip); > +} Same here, just do: static inline void ksft_print_cnts(struct ksft_counter counters) { ... } Otherwise looks good. > +static inline int ksft_exit_pass(void) { exit(0); } > +static inline int ksft_exit_fail(void) { exit(1); } > +static inline int ksft_exit_xfail(void) { exit(2); } > +static inline int ksft_exit_xpass(void) { exit(3); } > +static inline int ksft_exit_skip(void) { exit(4); } > + > +#endif /* __KSELFTEST_H */ -- To unsubscribe from this list: send the line "unsubscribe linux-api" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html