2009-06-12 Tristan Gingold <gingold@adacore.com>
[binutils.git] / gold / testsuite / test.h
blob37060d3a486a7facdb6008e489ca8f44b17ce216
1 // test.h -- simplistic test framework for gold unittests -*- C++ -*-
3 // Copyright 2006, 2007, 2008 Free Software Foundation, Inc.
4 // Written by Ian Lance Taylor <iant@google.com>.
6 // This file is part of gold.
8 // This program is free software; you can redistribute it and/or modify
9 // it under the terms of the GNU General Public License as published by
10 // the Free Software Foundation; either version 3 of the License, or
11 // (at your option) any later version.
13 // This program is distributed in the hope that it will be useful,
14 // but WITHOUT ANY WARRANTY; without even the implied warranty of
15 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 // GNU General Public License for more details.
18 // You should have received a copy of the GNU General Public License
19 // along with this program; if not, write to the Free Software
20 // Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
21 // MA 02110-1301, USA.
23 #ifndef GOLD_TESTSUITE_TEST_H
24 #define GOLD_TESTSUITE_TEST_H
26 namespace gold_testsuite
29 class Test_report;
31 // This class handles basic test framework functionality.
33 class Test_framework
35 public:
36 Test_framework()
37 : testname_(NULL), current_fail_(0), passes_(0), failures_(0)
38 { }
40 // Return number of failures.
41 unsigned int
42 failures() const
43 { return this->failures_; }
45 // Run a test.
46 void
47 run(const char* name, bool (*pfn)(Test_report*));
49 // Get the current Test_report. This is used by the test support
50 // macros.
51 static Test_report*
52 report()
53 { return Test_framework::current_report; }
55 private:
56 friend class Test_report;
58 // Cause the current test to fail.
59 void
60 fail(const char* filename, int lineno);
62 // Report an error from the current test.
63 void
64 error(const char* message);
66 // Current Test_report. This is a static variable valid while a
67 // test is being run.
68 static Test_report* current_report;
70 // Current test being run.
71 const char* testname_;
72 // Whether the current test is failing.
73 bool current_fail_;
74 // Total number of passeed tests.
75 unsigned int passes_;
76 // Total number of failed tests.
77 unsigned int failures_;
80 // An instance of this class is passed to each test function.
82 class Test_report
84 public:
85 Test_report(Test_framework* tf)
86 : tf_(tf)
87 { }
89 // Mark the test as failing.
90 void
91 fail(const char* filename, int lineno)
92 { this->tf_->fail(filename, lineno); }
94 // Report an error.
95 void
96 error(const char* message)
97 { this->tf_->error(message); }
99 private:
100 Test_framework* tf_;
103 // This class registers a test function so that the testsuite runs it.
105 class Register_test
107 public:
108 Register_test(const char* name, bool (*pfn)(Test_report*));
110 // Run all registered tests.
111 static void
112 run_tests(Test_framework*);
114 private:
115 // Linked list of all tests.
116 static Register_test* all_tests;
118 // Test name.
119 const char* name_;
120 // Function to call. It should return true if the test passes,
121 // false if it fails.
122 bool (*pfn_)(Test_report*);
123 // Next test in linked list.
124 Register_test* next_;
127 } // End namespace gold_testsuite.
129 // These macros are for convenient use in tests.
131 // Check that a condition is true. If it is false, report a failure.
133 #define CHECK(cond) \
134 ((void) \
135 ((cond) \
136 ? 0 \
137 : (::gold_testsuite::Test_framework::report()->fail(__FILE__, \
138 __LINE__), \
139 0)))
141 // Report an error during a test.
143 #define ERROR(msg) (::gold_testsuite::Test_framework::report()->error(msg))
145 #endif // !defined(GOLD_TESTSUITE_TEST_H)