blob: d9c658fd4aea4daacb49e077bdf0646b5e6d8fc7 [file] [log] [blame] [view]
Martin Moenee8225052017-08-24 15:21:36 +02001<a id="top"></a>
Martin Hořeňovský49f59192017-08-18 20:15:00 +02002# 2.0.0 (in progress)
3
4## Breaking changes
5* Removed C++98 support
6* Removed legacy reporter support
7* Removed legacy generator support
8 * Generator support will come back later, reworked
9* Removed `Catch::toString` support
10 * The new stringification machinery uses `Catch::StringMaker` specializations first and `operator<<` overloads second.
11* Removed legacy `SCOPED_MSG` and `SCOPED_INFO` macros
12* Output into debugger is now colourized
13* `*_THROWS_AS(expr, exception_type)` now unconditionally appends `const&` to the exception type.
14* `CATCH_CONFIG_FAST_COMPILE` now affects the `CHECK_` family of assertions as well as `REQUIRE_` family of assertions
15 * This is most noticeable in `CHECK(throws())`, which would previously report failure, properly stringify the exception and continue. Now it will report failure and stop executing current section.
16
17## Improvements
18* Reporters and Listeners can be defined in files different from the main file
19 * The file has to define `CATCH_CONFIG_EXTERNAL_INTERFACES` before including catch.hpp.
20* Errors that happen during set up before main are now caught and properly reported once main is entered
21 * If you are providing your own main, you can access and use these as well.
22* New assertion macros, *_THROWS_WITH(expr, exception_type, matcher) are provided
23 * As the arguments suggest, these allow you to assert that an expression throws desired type of exception and pass the exception to a matcher.
24* JUnit reporter no longer has significantly different output for test cases with and without sections
25* Most assertions now support expressions containing commas (ie `REQUIRE(foo() == std::vector<int>{1, 2, 3});`)
26* Catch now contains experimental micro benchmarking support
27 * See `projects/SelfTest/Benchmark.tests.cpp` for examples
28 * The support being experiment means that it can be changed without prior notice
29* Catch uses new CLI parsing library (Clara)
30 * Users can now easily add new command line options to the final executable
31 * This also leads to some changes in `Catch::Session` interface
32
33## Fixes
34
35
36## Internal changes
37* The development version now uses .cpp files instead of header files containing implementation.
38 * This makes partial rebuilds much faster during development
39* The expression decomposition layer has been rewritten
40* The evaluation layer has been rewritten
41* New library (TextFlow) is used for formatting text to output
42
43
Martin Hořeňovskýee67ac62017-06-27 12:21:48 +020044# 1.9.6
45
46### Improvements
47* Catch's runtime overhead has been significantly decreased (#937, #939)
48* Added `--list-extra-info` cli option (#934).
49 * It lists all tests together with extra information, ie filename, line number and description.
50
51
52
Martin Hořeňovský017a63d2017-06-15 13:08:26 +020053# 1.9.5
54
55### Fixes
56* Truthy expressions are now reconstructed properly, not as booleans (#914)
57* Various warnings are no longer erroneously suppressed in test files (files that include `catch.hpp`, but do not define `CATCH_CONFIG_MAIN` or `CATCH_CONFIG_RUNNER`) (#871)
58* Catch no longer fails to link when main is compiled as C++, but linked against Objective-C (#855)
59* Fixed incorrect gcc version detection when deciding to use `__COUNTER__` (#928)
60 * Previously any GCC with minor version less than 3 would be incorrectly classified as not supporting `__COUNTER__`.
61* Suppressed C4996 warning caused by upcoming updated to MSVC 2017, marking `std::uncaught_exception` as deprecated. (#927)
62
63### Improvements
64* CMake integration script now incorporates debug messages and registers tests in an improved way (#911)
65* Various documentation improvements
66
67
68
Martin Hořeňovský3dcc9232017-05-16 13:59:29 +020069# 1.9.4
70
71### Fixes
72* `CATCH_FAIL` macro no longer causes compilation error without variadic macro support
73* `INFO` messages are no longer cleared after being reported once
74
75### Improvements and minor changes
76* Catch now uses `wmain` when compiled under Windows and `UNICODE` is defined.
77 * Note that Catch still officially supports only ASCII
78
Phil Nasha0ada2e2017-04-25 14:23:06 +000079# 1.9.3
80
81### Fixes
82* Completed the fix for (lack of) uint64_t in earlier Visual Studios
83
Martin Hořeňovskýfc7f0a02017-04-25 11:08:02 +020084# 1.9.2
85
86### Improvements and minor changes
87* All of `Approx`'s member functions now accept strong typedefs in C++11 mode (#888)
88 * Previously `Approx::scale`, `Approx::epsilon`, `Approx::margin` and `Approx::operator()` didn't.
89
90
91### Fixes
92* POSIX signals are now disabled by default under QNX (#889)
93 * QNX does not support current enough (2001) POSIX specification
94* JUnit no longer counts exceptions as failures if given test case is marked as ok to fail.
95* `Catch::Option` should now have its storage properly aligned.
96* Catch no longer attempts to define `uint64_t` on windows (#862)
97 * This was causing trouble when compiled under Cygwin
98
99### Other
100* Catch is now compiled under MSVC 2017 using `std:c++latest` (C++17 mode) in CI
101* We now provide cmake script that autoregisters Catch tests into ctest.
102 * See `contrib` folder.
103
104
Martin Hořeňovskýc6990cd2017-04-09 21:25:20 +0200105# 1.9.1
106
107### Fixes
108* Unexpected exceptions are no longer ignored by default (#885, #887)
109
110
Martin Hořeňovský1b03c5a2017-04-07 22:56:36 +0200111# 1.9.0
112
113
114### Improvements and minor changes
115* Catch no longer attempts to ensure the exception type passed by user in `REQUIRE_THROWS_AS` is a constant reference.
116 * It was causing trouble when `REQUIRE_THROWS_AS` was used inside templated functions
117 * This actually reverts changes made in v1.7.2
118* Catch's `Version` struct should no longer be double freed when multiple instances of Catch tests are loaded into single program (#858)
119 * It is now a static variable in an inline function instead of being an `extern`ed struct.
120* Attempt to register invalid tag or tag alias now throws instead of calling `exit()`.
121 * Because this happen before entering main, it still aborts execution
122 * Further improvements to this are coming
123* `CATCH_CONFIG_FAST_COMPILE` now speeds-up compilation of `REQUIRE*` assertions by further ~15%.
124 * The trade-off is disabling translation of unexpected exceptions into text.
125* When Catch is compiled using C++11, `Approx` is now constructible with anything that can be explicitly converted to `double`.
126* Captured messages are now printed on unexpected exceptions
127
128### Fixes:
129* Clang's `-Wexit-time-destructors` should be suppressed for Catch's internals
130* GCC's `-Wparentheses` is now suppressed for all TU's that include `catch.hpp`.
131 * This is functionally a revert of changes made in 1.8.0, where we tried using `_Pragma` based suppression. This should have kept the suppression local to Catch's assertions, but bugs in GCC's handling of `_Pragma`s in C++ mode meant that it did not always work.
132* You can now tell Catch to use C++11-based check when checking whether a type can be streamed to output.
133 * This fixes cases when an unstreamable type has streamable private base (#877)
134 * [Details can be found in documentation](configuration.md#catch_config_cpp11_stream_insertable_check)
135
136
137### Other notes:
138* We have added VS 2017 to our CI
139* Work on Catch 2 should start soon
140
141
142
Martin Hořeňovský0c015aa2017-03-13 21:29:30 +0100143# 1.8.2
144
145
146### Improvements and minor changes
147* TAP reporter now behaves as if `-s` was always set
148 * This should be more consistent with the protocol desired behaviour.
149* Compact reporter now obeys `-d yes` argument (#780)
150 * The format is "XXX.123 s: <section-name>" (3 decimal places are always present).
151 * Before it did not report the durations at all.
152* XML reporter now behaves the same way as Console reporter in regards to `INFO`
153 * This means it reports `INFO` messages on success, if output on success (`-s`) is enabled.
154 * Previously it only reported `INFO` messages on failure.
155* `CAPTURE(expr)` now stringifies `expr` in the same way assertion macros do (#639)
156* Listeners are now finally [documented](event-listeners.md).
157 * Listeners provide a way to hook into events generated by running your tests, including start and end of run, every test case, every section and every assertion.
158
159
160### Fixes:
161* Catch no longer attempts to reconstruct expression that led to a fatal error (#810)
162 * This fixes possible signal/SEH loop when processing expressions, where the signal was triggered by expression decomposition.
163* Fixed (C4265) missing virtual destructor warning in Matchers (#844)
164* `std::string`s are now taken by `const&` everywhere (#842).
165 * Previously some places were taking them by-value.
166* Catch should no longer change errno (#835).
167 * This was caused by libstdc++ bug that we now work around.
168* Catch now provides `FAIL_CHECK( ... )` macro (#765).
169 * Same as `FAIL( ... )`, but does not abort the test.
170* Functions like `fabs`, `tolower`, `memset`, `isalnum` are now used with `std::` qualification (#543).
171* Clara no longer assumes first argument (binary name) is always present (#729)
172 * If it is missing, empty string is used as default.
173* Clara no longer reads 1 character past argument string (#830)
Phil Nash06923172017-03-15 09:04:09 +0000174* Regression in Objective-C bindings (Matchers) fixed (#854)
Martin Hořeňovský0c015aa2017-03-13 21:29:30 +0100175
176
177### Other notes:
178* We have added VS 2013 and 2015 to our CI
179* Catch Classic (1.x.x) now contains its own, forked, version of Clara (the argument parser).
180
181
182
Phil Nash658b5f62017-03-01 16:06:48 +0000183# 1.8.1
184
185### Fixes
186
187Cygwin issue with `gettimeofday` - `#define` was not early enough
188
Phil Nash0952b762017-02-28 14:19:09 +0000189# 1.8.0
190
191### New features/ minor changes
192
193* Matchers have new, simpler (and documented) interface.
194 * Catch provides string and vector matchers.
Martin Hořeňovský95fc8d62017-03-13 21:31:26 +0100195 * For details see [Matchers documentation](matchers.md).
Phil Nash0952b762017-02-28 14:19:09 +0000196* Changed console reporter test duration reporting format (#322)
197 * Old format: `Some simple comparisons between doubles completed in 0.000123s`
198 * New format: `xxx.123s: Some simple comparisons between doubles` _(There will always be exactly 3 decimal places)_
199* Added opt-in leak detection under MSVC + Windows (#439)
200 * Enable it by compiling Catch's main with `CATCH_CONFIG_WINDOWS_CRTDBG`
201* Introduced new compile-time flag, `CATCH_CONFIG_FAST_COMPILE`, trading features for compilation speed.
Martin Hořeňovskýaf1ed702017-03-03 15:03:23 +0100202 * Moves debug breaks out of tests and into implementation, speeding up test compilation time (~10% on linux).
Phil Nash0952b762017-02-28 14:19:09 +0000203 * _More changes are coming_
204* Added [TAP (Test Anything Protocol)](https://testanything.org/) and [Automake](https://www.gnu.org/software/automake/manual/html_node/Log-files-generation-and-test-results-recording.html#Log-files-generation-and-test-results-recording) reporters.
205 * These are not present in the default single-include header and need to be downloaded from GitHub separately.
Phil Nash417202b2017-03-01 08:22:38 +0000206 * For details see [documentation about integrating with build systems](build-systems.md).
Phil Nash0952b762017-02-28 14:19:09 +0000207* XML reporter now reports filename as part of the `Section` and `TestCase` tags.
208* `Approx` now supports an optional margin of absolute error
Martin Hořeňovský95fc8d62017-03-13 21:31:26 +0100209 * It has also received [new documentation](assertions.md).
Phil Nash0952b762017-02-28 14:19:09 +0000210
211### Fixes
212* Silenced C4312 ("conversion from int to 'ClassName *") warnings in the evaluate layer.
213* Fixed C4512 ("assignment operator could not be generated") warnings under VS2013.
214* Cygwin compatibility fixes
215 * Signal handling is no longer compiled by default.
216 * Usage of `gettimeofday` inside Catch should no longer cause compilation errors.
217* Improved `-Wparentheses` supression for gcc (#674)
218 * When compiled with gcc 4.8 or newer, the supression is localized to assertions only
219 * Otherwise it is supressed for the whole TU
220* Fixed test spec parser issue (with escapes in multiple names)
221
222### Other
223* Various documentation fixes and improvements
224
225
Phil Nashd08cee22017-02-13 16:15:42 +0000226# 1.7.2
227
228### Fixes and minor improvements
229Xml:
230
231(technically the first two are breaking changes but are also fixes and arguably break few if any people)
232* C-escape control characters instead of XML encoding them (which requires XML 1.1)
233* Revert XML output to XML 1.0
234* Can provide stylesheet references by extending the XML reporter
235* Added description and tags attribites to XML Reporter
236* Tags are closed and the stream flushed more eagerly to avoid stdout interpolation
237
238
239Other:
240* `REQUIRE_THROWS_AS` now catches exception by `const&` and reports expected type
241* In `SECTION`s the file/ line is now of the `SECTION`. not the `TEST_CASE`
242* Added std:: qualification to some functions from C stdlib
243* Removed use of RTTI (`dynamic_cast`) that had crept back in
244* Silenced a few more warnings in different circumstances
245* Travis improvements
246
Martin Hořeňovský7b8a27e2017-02-07 10:06:52 +0100247# 1.7.1
248
249### Fixes:
250* Fixed inconsistency in defining `NOMINMAX` and `WIN32_LEAN_AND_MEAN` inside `catch.hpp`.
251* Fixed SEH-related compilation error under older MinGW compilers, by making Windows SEH handling opt-in for compilers other than MSVC.
Martin Hořeňovský95fc8d62017-03-13 21:31:26 +0100252 * For specifics, look into the [documentation](configuration.md).
Martin Hořeňovský7b8a27e2017-02-07 10:06:52 +0100253* Fixed compilation error under MinGW caused by improper compiler detection.
254* Fixed XML reporter sometimes leaving an empty output file when a test ends with signal/structured exception.
255* Fixed XML reporter not reporting captured stdout/stderr.
256* Fixed possible infinite recursion in Windows SEH.
257* Fixed possible compilation error caused by Catch's operator overloads being ambiguous in regards to user-defined templated operators.
258
Martin Hořeňovský7b8a27e2017-02-07 10:06:52 +0100259## 1.7.0
Martin Hořeňovskýce37f482017-02-01 21:47:43 +0100260
261### Features/ Changes:
262* Catch now runs significantly faster for passing tests
263 * Microbenchmark focused on Catch's overhead went from ~3.4s to ~0.7s.
264 * Real world test using [JSON for Modern C++](https://github.com/nlohmann/json)'s test suite went from ~6m 25s to ~4m 14s.
265* Catch can now run specific sections within test cases.
Martin Hořeňovský95fc8d62017-03-13 21:31:26 +0100266 * For now the support is only basic (no wildcards or tags), for details see the [documentation](command-line.md).
Martin Hořeňovskýce37f482017-02-01 21:47:43 +0100267* Catch now supports SEH on Windows as well as signals on Linux.
268 * After receiving a signal, Catch reports failing assertion and then passes the signal onto the previous handler.
269* Approx can be used to compare values against strong typedefs (available in C++11 mode only).
270 * Strong typedefs mean types that are explicitly convertible to double.
271* CHECK macro no longer stops executing section if an exception happens.
272* Certain characters (space, tab, etc) are now pretty printed.
273 * This means that a `char c = ' '; REQUIRE(c == '\t');` would be printed as `' ' == '\t'`, instead of ` == 9`.
274
275### Fixes:
276* Text formatting no longer attempts to access out-of-bounds characters under certain conditions.
277* THROW family of assertions no longer trigger `-Wunused-value` on expressions containing explicit cast.
278* Breaking into debugger under OS X works again and no longer required `DEBUG` to be defined.
279* Compilation no longer breaks under certain compiler if a lambda is used inside assertion macro.
280
281### Other:
282* Catch's CMakeLists now defines install command.
283* Catch's CMakeLists now generates projects with warnings enabled.
284
285
Martin Hořeňovskýce37f482017-02-01 21:47:43 +0100286## 1.6.1
Martin Hořeňovský9a566092017-01-20 12:49:59 +0100287
288### Features/ Changes:
289* Catch now supports breaking into debugger on Linux
290
291### Fixes:
292* Generators no longer leak memory (generators are still unsupported in general)
293* JUnit reporter now reports UTC timestamps, instead of "tbd"
294* `CHECK_THAT` macro is now properly defined as `CATCH_CHECK_THAT` when using `CATCH_` prefixed macros
295
296### Other:
297* Types with overloaded `&&` operator are no longer evaluated twice when used in an assertion macro.
298* The use of `__COUNTER__` is supressed when Catch is parsed by CLion
299 * This change is not active when compiling a binary
300* Approval tests can now be run on Windows
301* CMake will now warn if a file is present in the `include` folder but not is not enumerated as part of the project
302* Catch now defines `NOMINMAX` and `WIN32_LEAN_AND_MEAN` before including `windows.h`
Martin Hořeňovský95fc8d62017-03-13 21:31:26 +0100303 * This can be disabled if needed, see [documentation](configuration.md) for details.
Martin Hořeňovský9a566092017-01-20 12:49:59 +0100304
305
Martin Hořeňovský9a566092017-01-20 12:49:59 +0100306## 1.6.0
Phil Nash3b2f2062017-01-11 16:43:56 +0000307
308### Cmake/ projects:
309* Moved CMakeLists.txt to root, made it friendlier for CLion and generating XCode and VS projects, and removed the manually maintained XCode and VS projects.
310
311### Features/ Changes:
Phil Nash1ff0acf2017-01-11 16:50:35 +0000312* Approx now supports `>=` and `<=`
313* Can now use `\` to escape chars in test names on command line
Phil Nash3b2f2062017-01-11 16:43:56 +0000314* Standardize C++11 feature toggles
315
316### Fixes:
317* Blue shell colour
Phil Nash1ff0acf2017-01-11 16:50:35 +0000318* Missing argument to `CATCH_CHECK_THROWS`
Phil Nash3b2f2062017-01-11 16:43:56 +0000319* Don't encode extended ASCII in XML
Phil Nashe6aa1f42017-01-11 17:14:28 +0000320* use `std::shuffle` on more compilers (fixes deprecation warning/error)
Phil Nash1ff0acf2017-01-11 16:50:35 +0000321* Use `__COUNTER__` more consistently (where available)
Phil Nash3b2f2062017-01-11 16:43:56 +0000322
323### Other:
324* Tweaks and changes to scripts - particularly for Approval test - to make them more portable
325
Phil Nash3b2f2062017-01-11 16:43:56 +0000326
Phil Nash0952b762017-02-28 14:19:09 +0000327# Older versions
328Release notes were not maintained prior to v1.6.0, but you should be able to work them out from the Git history
329
Phil Nash3b2f2062017-01-11 16:43:56 +0000330---
331
332[Home](Readme.md)