1/*==============================================================================
2|
3| NAME
4|
5| ppUnitTest.hpp
6|
7| DESCRIPTION
8|
9| Header file for unit test routines.
10|
11| User manual and technical documentation are described in detail in my web page at
12| http://seanerikoconnor.freeservers.com/Mathematics/AbstractAlgebra/PrimitivePolynomials/overview.html
13|
14| LEGAL
15|
16| Primpoly Version 16.3 - A Program for Computing Primitive Polynomials.
17| Copyright (C) 1999-2025 by Sean Erik O'Connor. All Rights Reserved.
18|
19| This program is free software: you can redistribute it and/or modify
20| it under the terms of the GNU General Public License as published by
21| the Free Software Foundation, either version 3 of the License, or
22| (at your option) any later version.
23|
24| This program is distributed in the hope that it will be useful,
25| but WITHOUT ANY WARRANTY; without even the implied warranty of
26| MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
27| GNU General Public License for more details.
28|
29| You should have received a copy of the GNU General Public License
30| along with this program. If not, see http://www.gnu.org/licenses/.
31|
32| The author's address is seanerikoconnor!AT!gmail!DOT!com
33| with the !DOT! replaced by . and the !AT! replaced by @
34|
35==============================================================================*/
36
37// Wrap this header file to prevent duplication if it is included
38// accidentally more than once.
39#ifndef __PP_UNITTEST_H__
40#define __PP_UNITTEST_H__
41
42
43/*=============================================================================
44|
45| NAME
46|
47| unitTest
48|
49| DESCRIPTION
50|
51| In the spirit of EXTREME programming, test each class and its member
52| functions. Run the tests every time we run this application.
53| Place the test results into the current directory in the file
54| unitTest.txt. If we can't write the file, log an error message
55| to the console and skip the tests. If we can't even do that, throw
56| an exception.
57|
58+============================================================================*/
59
60class UnitTest
61{
62 public:
63 // Default constructor with a reasonable default file name.
64 UnitTest( const char * fileName = "unitTest.log" ) ;
65
66 ~UnitTest() ;
67
68 // We have only one unit test object; prevent any copy constructors or
69 // assignment operators from being defined.
70 UnitTest( const UnitTest & u ) = delete ;
71 UnitTest & operator=( const UnitTest & unitTest ) = delete ;
72
73 // Run all unit tests.
74 bool run() ;
75
76 protected:
77 // Unit tests for different functional areas.
78 bool unitTestSystemFunctions() ;
79 bool unitTestBigIntBase10() ;
80 bool unitTestBigIntDefaultBase() ;
81 bool unitTestModPArithmetic() ;
82 bool unitTestFactoring() ;
83 bool unitTestPolynomials() ;
84 bool unitTestPolynomialOrder() ;
85 bool unitTestParser() ;
86
87 protected:
88 // File to log the unit test results. Can be standard output (console) if we can't open the file.
89 const char * unit_test_log_file_name_ ;
90 ofstream fout_ ;
91} ;
92
93
94/*=============================================================================
95|
96| NAME
97|
98| UnitTestError
99|
100| DESCRIPTION
101|
102| Exception classes for the the UnitTest class
103| derived from the STL exception class runtime_error.
104|
105+============================================================================*/
106
107class UnitTestError : public runtime_error
108{
109 public:
110 // Throw with error message, file name and line number.
111 UnitTestError( const string & description, const string & file, const int & line )
112 : runtime_error( description + " in file " + file + " at line " + to_string(line) )
113 {
114 } ;
115
116 // Throw with an error message.
117 UnitTestError( const string & description )
118 : runtime_error( description )
119 {
120 } ;
121
122 // Default throw with no error message.
123 UnitTestError()
124 : runtime_error( "UnitTest exception: " )
125 {
126 } ;
127} ;
128#endif // __PP_UNITTEST_H__ -- End of wrapper for header file.