1 /*
2  *  Created by Phil on 29/11/2010.
3  *  Copyright 2010 Two Blue Cubes Ltd. All rights reserved.
4  *
5  *  Distributed under the Boost Software License, Version 1.0. (See accompanying
6  *  file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
7  */
8 
9 #include "catch.hpp"
10 
11 #ifdef __clang__
12 #   pragma clang diagnostic ignored "-Wc++98-compat"
13 #   pragma clang diagnostic ignored "-Wc++98-compat-pedantic"
14 #endif
15 
16 
17 #include <iostream>
18 #include <cerrno>
19 #include <limits>
20 #include <sstream>
21 
22 namespace { namespace MiscTests {
23 
24 #ifndef MISC_TEST_HELPERS_INCLUDED // Don't compile this more than once per TU
25 #define MISC_TEST_HELPERS_INCLUDED
26 
makeString(bool makeNull)27 inline const char* makeString( bool makeNull ) {
28     return makeNull ? nullptr : "valid string";
29 }
testCheckedIf(bool flag)30 inline bool testCheckedIf( bool flag )  {
31     CHECKED_IF( flag )
32         return true;
33     else
34         return false;
35 }
testCheckedElse(bool flag)36 inline bool testCheckedElse( bool flag ) {
37     CHECKED_ELSE( flag )
38         return false;
39 
40     return true;
41 }
42 
Factorial(unsigned int number)43 inline unsigned int Factorial( unsigned int number )  {
44     return number > 1 ? Factorial(number-1)*number : 1;
45 }
46 
f()47 static int f() {
48     return 1;
49 }
50 
manuallyRegisteredTestFunction()51 inline void manuallyRegisteredTestFunction() {
52     SUCCEED( "was called" );
53 }
54 
55 struct AutoTestReg {
AutoTestReg__anonb8c7cabc0111::MiscTests::AutoTestReg56     AutoTestReg() {
57         REGISTER_TEST_CASE( manuallyRegisteredTestFunction, "ManuallyRegistered" );
58     }
59 };
60 CATCH_INTERNAL_SUPPRESS_GLOBALS_WARNINGS
61 static AutoTestReg autoTestReg;
62 CATCH_INTERNAL_UNSUPPRESS_GLOBALS_WARNINGS
63 
64 template<typename T>
65 struct Foo {
size__anonb8c7cabc0111::MiscTests::Foo66     size_t size() { return 0; }
67 };
68 
69 #endif
70 
71 TEST_CASE( "random SECTION tests", "[.][sections][failing]" ) {
72     int a = 1;
73     int b = 2;
74 
75     SECTION( "doesn't equal" ) {
76         REQUIRE( a != b );
77         REQUIRE( b != a );
78     }
79 
80     SECTION( "not equal" ) {
81         REQUIRE( a != b);
82     }
83 }
84 
85 TEST_CASE( "nested SECTION tests", "[.][sections][failing]" ) {
86     int a = 1;
87     int b = 2;
88 
89     SECTION( "doesn't equal" ) {
90         REQUIRE( a != b );
91         REQUIRE( b != a );
92 
93         SECTION( "not equal" ) {
94             REQUIRE( a != b);
95         }
96     }
97 }
98 
99 TEST_CASE( "more nested SECTION tests", "[sections][failing][.]" ) {
100     int a = 1;
101     int b = 2;
102 
103     SECTION( "doesn't equal" ) {
104         SECTION( "equal" ) {
105             REQUIRE( a == b );
106         }
107 
108         SECTION( "not equal" ) {
109             REQUIRE( a != b );
110         }
111         SECTION( "less than" ) {
112             REQUIRE( a < b );
113         }
114     }
115 }
116 
117 TEST_CASE( "even more nested SECTION tests", "[sections]" ) {
118     SECTION( "c" ) {
119         SECTION( "d (leaf)" ) {
120             SUCCEED(); // avoid failing due to no tests
121         }
122 
123         SECTION( "e (leaf)" ) {
124             SUCCEED(); // avoid failing due to no tests
125         }
126     }
127 
128     SECTION( "f (leaf)" ) {
129         SUCCEED(); // avoid failing due to no tests
130     }
131 }
132 
133 TEST_CASE( "looped SECTION tests", "[.][failing][sections]" ) {
134     int a = 1;
135 
136     for( int b = 0; b < 10; ++b ) {
137         DYNAMIC_SECTION( "b is currently: " << b ) {
138             CHECK( b > a );
139         }
140     }
141 }
142 
143 TEST_CASE( "looped tests", "[.][failing]" ) {
144     static const int fib[]  = { 1, 1, 2, 3, 5, 8, 13, 21 };
145 
146     for( std::size_t i=0; i < sizeof(fib)/sizeof(int); ++i ) {
147         INFO( "Testing if fib[" << i << "] (" << fib[i] << ") is even" );
148         CHECK( ( fib[i] % 2 ) == 0 );
149     }
150 }
151 
152 TEST_CASE( "Sends stuff to stdout and stderr", "[.]" ) {
153     std::cout << "A string sent directly to stdout" << std::endl;
154     std::cerr << "A string sent directly to stderr" << std::endl;
155     std::clog << "A string sent to stderr via clog" << std::endl;
156 }
157 
158 TEST_CASE( "null strings" ) {
159     REQUIRE( makeString( false ) != static_cast<char*>(nullptr));
160     REQUIRE( makeString( true ) == static_cast<char*>(nullptr));
161 }
162 
163 TEST_CASE( "checkedIf" ) {
164     REQUIRE( testCheckedIf( true ) );
165 }
166 
167 TEST_CASE( "checkedIf, failing", "[failing][.]" ) {
168     REQUIRE( testCheckedIf( false ) );
169 }
170 
171 TEST_CASE( "checkedElse" ) {
172     REQUIRE( testCheckedElse( true ) );
173 }
174 
175 TEST_CASE( "checkedElse, failing", "[failing][.]" ) {
176     REQUIRE( testCheckedElse( false ) );
177 }
178 
179 TEST_CASE( "xmlentitycheck" ) {
180     SECTION( "embedded xml: <test>it should be possible to embed xml characters, such as <, \" or &, or even whole <xml>documents</xml> within an attribute</test>" ) {
181         SUCCEED(); // We need this here to stop it failing due to no tests
182     }
183     SECTION( "encoded chars: these should all be encoded: &&&\"\"\"<<<&\"<<&\"" ) {
184         SUCCEED(); // We need this here to stop it failing due to no tests
185     }
186 }
187 
188 TEST_CASE( "send a single char to INFO", "[failing][.]" ) {
189     INFO(3);
190     REQUIRE(false);
191 }
192 
193 TEST_CASE( "atomic if", "[failing][0]") {
194     std::size_t x = 0;
195 
196     if( x )
197         REQUIRE(x > 0);
198     else
199         REQUIRE(x == 0);
200 }
201 
202 
203 TEST_CASE( "Factorials are computed", "[factorial]" ) {
204   REQUIRE( Factorial(0) == 1 );
205   REQUIRE( Factorial(1) == 1 );
206   REQUIRE( Factorial(2) == 2 );
207   REQUIRE( Factorial(3) == 6 );
208   REQUIRE( Factorial(10) == 3628800 );
209 }
210 
211 TEST_CASE( "An empty test with no assertions", "[empty]" ) {}
212 
213 TEST_CASE( "Nice descriptive name", "[tag1][tag2][tag3][.]" ) {
214     WARN( "This one ran" );
215 }
216 TEST_CASE( "first tag", "[tag1]" ) {}
217 TEST_CASE( "second tag", "[tag2]" ) {}
218 
219 //
220 //TEST_CASE( "spawn a new process", "[.]" )
221 //{
222 //    // !TBD Work in progress
223 //    char line[200];
224 //    FILE* output = popen("./CatchSelfTest ./failing/matchers/StartsWith", "r");
225 //    while ( fgets(line, 199, output) )
226 //        std::cout << line;
227 //}
228 
229 TEST_CASE( "vectors can be sized and resized", "[vector]" ) {
230 
231     std::vector<int> v( 5 );
232 
233     REQUIRE( v.size() == 5 );
234     REQUIRE( v.capacity() >= 5 );
235 
236     SECTION( "resizing bigger changes size and capacity" ) {
237         v.resize( 10 );
238 
239         REQUIRE( v.size() == 10 );
240         REQUIRE( v.capacity() >= 10 );
241     }
242     SECTION( "resizing smaller changes size but not capacity" ) {
243         v.resize( 0 );
244 
245         REQUIRE( v.size() == 0 );
246         REQUIRE( v.capacity() >= 5 );
247 
248         SECTION( "We can use the 'swap trick' to reset the capacity" ) {
249             std::vector<int> empty;
250             empty.swap( v );
251 
252             REQUIRE( v.capacity() == 0 );
253         }
254     }
255     SECTION( "reserving bigger changes capacity but not size" ) {
256         v.reserve( 10 );
257 
258         REQUIRE( v.size() == 5 );
259         REQUIRE( v.capacity() >= 10 );
260     }
261     SECTION( "reserving smaller does not change size or capacity" ) {
262         v.reserve( 0 );
263 
264         REQUIRE( v.size() == 5 );
265         REQUIRE( v.capacity() >= 5 );
266     }
267 }
268 
269 TEMPLATE_TEST_CASE( "TemplateTest: vectors can be sized and resized", "[vector][template]", int, float, std::string, (std::tuple<int,float>) ) {
270 
271     std::vector<TestType> v( 5 );
272 
273     REQUIRE( v.size() == 5 );
274     REQUIRE( v.capacity() >= 5 );
275 
276     SECTION( "resizing bigger changes size and capacity" ) {
277         v.resize( 10 );
278 
279         REQUIRE( v.size() == 10 );
280         REQUIRE( v.capacity() >= 10 );
281     }
282     SECTION( "resizing smaller changes size but not capacity" ) {
283         v.resize( 0 );
284 
285         REQUIRE( v.size() == 0 );
286         REQUIRE( v.capacity() >= 5 );
287 
288         SECTION( "We can use the 'swap trick' to reset the capacity" ) {
289             std::vector<TestType> empty;
290             empty.swap( v );
291 
292             REQUIRE( v.capacity() == 0 );
293         }
294     }
295     SECTION( "reserving bigger changes capacity but not size" ) {
296         v.reserve( 10 );
297 
298         REQUIRE( v.size() == 5 );
299         REQUIRE( v.capacity() >= 10 );
300     }
301     SECTION( "reserving smaller does not change size or capacity" ) {
302         v.reserve( 0 );
303 
304         REQUIRE( v.size() == 5 );
305         REQUIRE( v.capacity() >= 5 );
306     }
307 }
308 
309 TEMPLATE_PRODUCT_TEST_CASE("A Template product test case", "[template][product]", (std::vector, Foo), (int, float)) {
310     TestType x;
311     REQUIRE(x.size() == 0);
312 }
313 
314 TEMPLATE_PRODUCT_TEST_CASE("Product with differing arities", "[template][product]", std::tuple, (int, (int, double), (int, double, float))) {
315     REQUIRE(std::tuple_size<TestType>::value >= 1);
316 }
317 
318 // https://github.com/philsquared/Catch/issues/166
319 TEST_CASE("A couple of nested sections followed by a failure", "[failing][.]") {
320     SECTION("Outer")
321         SECTION("Inner")
322             SUCCEED("that's not flying - that's failing in style");
323 
324     FAIL("to infinity and beyond");
325 }
326 
327 TEST_CASE("not allowed", "[!throws]") {
328     // This test case should not be included if you run with -e on the command line
329     SUCCEED();
330 }
331 
332 //TEST_CASE( "Is big endian" ) {
333 //    CHECK( Catch::Detail::Endianness::which() == Catch::Detail::Endianness::Little );
334 //}
335 
336 TEST_CASE( "Tabs and newlines show in output", "[.][whitespace][failing]" ) {
337 
338     // Based on issue #242
339     std::string s1 = "if ($b == 10) {\n\t\t$a\t= 20;\n}";
340     std::string s2 = "if ($b == 10) {\n\t$a = 20;\n}\n";
341     CHECK( s1 == s2 );
342 }
343 
344 
345 #ifdef CATCH_CONFIG_WCHAR
346 TEST_CASE( "toString on const wchar_t const pointer returns the string contents", "[toString]" ) {
347         const wchar_t * const s = L"wide load";
348         std::string result = ::Catch::Detail::stringify( s );
349         CHECK( result == "\"wide load\"" );
350 }
351 
352 TEST_CASE( "toString on const wchar_t pointer returns the string contents", "[toString]" ) {
353         const wchar_t * s = L"wide load";
354         std::string result = ::Catch::Detail::stringify( s );
355         CHECK( result == "\"wide load\"" );
356 }
357 
358 TEST_CASE( "toString on wchar_t const pointer returns the string contents", "[toString]" ) {
359         auto const s = const_cast<wchar_t*>( L"wide load" );
360         std::string result = ::Catch::Detail::stringify( s );
361         CHECK( result == "\"wide load\"" );
362 }
363 
364 TEST_CASE( "toString on wchar_t returns the string contents", "[toString]" ) {
365         auto s = const_cast<wchar_t*>( L"wide load" );
366         std::string result = ::Catch::Detail::stringify( s );
367         CHECK( result == "\"wide load\"" );
368 }
369 #endif
370 
371 TEST_CASE( "long long" ) {
372     long long l = std::numeric_limits<long long>::max();
373 
374     REQUIRE( l == std::numeric_limits<long long>::max() );
375 }
376 
377 //TEST_CASE( "Divide by Zero signal handler", "[.][sig]" ) {
378 //    int i = 0;
379 //    int x = 10/i; // This should cause the signal to fire
380 //    CHECK( x == 0 );
381 //}
382 
383 TEST_CASE( "This test 'should' fail but doesn't", "[.][failing][!shouldfail]" ) {
384     SUCCEED( "oops!" );
385 }
386 
387 TEST_CASE( "# A test name that starts with a #" ) {
388     SUCCEED( "yay" );
389 }
390 
391 TEST_CASE( "#835 -- errno should not be touched by Catch", "[.][failing][!shouldfail]" ) {
392     errno = 1;
393     CHECK(f() == 0);
394     REQUIRE(errno == 1); // Check that f() doesn't touch errno.
395 }
396 
397 TEST_CASE( "#961 -- Dynamically created sections should all be reported", "[.]" ) {
398     for (char i = '0'; i < '5'; ++i) {
399         SECTION(std::string("Looped section ") + i) {
400             SUCCEED( "Everything is OK" );
401         }
402     }
403 }
404 
405 TEST_CASE( "#1175 - Hidden Test", "[.]" ) {
406   // Just for checking that hidden test is not listed by default
407   SUCCEED();
408 }
409 
410 }} // namespace MiscTests
411