dcd1f97951
I wanted to unit test the Rust lexer, so I added a simple unit testing command to gdb. The intent is that self tests will only be compiled into gdb in development mode. In release mode they simply won't exist. So, this exposes $development to C code as GDB_SELF_TEST. In development mode, test functions are registered with the self test module. A test function is just a function that does some checks, and throws an exception on failure. Then this adds a new "maint selftest" command which invokes the test functions, and a new dejagnu test case that invokes it. 2016-05-17 Tom Tromey <tom@tromey.com> * NEWS: Add "maint selftest" entry. * selftest.h: New file. * selftest.c: New file. * maint.c: Include selftest.h. (maintenance_selftest): New function. (_initialize_maint_cmds): Add "maint selftest" command. * configure.ac (GDB_SELF_TEST): Maybe define. * config.in, configure: Rebuild. * Makefile.in (SFILES): Add selftest.c. (COMMON_OBS): Add selftest.o. 2016-05-17 Tom Tromey <tom@tromey.com> * gdb.texinfo (Maintenance Commands): Document "maint selftest". 2016-05-17 Tom Tromey <tom@tromey.com> * gdb.gdb/unittest.exp: New file.
45 lines
1.4 KiB
C
45 lines
1.4 KiB
C
/* GDB self-testing.
|
|
Copyright (C) 2016 Free Software Foundation, Inc.
|
|
|
|
This file is part of GDB.
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation; either version 3 of the License, or
|
|
(at your option) any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>. */
|
|
|
|
#ifndef SELFTEST_H
|
|
#define SELFTEST_H
|
|
|
|
/* A test is just a function that does some checks and throws an
|
|
exception if something has gone wrong. */
|
|
|
|
typedef void self_test_function (void);
|
|
|
|
/* Register a new self-test. */
|
|
|
|
extern void register_self_test (self_test_function *function);
|
|
|
|
/* Run all the self tests. This print a message describing the number
|
|
of test and the number of failures. */
|
|
|
|
extern void run_self_tests (void);
|
|
|
|
/* Check that VALUE is true, and, if not, throw an exception. */
|
|
|
|
#define SELF_CHECK(VALUE) \
|
|
do { \
|
|
if (!(VALUE)) \
|
|
error (_("self-test failed at %s:%d"), __FILE__, __LINE__); \
|
|
} while (0)
|
|
|
|
#endif /* SELFTEST_H */
|