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