mirror of
git://sourceware.org/git/libabigail.git
synced 2025-02-04 07:41:48 +00:00
0fb03efa85
* update-copyright.sh: Update the date in this script. Running the script then yields the changes below. * include/abg-btf-reader.h: Update copyright year as a result of running update-copyright.sh above. * include/abg-comp-filter.h: Likewise. * include/abg-comparison.h: Likewise. * include/abg-config.h: Likewise. * include/abg-corpus.h: Likewise. * include/abg-ctf-reader.h: Likewise. * include/abg-cxx-compat.h: Likewise. * include/abg-diff-utils.h: Likewise. * include/abg-dwarf-reader.h: Likewise. * include/abg-elf-based-reader.h: Likewise. * include/abg-elf-reader.h: Likewise. * include/abg-fe-iface.h: Likewise. * include/abg-fwd.h: Likewise. * include/abg-hash.h: Likewise. * include/abg-ini.h: Likewise. * include/abg-interned-str.h: Likewise. * include/abg-ir.h: Likewise. * include/abg-libxml-utils.h: Likewise. * include/abg-reader.h: Likewise. * include/abg-regex.h: Likewise. * include/abg-reporter.h: Likewise. * include/abg-sptr-utils.h: Likewise. * include/abg-suppression.h: Likewise. * include/abg-tools-utils.h: Likewise. * include/abg-traverse.h: Likewise. * include/abg-viz-common.h: Likewise. * include/abg-viz-dot.h: Likewise. * include/abg-viz-svg.h: Likewise. * include/abg-workers.h: Likewise. * include/abg-writer.h: Likewise. * src/abg-btf-reader.cc: Likewise. * src/abg-comp-filter.cc: Likewise. * src/abg-comparison-priv.h: Likewise. * src/abg-comparison.cc: Likewise. * src/abg-config.cc: Likewise. * src/abg-corpus-priv.h: Likewise. * src/abg-corpus.cc: Likewise. * src/abg-ctf-reader.cc: Likewise. * src/abg-default-reporter.cc: Likewise. * src/abg-diff-utils.cc: Likewise. * src/abg-dwarf-reader.cc: Likewise. * src/abg-elf-based-reader.cc: Likewise. * src/abg-elf-helpers.cc: Likewise. * src/abg-elf-helpers.h: Likewise. * src/abg-elf-reader.cc: Likewise. * src/abg-fe-iface.cc: Likewise. * src/abg-hash.cc: Likewise. * src/abg-ini.cc: Likewise. * src/abg-internal.h: Likewise. * src/abg-ir-priv.h: Likewise. * src/abg-ir.cc: Likewise. * src/abg-leaf-reporter.cc: Likewise. * src/abg-libxml-utils.cc: Likewise. * src/abg-reader.cc: Likewise. * src/abg-regex.cc: Likewise. * src/abg-reporter-priv.cc: Likewise. * src/abg-reporter-priv.h: Likewise. * src/abg-suppression-priv.h: Likewise. * src/abg-suppression.cc: Likewise. * src/abg-symtab-reader.cc: Likewise. * src/abg-symtab-reader.h: Likewise. * src/abg-tools-utils.cc: Likewise. * src/abg-traverse.cc: Likewise. * src/abg-viz-common.cc: Likewise. * src/abg-viz-dot.cc: Likewise. * src/abg-viz-svg.cc: Likewise. * src/abg-workers.cc: Likewise. * src/abg-writer.cc: Likewise. * tests/print-diff-tree.cc: Likewise. * tests/test-abicompat.cc: Likewise. * tests/test-abidiff-exit.cc: Likewise. * tests/test-abidiff.cc: Likewise. * tests/test-alt-dwarf-file.cc: Likewise. * tests/test-core-diff.cc: Likewise. * tests/test-cxx-compat.cc: Likewise. * tests/test-diff-dwarf-abixml.cc: Likewise. * tests/test-diff-dwarf.cc: Likewise. * tests/test-diff-filter.cc: Likewise. * tests/test-diff-pkg.cc: Likewise. * tests/test-diff-suppr.cc: Likewise. * tests/test-diff2.cc: Likewise. * tests/test-dot.cc: Likewise. * tests/test-elf-helpers.cc: Likewise. * tests/test-ini.cc: Likewise. * tests/test-ir-walker.cc: Likewise. * tests/test-kmi-whitelist.cc: Likewise. * tests/test-lookup-syms.cc: Likewise. * tests/test-read-btf.cc: Likewise. * tests/test-read-ctf.cc: Likewise. * tests/test-read-dwarf.cc: Likewise. * tests/test-read-write.cc: Likewise. * tests/test-svg.cc: Likewise. * tests/test-symtab-reader.cc: Likewise. * tests/test-symtab.cc: Likewise. * tests/test-tools-utils.cc: Likewise. * tests/test-types-stability.cc: Likewise. * tests/test-utils.cc: Likewise. * tests/test-utils.h: Likewise. * tools/abicompat.cc: Likewise. * tools/abidiff.cc: Likewise. * tools/abidw.cc: Likewise. * tools/abilint.cc: Likewise. * tools/abipkgdiff.cc: Likewise. * tools/abisym.cc: Likewise. * tools/binilint.cc: Likewise. * tools/fedabipkgdiff: Likewise. * tools/kmidiff.cc: Likewise. Signed-off-by: Dodji Seketeli <dodji@redhat.com>
406 lines
14 KiB
C++
406 lines
14 KiB
C++
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
// -*- Mode: C++ -*-
|
|
//
|
|
// Copyright (C) 2014-2024 Red Hat, Inc.
|
|
//
|
|
// Author: Dodji Seketeli
|
|
|
|
/// @file
|
|
///
|
|
/// Given a program P that links against a library L of version V
|
|
/// denoted L(V), this program checks if P is still ABI compatible
|
|
/// with a subsequent version of L denoted L(V+N), N being a positive
|
|
/// integer. The result of the check is a report that is compared
|
|
/// against a reference report. This program actually performs these
|
|
/// checks for a variety of tuple {P, L(V), L(V+N)}
|
|
///
|
|
/// The set of input files and reference reports to consider should be
|
|
/// present in the source distribution.
|
|
|
|
#include <cstring>
|
|
#include <string>
|
|
#include <fstream>
|
|
#include <iostream>
|
|
#include <cstdlib>
|
|
#include "abg-tools-utils.h"
|
|
#include "test-utils.h"
|
|
|
|
using std::string;
|
|
using std::cerr;
|
|
using std::cout;
|
|
using abigail::tools_utils::abidiff_status;
|
|
|
|
struct InOutSpec
|
|
{
|
|
const char* in_app_path;
|
|
const char* in_lib1_path;
|
|
const char* in_lib2_path;
|
|
const char* suppressions;
|
|
const char* options;
|
|
abidiff_status status;
|
|
const char* in_report_path;
|
|
const char* out_report_path;
|
|
};
|
|
|
|
InOutSpec in_out_specs[] =
|
|
{
|
|
{
|
|
"data/test-abicompat/test0-fn-changed-app",
|
|
"data/test-abicompat/libtest0-fn-changed-libapp-v0.so",
|
|
"data/test-abicompat/libtest0-fn-changed-libapp-v1.so",
|
|
"",
|
|
"--show-base-names --no-show-locs --no-redundant",
|
|
abigail::tools_utils::ABIDIFF_ABI_CHANGE,
|
|
"data/test-abicompat/test0-fn-changed-report-0.txt",
|
|
"output/test-abicompat/test0-fn-changed-report-0.txt",
|
|
},
|
|
{
|
|
"data/test-abicompat/test0-fn-changed-app",
|
|
"data/test-abicompat/libtest0-fn-changed-libapp-v0.so",
|
|
"data/test-abicompat/libtest0-fn-changed-libapp-v1.so",
|
|
"data/test-abicompat/test0-fn-changed-0.suppr",
|
|
"--show-base-names --no-show-locs --no-redundant",
|
|
abigail::tools_utils::ABIDIFF_OK,
|
|
"data/test-abicompat/test0-fn-changed-report-1.txt",
|
|
"output/test-abicompat/test0-fn-changed-report-1.txt",
|
|
},
|
|
{ // Previous test, but emitting loc info.
|
|
"data/test-abicompat/test0-fn-changed-app",
|
|
"data/test-abicompat/libtest0-fn-changed-libapp-v0.so",
|
|
"data/test-abicompat/libtest0-fn-changed-libapp-v1.so",
|
|
"",
|
|
"--show-base-names --no-redundant",
|
|
abigail::tools_utils::ABIDIFF_ABI_CHANGE,
|
|
"data/test-abicompat/test0-fn-changed-report-2.txt",
|
|
"output/test-abicompat/test0-fn-changed-report-2.txt",
|
|
},
|
|
{
|
|
"data/test-abicompat/test0-fn-changed-app",
|
|
"data/test-abicompat/libtest0-fn-changed-libapp-v0.so",
|
|
"data/test-abicompat/libtest0-fn-changed-libapp-v1.so",
|
|
"data/test-abicompat/test0-fn-changed-1.suppr",
|
|
"--show-base-names --no-show-locs --no-redundant",
|
|
abigail::tools_utils::ABIDIFF_OK,
|
|
"data/test-abicompat/test0-fn-changed-report-3.txt",
|
|
"output/test-abicompat/test0-fn-changed-report-3.txt",
|
|
},
|
|
{
|
|
"data/test-abicompat/test1-fn-removed-app",
|
|
"data/test-abicompat/libtest1-fn-removed-v0.so",
|
|
"data/test-abicompat/libtest1-fn-removed-v1.so",
|
|
"",
|
|
"--show-base-names --no-show-locs --no-redundant",
|
|
abigail::tools_utils::ABIDIFF_ABI_CHANGE
|
|
| abigail::tools_utils::ABIDIFF_ABI_INCOMPATIBLE_CHANGE,
|
|
"data/test-abicompat/test1-fn-removed-report-0.txt",
|
|
"output/test-abicompat/test1-fn-removed-report-0.txt",
|
|
},
|
|
{
|
|
"data/test-abicompat/test2-var-removed-app",
|
|
"data/test-abicompat/libtest2-var-removed-v0.so",
|
|
"data/test-abicompat/libtest2-var-removed-v1.so",
|
|
"",
|
|
"--show-base-names --no-show-locs --no-redundant",
|
|
abigail::tools_utils::ABIDIFF_ABI_CHANGE
|
|
| abigail::tools_utils::ABIDIFF_ABI_INCOMPATIBLE_CHANGE,
|
|
"data/test-abicompat/test2-var-removed-report-0.txt",
|
|
"output/test-abicompat/test2-var-removed-report-0.txt",
|
|
},
|
|
{
|
|
"data/test-abicompat/test3-fn-removed-app",
|
|
"data/test-abicompat/libtest3-fn-removed-v0.so",
|
|
"data/test-abicompat/libtest3-fn-removed-v1.so",
|
|
"",
|
|
"--show-base-names --no-show-locs --no-redundant",
|
|
abigail::tools_utils::ABIDIFF_ABI_CHANGE
|
|
| abigail::tools_utils::ABIDIFF_ABI_INCOMPATIBLE_CHANGE,
|
|
"data/test-abicompat/test3-fn-removed-report-0.txt",
|
|
"output/test-abicompat/test3-fn-removed-report-0.txt",
|
|
},
|
|
{
|
|
"data/test-abicompat/test4-soname-changed-app",
|
|
"data/test-abicompat/libtest4-soname-changed-v0.so",
|
|
"data/test-abicompat/libtest4-soname-changed-v1.so",
|
|
"",
|
|
"--show-base-names --no-show-locs --no-redundant",
|
|
abigail::tools_utils::ABIDIFF_ABI_CHANGE
|
|
| abigail::tools_utils::ABIDIFF_ABI_INCOMPATIBLE_CHANGE,
|
|
"data/test-abicompat/test4-soname-changed-report-0.txt",
|
|
"output/test-abicompat/test4-soname-changed-report-0.txt",
|
|
},
|
|
{
|
|
"data/test-abicompat/test5-fn-changed-app",
|
|
"data/test-abicompat/libtest5-fn-changed-libapp-v1.so",
|
|
"",
|
|
"",
|
|
"--show-base-names --no-show-locs --weak-mode",
|
|
abigail::tools_utils::ABIDIFF_ABI_CHANGE,
|
|
"data/test-abicompat/test5-fn-changed-report-0.txt",
|
|
"output/test-abicompat/test5-fn-changed-report-0.txt",
|
|
},
|
|
{ // Previous test, but emitting loc info.
|
|
"data/test-abicompat/test5-fn-changed-app",
|
|
"data/test-abicompat/libtest5-fn-changed-libapp-v1.so",
|
|
"",
|
|
"",
|
|
"--show-base-names --weak-mode",
|
|
abigail::tools_utils::ABIDIFF_ABI_CHANGE,
|
|
"data/test-abicompat/test5-fn-changed-report-1.txt",
|
|
"output/test-abicompat/test5-fn-changed-report-1.txt",
|
|
},
|
|
{
|
|
"data/test-abicompat/libtest6-undefined-var.so",
|
|
"data/test-abicompat/libtest6-var-changed-libapp-v1.so",
|
|
"",
|
|
"",
|
|
"--show-base-names --no-show-locs --weak-mode",
|
|
abigail::tools_utils::ABIDIFF_ABI_CHANGE,
|
|
"data/test-abicompat/test6-var-changed-report-0.txt",
|
|
"output/test-abicompat/test6-var-changed-report-0.txt",
|
|
},
|
|
{ // Previous test, but emitting loc info.
|
|
"data/test-abicompat/libtest6-undefined-var.so",
|
|
"data/test-abicompat/libtest6-var-changed-libapp-v1.so",
|
|
"",
|
|
"",
|
|
"--show-base-names --weak-mode",
|
|
abigail::tools_utils::ABIDIFF_ABI_CHANGE,
|
|
"data/test-abicompat/test6-var-changed-report-1.txt",
|
|
"output/test-abicompat/test6-var-changed-report-1.txt",
|
|
},
|
|
{ // Previous test, but in reverse direction.
|
|
"data/test-abicompat/libtest6-var-changed-libapp-v1.so",
|
|
"data/test-abicompat/libtest6-undefined-var.so",
|
|
"",
|
|
"",
|
|
"--show-base-names --weak-mode",
|
|
abigail::tools_utils::ABIDIFF_ABI_CHANGE,
|
|
"data/test-abicompat/test6-var-changed-report-2.txt",
|
|
"output/test-abicompat/test6-var-changed-report-2.txt",
|
|
},
|
|
{
|
|
"data/test-abicompat/test7-fn-changed-app",
|
|
"data/test-abicompat/libtest7-fn-changed-libapp-v0.so",
|
|
"data/test-abicompat/libtest7-fn-changed-libapp-v1.so",
|
|
"",
|
|
"--show-base-names --no-show-locs --no-redundant",
|
|
abigail::tools_utils::ABIDIFF_ABI_CHANGE,
|
|
"data/test-abicompat/test7-fn-changed-report-0.txt",
|
|
"output/test-abicompat/test7-fn-changed-report-0.txt",
|
|
},
|
|
#ifdef WITH_BTF
|
|
{
|
|
"data/test-abicompat/test7-fn-changed-app.btf",
|
|
"data/test-abicompat/libtest7-fn-changed-libapp-btf-v0.so",
|
|
"data/test-abicompat/libtest7-fn-changed-libapp-btf-v1.so",
|
|
"",
|
|
"--show-base-names --no-show-locs --no-redundant --btf",
|
|
abigail::tools_utils::ABIDIFF_ABI_CHANGE,
|
|
"data/test-abicompat/test7-fn-changed-report-0.1.txt",
|
|
"output/test-abicompat/test7-fn-changed-report-0.1.txt",
|
|
},
|
|
#endif
|
|
{
|
|
"data/test-abicompat/test7-fn-changed-app",
|
|
"data/test-abicompat/libtest7-fn-changed-libapp-v1.so",
|
|
"",
|
|
"",
|
|
"--show-base-names --no-show-locs --weak-mode",
|
|
abigail::tools_utils::ABIDIFF_ABI_CHANGE,
|
|
"data/test-abicompat/test7-fn-changed-report-1.txt",
|
|
"output/test-abicompat/test7-fn-changed-report-1.txt",
|
|
},
|
|
{ // Previous test, but emitting loc info.
|
|
"data/test-abicompat/test7-fn-changed-app",
|
|
"data/test-abicompat/libtest7-fn-changed-libapp-v1.so",
|
|
"",
|
|
"",
|
|
"--show-base-names --weak-mode",
|
|
abigail::tools_utils::ABIDIFF_ABI_CHANGE,
|
|
"data/test-abicompat/test7-fn-changed-report-2.txt",
|
|
"output/test-abicompat/test7-fn-changed-report-2.txt",
|
|
},
|
|
#ifdef WITH_BTF
|
|
{
|
|
"data/test-abicompat/test7-fn-changed-app.btf",
|
|
"data/test-abicompat/libtest7-fn-changed-libapp-btf-v1.so",
|
|
"",
|
|
"",
|
|
"--show-base-names --no-show-locs --weak-mode",
|
|
abigail::tools_utils::ABIDIFF_ABI_CHANGE,
|
|
"data/test-abicompat/test7-fn-changed-report-2.1.txt",
|
|
"output/test-abicompat/test7-fn-changed-report-2.1.txt",
|
|
},
|
|
#endif
|
|
{
|
|
"data/test-abicompat/test8-fn-changed-app",
|
|
"data/test-abicompat/libtest8-fn-changed-libapp-v1.so",
|
|
"",
|
|
"",
|
|
"--show-base-names --weak-mode",
|
|
abigail::tools_utils::ABIDIFF_ABI_CHANGE,
|
|
"data/test-abicompat/test8-fn-changed-report-0.txt",
|
|
"output/test-abicompat/test8-fn-changed-report-0.txt",
|
|
},
|
|
{
|
|
"data/test-abicompat/test9-fn-changed-app",
|
|
"data/test-abicompat/libtest9-fn-changed-v1.so ",
|
|
"",
|
|
"",
|
|
"--show-base-names --weak-mode",
|
|
abigail::tools_utils::ABIDIFF_ABI_CHANGE,
|
|
"data/test-abicompat/test9-fn-changed-report-0.txt",
|
|
"output/test-abicompat/test9-fn-changed-report-0.txt",
|
|
},
|
|
{
|
|
"data/test-abicompat/test10/test10-app-with-undefined-symbols",
|
|
"data/test-abicompat/test10/libtest10-with-exported-symbols.so",
|
|
"",
|
|
"",
|
|
"--show-base-names",
|
|
abigail::tools_utils::ABIDIFF_OK,
|
|
"data/test-abicompat/test10/test10-fn-changed-report-0.txt",
|
|
"output/test-abicompat/test10/test10-fn-changed-report-0.txt",
|
|
},
|
|
{
|
|
"data/test-abicompat/test10/test10-app-with-undefined-symbols.abi",
|
|
"data/test-abicompat/test10/libtest10-with-exported-symbols.so",
|
|
"",
|
|
"",
|
|
"--show-base-names",
|
|
abigail::tools_utils::ABIDIFF_OK,
|
|
"data/test-abicompat/test10/test10-fn-changed-report-0.txt",
|
|
"output/test-abicompat/test10/test10-fn-changed-report-0.txt",
|
|
},
|
|
{
|
|
"data/test-abicompat/test10/test10-app-with-undefined-symbols",
|
|
"data/test-abicompat/test10/libtest10-with-incompatible-exported-symbols.so",
|
|
"",
|
|
"",
|
|
"--show-base-names",
|
|
abigail::tools_utils::ABIDIFF_ABI_CHANGE,
|
|
"data/test-abicompat/test10/test10-fn-changed-report-1.txt",
|
|
"output/test-abicompat/test10/test10-fn-changed-report-1.txt",
|
|
},
|
|
{
|
|
"data/test-abicompat/test10/test10-app-with-undefined-symbols",
|
|
"data/test-abicompat/test10/libtest10-with-incompatible-exported-symbols.so.abi",
|
|
"",
|
|
"",
|
|
"--show-base-names",
|
|
abigail::tools_utils::ABIDIFF_ABI_CHANGE,
|
|
"data/test-abicompat/test10/test10-fn-changed-report-2.txt",
|
|
"output/test-abicompat/test10/test10-fn-changed-report-2.txt",
|
|
},
|
|
{
|
|
"data/test-abicompat/test10/test10-app-with-undefined-symbols.abi",
|
|
"data/test-abicompat/test10/libtest10-with-incompatible-exported-symbols.so",
|
|
"",
|
|
"",
|
|
"--show-base-names",
|
|
abigail::tools_utils::ABIDIFF_ABI_CHANGE,
|
|
"data/test-abicompat/test10/test10-fn-changed-report-3.txt",
|
|
"output/test-abicompat/test10/test10-fn-changed-report-3.txt",
|
|
},
|
|
{
|
|
"data/test-abicompat/test10/test10-app-with-undefined-symbols.abi",
|
|
"data/test-abicompat/test10/libtest10-with-incompatible-exported-symbols.so.abi",
|
|
"",
|
|
"",
|
|
"--show-base-names",
|
|
abigail::tools_utils::ABIDIFF_ABI_CHANGE,
|
|
"data/test-abicompat/test10/test10-fn-changed-report-4.txt",
|
|
"output/test-abicompat/test10/test10-fn-changed-report-4.txt",
|
|
},
|
|
// This entry must be the last one.
|
|
{0, 0, 0, 0, 0, abigail::tools_utils::ABIDIFF_OK, 0, 0}
|
|
};
|
|
|
|
int
|
|
main()
|
|
{
|
|
using abigail::tests::get_src_dir;
|
|
using abigail::tests::get_build_dir;
|
|
using abigail::tools_utils::ensure_parent_dir_created;
|
|
using abigail::tools_utils::abidiff_status;
|
|
|
|
unsigned int cnt_total = 0, cnt_passed = 0, cnt_failed = 0;
|
|
string in_app_path, in_lib1_path, in_lib2_path, suppression_path,
|
|
abicompat_options, ref_report_path, out_report_path, abicompat, cmd, diffcmd;
|
|
|
|
for (InOutSpec* s = in_out_specs; s->in_app_path; ++s)
|
|
{
|
|
bool is_ok = true;
|
|
in_app_path = string(get_src_dir()) + "/tests/" + s->in_app_path;
|
|
in_lib1_path = string(get_src_dir()) + "/tests/" + s->in_lib1_path;
|
|
if (s->in_lib2_path && strcmp(s->in_lib2_path, ""))
|
|
in_lib2_path = string(get_src_dir()) + "/tests/" + s->in_lib2_path;
|
|
else
|
|
in_lib2_path.clear();
|
|
if (s->suppressions == 0 || !strcmp(s->suppressions, ""))
|
|
suppression_path.clear();
|
|
else
|
|
suppression_path = string(get_src_dir()) + "/tests/" + s->suppressions;
|
|
abicompat_options = s->options;
|
|
ref_report_path = string(get_src_dir()) + "/tests/" + s->in_report_path;
|
|
out_report_path =
|
|
string(get_build_dir()) + "/tests/" + s->out_report_path;
|
|
|
|
if (!ensure_parent_dir_created(out_report_path))
|
|
{
|
|
cerr << "could not create parent directory for "
|
|
<< out_report_path;
|
|
is_ok = false;
|
|
continue;
|
|
}
|
|
|
|
abicompat = string(get_build_dir()) + "/tools/abicompat";
|
|
if (!suppression_path.empty())
|
|
abicompat += " --suppressions " + suppression_path;
|
|
abicompat += " " + abicompat_options;
|
|
|
|
cmd = abicompat + " " + in_app_path + " " + in_lib1_path;
|
|
if (!in_lib2_path.empty())
|
|
cmd += string(" ") + in_lib2_path;
|
|
|
|
cmd += " > " + out_report_path;
|
|
|
|
bool abicompat_ok = true;
|
|
int code = system(cmd.c_str());
|
|
abidiff_status status = static_cast<abidiff_status>(WEXITSTATUS(code));
|
|
if (status != s->status)
|
|
abicompat_ok = false;
|
|
|
|
if (abicompat_ok)
|
|
{
|
|
diffcmd = "diff -u " + ref_report_path + " " + out_report_path;
|
|
if (system(diffcmd.c_str()))
|
|
is_ok = false;
|
|
}
|
|
else
|
|
is_ok = false;
|
|
|
|
if (is_ok)
|
|
cnt_passed++;
|
|
else
|
|
{
|
|
cout << BRIGHT_RED_COLOR
|
|
<< "Test Failed:"
|
|
<< DEFAULT_TERMINAL_COLOR
|
|
<< cmd
|
|
<< std::endl;
|
|
if (status != s->status)
|
|
cout << BRIGHT_RED_COLOR
|
|
<< "expected abicompat exit code: " << s->status << ", got: " << status << std::endl;
|
|
cnt_failed++;
|
|
}
|
|
cnt_total++;
|
|
}
|
|
cout << "Summary: " << cnt_total << " tested!"
|
|
<< " Test Passed: " << cnt_passed
|
|
<< ", Test Failed: " << cnt_failed
|
|
<< ".\n";
|
|
|
|
return cnt_failed;
|
|
}
|