137 lines
4.0 KiB
C
137 lines
4.0 KiB
C
/* Implementation of selftests.
|
|
Copyright (C) 2015-2021 Free Software Foundation, Inc.
|
|
|
|
This file is part of GCC.
|
|
|
|
GCC 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, or (at your option) any later
|
|
version.
|
|
|
|
GCC 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 GCC; see the file COPYING3. If not see
|
|
<http://www.gnu.org/licenses/>. */
|
|
|
|
#include "config.h"
|
|
#include "system.h"
|
|
#include "coretypes.h"
|
|
#include "selftest.h"
|
|
#include "tree.h"
|
|
#include "target.h"
|
|
#include "langhooks.h"
|
|
#include "options.h"
|
|
#include "stringpool.h"
|
|
#include "attribs.h"
|
|
#include "analyzer/analyzer-selftests.h"
|
|
|
|
/* This function needed to be split out from selftest.c as it references
|
|
tests from the whole source tree, and so is within
|
|
OBJS in Makefile.in, whereas selftest.o is within OBJS-libcommon.
|
|
This allows us to embed tests within files in OBJS-libcommon without
|
|
introducing a dependency on objects within OBJS. */
|
|
|
|
#if CHECKING_P
|
|
|
|
/* Run all tests, aborting if any fail. */
|
|
|
|
void
|
|
selftest::run_tests ()
|
|
{
|
|
/* Makefile.in has -fself-test=$(srcdir)/testsuite/selftests, so that
|
|
flag_self_test contains the path to the selftest subdirectory of the
|
|
source tree (without a trailing slash). Copy it up to
|
|
path_to_selftest_files, to avoid selftest.c depending on
|
|
option-handling. */
|
|
path_to_selftest_files = flag_self_test;
|
|
|
|
test_runner r ("-fself-test");
|
|
|
|
/* Run all the tests, in hand-coded order of (approximate) dependencies:
|
|
run the tests for lowest-level code first. */
|
|
|
|
/* Sanity-check for selftests themselves. */
|
|
selftest_c_tests ();
|
|
|
|
/* Low-level data structures. */
|
|
bitmap_c_tests ();
|
|
sbitmap_c_tests ();
|
|
dumpfile_c_tests ();
|
|
et_forest_c_tests ();
|
|
hash_map_tests_c_tests ();
|
|
hash_set_tests_c_tests ();
|
|
vec_c_tests ();
|
|
pretty_print_c_tests ();
|
|
wide_int_cc_tests ();
|
|
ggc_tests_c_tests ();
|
|
sreal_c_tests ();
|
|
fibonacci_heap_c_tests ();
|
|
typed_splay_tree_c_tests ();
|
|
unique_ptr_tests_cc_tests ();
|
|
opt_proposer_c_tests ();
|
|
opts_c_tests ();
|
|
json_cc_tests ();
|
|
cgraph_c_tests ();
|
|
optinfo_emit_json_cc_tests ();
|
|
opt_problem_cc_tests ();
|
|
ordered_hash_map_tests_cc_tests ();
|
|
splay_tree_cc_tests ();
|
|
|
|
/* Mid-level data structures. */
|
|
input_c_tests ();
|
|
vec_perm_indices_c_tests ();
|
|
tree_c_tests ();
|
|
convert_c_tests ();
|
|
gimple_c_tests ();
|
|
rtl_tests_c_tests ();
|
|
read_rtl_function_c_tests ();
|
|
digraph_cc_tests ();
|
|
tristate_cc_tests ();
|
|
ipa_modref_tree_c_tests ();
|
|
|
|
/* Higher-level tests, or for components that other selftests don't
|
|
rely on. */
|
|
diagnostic_show_locus_c_tests ();
|
|
diagnostic_c_tests ();
|
|
diagnostic_format_json_cc_tests ();
|
|
edit_context_c_tests ();
|
|
fold_const_c_tests ();
|
|
spellcheck_c_tests ();
|
|
spellcheck_tree_c_tests ();
|
|
tree_cfg_c_tests ();
|
|
tree_diagnostic_path_cc_tests ();
|
|
attribute_c_tests ();
|
|
|
|
/* This one relies on most of the above. */
|
|
function_tests_c_tests ();
|
|
|
|
/* Run any target-specific selftests. */
|
|
if (targetm.run_target_selftests)
|
|
targetm.run_target_selftests ();
|
|
|
|
store_merging_c_tests ();
|
|
predict_c_tests ();
|
|
simplify_rtx_c_tests ();
|
|
dbgcnt_c_tests ();
|
|
|
|
/* Run any lang-specific selftests. */
|
|
lang_hooks.run_lang_selftests ();
|
|
|
|
/* Run the analyzer selftests (if enabled). */
|
|
ana::selftest::run_analyzer_selftests ();
|
|
|
|
/* Force a GC at the end of the selftests, to shake out GC-related
|
|
issues. For example, if any GC-managed items have buggy (or missing)
|
|
finalizers, this last collection will ensure that things that were
|
|
failed to be finalized can be detected by valgrind. */
|
|
forcibly_ggc_collect ();
|
|
|
|
/* Finished running tests; the test_runner dtor will print a summary. */
|
|
}
|
|
|
|
#endif /* #if CHECKING_P */
|