1Major changes between releases Automated Testing Framework 2=========================================================================== 3 4 5Changes in version 0.17 6*********************** 7 8Experimental version released on February 14th, 2013. 9 10* Added the atf_utils_cat_file, atf_utils_compare_file, 11 atf_utils_copy_file, atf_utils_create_file, atf_utils_file_exists, 12 atf_utils_fork, atf_utils_grep_file, atf_utils_grep_string, 13 atf_utils_readline, atf_utils_redirect and atf_utils_wait utility 14 functions to atf-c-api. Documented the already-public 15 atf_utils_free_charpp function. 16 17* Added the cat_file, compare_file, copy_file, create_file, file_exists, 18 fork, grep_collection, grep_file, grep_string, redirect and wait 19 functions to the atf::utils namespace of atf-c++-api. These are 20 wrappers around the same functions added to the atf-c-api library. 21 22* Added the ATF_CHECK_MATCH, ATF_CHECK_MATCH_MSG, ATF_REQUIRE_MATCH and 23 ATF_REQUIRE_MATCH_MSG macros to atf-c to simplify the validation of a 24 string against a regular expression. 25 26* Miscellaneous fixes for manpage typos and compilation problems with 27 clang. 28 29* Added caching of the results of those configure tests that rely on 30 executing a test program. This should help crossbuild systems by 31 providing a mechanism to pre-specify what the results should be. 32 33* PR bin/45690: Make atf-report convert any non-printable characters to 34 a plain-text representation (matching their corresponding hexadecimal 35 entities) in XML output files. This is to prevent the output of test 36 cases from breaking xsltproc later. 37 38 39Changes in version 0.16 40*********************** 41 42Experimental version released on July 10th, 2012. 43 44* Added a --enable-tools flag to configure to request the build of the 45 deprecated ATF tools, whose build is now disabled by default. In order 46 to continue running tests, you should migrate to Kyua instead of enabling 47 the build of the deprecated tools. The kyua-atf-compat package provides 48 transitional compatibility versions of atf-run and atf-report built on 49 top of Kyua. 50 51* Tweaked the ATF_TEST_CASE macro of atf-c++ so that the compiler can 52 detect defined but unused test cases. 53 54* PR bin/45859: Fixed some XSLT bugs that resulted in the tc-time and 55 tp-time XML tags leaking into the generated HTML file. Also improved 56 the CSS file slightly to correct alignment and color issues with the 57 timestamps column. 58 59* Optimized atf-c++/macros.hpp so that GNU G++ consumes less memory during 60 compilation with GNU G++. 61 62* Flipped the default to building shared libraries for atf-c and atf-c++, 63 and started versioning them. As a side-effect, this removes the 64 --enable-unstable-shared flag from configure that appears to not work any 65 more (under NetBSD). Additionally, some distributions require the use of 66 shared libraries for proper dependency tracking (e.g. Fedora), so it is 67 better if we do the right versioning upstream. 68 69* Project hosting moved from an adhoc solution (custom web site and 70 Monotone repository) to Google Code (standard wiki and Git). ATF now 71 lives in a subcomponent of the Kyua project. 72 73 74Changes in version 0.15 75*********************** 76 77Experimental version released on January 16th, 2012. 78 79* Respect stdin in atf-check. The previous release silenced stdin for any 80 processes spawned by atf, not only test programs, which caused breakage 81 in tests that pipe data through atf-check. 82 83* Performance improvements to atf-sh. 84 85* Enabled detection of unused parameters and variables in the code and 86 fixed all warnings. 87 88* Changed the behavior of "developer mode". Compiler warnings are now 89 enabled unconditionally regardless of whether we are in developer mode or 90 not; developer mode is now only used to perform strict warning checks and 91 to enable assertions. Additionally, developer mode is now only 92 automatically enabled when building from the repository, not for formal 93 releases. 94 95* Added new Autoconf M4 macros (ATF_ARG_WITH, ATF_CHECK_C and 96 ATF_CHECK_CXX) to provide a consistent way of defining a --with-arg flag 97 in configure scripts and detecting the presence of any of the ATF 98 bindings. Note that ATF_CHECK_SH was already introduced in 0.14, but it 99 has now been modified to also honor --with-atf if instantiated. 100 101* Added timing support to atf-run / atf-report. 102 103* Added support for a 'require.memory' property, to specify the minimum 104 amount of physical memory needed by the test case to yield valid results. 105 106* PR bin/45690: Force an ISO-8859-1 encoding in the XML files generated by 107 atf-report so that invalid data in the output of test cases does not 108 mangle our report. 109 110 111Changes in version 0.14 112*********************** 113 114Experimental version released on June 14th, 2011. 115 116* Added a pkg-config file for atf-sh and an aclocal file to ease the 117 detection of atf-sh from autoconf scripts. 118 119* Made the default test case body defined by atf_sh fail. This is to 120 ensure that test cases are properly defined in test programs and helps 121 in catching typos in the names of the body functions. 122 123* PR bin/44882: Made atf-run connect the stdin of test cases to /dev/zero. 124 This provides more consistent results with "normal" execution (in 125 particular, when tests are executed detached from a terminal). 126 127* Made atf-run hardcode TZ=UTC for test cases. It used to undefine TZ, but 128 that does not take into account that libc determines the current timezone 129 from a configuration file. 130 131* All test programs will now print a warning when they are not run through 132 atf-run(1) stating that this is unsupported and may deliver incorrect 133 results. 134 135* Added support for the 'require.files' test-case property. This allows 136 test cases to specify installed files that must be present for the test 137 case to run. 138 139 140Changes in version 0.13 141*********************** 142 143Experimental version released on March 31st, 2011. 144 145This is the first release after the creation of the Kyua project, a more 146modular and reliable replacement for ATF. From now on, ATF will change to 147accomodate the transition to this new codebase, but ATF will still continue 148to see development in the short/medium term. Check out the project page at 149http://code.google.com/p/kyua/ for more details. 150 151The changes in this release are: 152 153* Added support to run the tests with the Kyua runtime engine (kyua-cli), a 154 new package that aims to replace atf-run and atf-report. The ATF tests 155 can be run with the new system by issuing a 'make installcheck-kyua' from 156 the top-level directory of the project (assuming the 'kyua' binary is 157 available during the configuration stage of ATF). 158 159* atf-run and atf-report are now in maintenance mode (but *not* deprecated 160 yet!). Kyua already implements a new, much more reliable runtime engine 161 that provides similar features to these tools. That said, it is not 162 complete yet so all development efforts should go towards it. 163 164* If GDB is installed, atf-run dumps the stack trace of crashing test 165 programs in an attempt to aid debugging. Contributed by Antti Kantee. 166 167* Reverted default timeout change in previous release and reset its value 168 to 5 minutes. This was causing several issues, specially when running 169 the existing NetBSD test suite in qemu. 170 171* Fixed the 'match' output checker in atf-check to properly validate the 172 last line of a file even if it does not have a newline. 173 174* Added the ATF_REQUIRE_IN and ATF_REQUIRE_NOT_IN macros to atf-c++ to 175 check for the presence (or lack thereof) of an element in a collection. 176 177* PR bin/44176: Fixed a race condition in atf-run that would crash atf-run 178 when the cleanup of a test case triggered asynchronous modifications to 179 its work directory (e.g. killing a daemon process that cleans up a pid 180 file in the work directory). 181 182* PR bin/44301: Fixed the sample XSLT file to report bogus test programs 183 instead of just listing them as having 0 test cases. 184 185 186Changes in version 0.12 187*********************** 188 189Experimental version released on November 7th, 2010. 190 191* Added the ATF_REQUIRE_THROW_RE to atf-c++, which is the same as 192 ATF_REQUIRE_THROW but allows checking for the validity of the exception's 193 error message by means of a regular expression. 194 195* Added the ATF_REQUIRE_MATCH to atf-c++, which allows checking for a 196 regular expression match in a string. 197 198* Changed the default timeout for test cases from 5 minutes to 30 seconds. 199 30 seconds is long enough for virtually all tests to complete, and 5 200 minutes is a way too long pause in a test suite where a single test case 201 stalls. 202 203* Deprecated the use.fs property. While this seemed like a good idea in 204 the first place to impose more control on what test cases can do, it 205 turns out to be bad. First, use.fs=false prevents bogus test cases 206 from dumping core so after-the-fact debugging is harder. Second, 207 supporting use.fs adds a lot of unnecessary complexity. atf-run will 208 now ignore any value provided to use.fs and will allow test cases to 209 freely access the file system if they wish to. 210 211* Added the atf_tc_get_config_var_as_{bool,long}{,_wd} functions to the atf-c 212 library. The 'text' module became private in 0.11 but was being used 213 externally to simplify the parsing of configuration variables. 214 215* Made atf-run recognize the 'unprivileged-user' configuration variable 216 and automatically drop root privileges when a test case sets 217 require.user=unprivileged. Note that this is, by no means, done for 218 security purposes; this is just for user convenience; tests should, in 219 general, not be blindly run as root in the first place. 220 221 222Changes in version 0.11 223*********************** 224 225Experimental version released on October 20th, 2010. 226 227* The ATF_CHECK* macros in atf-c++ were renamed to ATF_REQUIRE* to match 228 their counterparts in atf-c. 229 230* Clearly separated the modules in atf-c that are supposed to be public 231 from those that are implementation details. The header files for the 232 internal modules are not installed any more. 233 234* Made the atf-check tool private. It is only required by atf-sh and being 235 public has the danger of causing confusion. Also, making it private 236 simplifies the public API of atf. 237 238* Changed atf-sh to enable per-command error checking (set -e) by default. 239 This catches many cases in which a test case is broken but it is not 240 reported as such because execution continues. 241 242* Fixed the XSTL and CSS stylesheets to support expected failures. 243 244 245Changes in version 0.10 246*********************** 247 248Experimental version released on July 2nd, 2010. 249 250Miscellaneous features 251 252* Added expected failures support to test cases and atf-run. These 253 include, for example, expected clean exits, expected reception of fatal 254 signals, expected timeouts and expected errors in condition checks. 255 These statuses can be used to denote test cases that are known to fail 256 due to a bug in the code they are testing. atf-report reports these 257 tests separately but they do not count towards the failed test cases 258 amount. 259 260* Added the ATF_CHECK_ERRNO and ATF_REQUIRE_ERRNO to the C library to 261 allow easy checking of call failures that update errno. 262 263* Added the has.cleanup meta-data property to test caes that specifies 264 whether the test case has a cleanup routine or not; its value is 265 automatically set. This property is read by atf-run to know if it has to 266 run the cleanup routine; skipping this run for every test case 267 significantly speeds up the run time of test suites. 268 269* Reversed the order of the ATF_CHECK_THROW macro in the C++ binding to 270 take the expected exception as the first argument and the statement to 271 execute as the second argument. 272 273Changes in atf-check 274 275* Changed atf-check to support negating the status and output checks by 276 prefixing them with not- and added support to specify multiple checkers 277 for stdout and stderr, not only one. 278 279* Added the match output checker to atf-check to look for regular 280 expressions in the stdout and stderr of commands. 281 282* Modified the exit checks in atf-check to support checking for the 283 reception of signals. 284 285Code simplifications and cleanups 286 287* Removed usage messages from test programs to simplify the 288 implementation of every binding by a significant amount. They just now 289 refer the user to the appropriate manual page and do not attempt to wrap 290 lines on terminal boundaries. Test programs are not supposed to be run 291 by users directly so this minor interface regression is not important. 292 293* Removed the atf-format internal utility, which is unused after the 294 change documented above. 295 296* Removed the atf-cleanup internal utility. It has been unused since the 297 test case isolation was moved to atf-run in 0.8 298 299* Splitted the Makefile.am into smaller files for easier maintenance and 300 dropped the use of M4. Only affects users building from the repository 301 sources. 302 303* Intermixed tests with the source files in the source tree to provide 304 them more visibility and easier access. The tests directory is gone from 305 the source tree and tests are now suffixed by _test, not prefixed by t_. 306 307* Simplifications to the atf-c library: removed the io, tcr and ui 308 modules as they had become unnecessary after all simplifications 309 introduced since the 0.8 release. 310 311* Removed the application/X-atf-tcr format introduced in 0.8 release. 312 Tests now print a much simplified format that is easy to parse and nicer 313 to read by end users. As a side effect, the default for test cases is 314 now to print their results to stdout unless otherwise stated by providing 315 the -r flag. 316 317* Removed XML distribution documents and replaced them with plain-text 318 documents. They provided little value and introduced a lot of complexity 319 to the build system. 320 321* Simplified the output of atf-version by not attempting to print a 322 revision number when building form a distfile. Makes the build system 323 easier to maintain. 324 325 326Changes in version 0.9 327********************** 328 329Experimental version released on June 3rd, 2010. 330 331* Added atf-sh, an interpreter to process test programs written using 332 the shell API. This is not really a shell interpreter by itself though: 333 it is just a wrapper around the system shell that eases the loading of 334 the necessary ATF libraries. 335 336* Removed atf-compile in favour of atf-sh. 337 338* Added the use.fs metadata property to test case, which is used to 339 specify which test cases require file system access. This is to 340 highlight dependencies on external resources more clearly and to speed up 341 the execution of test suites by skipping the creation of many unnecessary 342 work directories. 343 344* Fixed test programs to get a sane default value for their source 345 directory. This means that it should not be necessary any more to pass 346 -s when running test programs that do not live in the current directory. 347 348* Defining test case headers became optional. This is trivial to achieve 349 in shell-based tests but a bit ugly in C and C++. In C, use the new 350 ATF_TC_WITHOUT_HEAD macro to define the test case, and in C++ use 351 ATF_TEST_CASE_WITHOUT_HEAD. 352 353 354Changes in version 0.8 355********************** 356 357Experimental version released on May 7th, 2010. 358 359* Test programs no longer run several test cases in a row. The execution 360 of a test program now requires a test case name, and that single test 361 case is executed. To execute several test cases, use the atf-run utility 362 as usual. 363 364* Test programs no longer fork a subprocess to isolate the execution of 365 test cases. They run the test case code in-process, and a crash of the 366 test case will result in a crash of the test program. This is to ease 367 debugging of faulty test cases. 368 369* Test programs no longer isolate their test cases. This means that they 370 will not create temporary directories nor sanitize the environment any 371 more. Yes: running a test case that depends on system state by hand will 372 most likely yield different results depending on where (machine, 373 directory, user environment, etc.) it is run. Isolation has been moved 374 to atf-run. 375 376* Test programs no longer print a cryptic format (application/X-atf-tcs) 377 on a special file channel. They can now print whatever they want on the 378 screen. Because test programs can now only run one test case every time, 379 providing controlled output is not necessary any more. 380 381* Test programs no longer write their status into a special file 382 descriptor. Instead, they create a file with the results, which is later 383 parsed by atf-run. This changes the semantics of the -r flag. 384 385* atf-run has been adjusted to perform the test case isolation. As a 386 result, there is now a single canonical place that implements the 387 isolation of test caes. In previous releases, the three language 388 bindings (C, C++ and shell) had to be kept in sync with each other (read: 389 not a nice thing to do at all). As a side effect of this change, writing 390 bindings for other languages will be much, much easier from now on. 391 392* atf-run forks test programs on a test case basis, instead of on a test 393 program basis as it did before. This is to provide the test case 394 isolation that was before implemented by the test programs themselves. 395 396* Removed the atf-exec tool. This was used to implement test case 397 isolation in atf-sh, but it is now unnecessary. 398 399* It is now optional to define the descr meta-data property. It has been 400 proven to be mostly useless, because test cases often carry a descriptive 401 name of their own. 402 403 404Changes in version 0.7 405********************** 406 407Experimental version released on December 22nd, 2009. 408 409* Added build-time checks to atf-c and atf-c++. A binding for atf-sh 410 will come later. 411 412* Migrated all build-time checks for header files to proper ATF tests. 413 This demonstrates the use of the new feature described above. 414 415* Added an internal API for child process management. 416 417* Converted all plain-text distribution documents to a Docbook canonical 418 version, and include pre-generated plain text and HTML copies in the 419 distribution file. 420 421* Simplified the contents of the Makefile.am by regenerating it from a 422 canonical Makefile.am.m4 source. As a side-effect, some dependency 423 specifications were fixed. 424 425* Migrated all checks from the check target to installcheck, as these 426 require ATF to be installed. 427 428* Fixed sign comparison mismatches triggered by the now-enabled 429 -Wsign-compare. 430 431* Fixed many memory and object leaks. 432 433 434Changes in version 0.6 435********************** 436 437Experimental version released on January 18th, 2009. 438 439* Make atf-exec be able to kill its child process after a certain period 440 of time; this is controlled through the new -t option. 441 442* Change atf-sh to use atf-exec's -t option to control the test case's 443 timeouts, instead of doing it internally. Same behavior as before, but 444 noticeably faster. 445 446* atf-exec's -g option and atf-killpg are gone due to the previous 447 change. 448 449* Added the atf-check(1) tool, a program that executes a given command 450 and checks its exit code against a known value and allows the management 451 of stdout and stderr in multiple ways. This replaces the previous 452 atf_check function in the atf-sh library and exposes this functionality 453 to both atf-c and atf-c++. 454 455* Added the ATF_REQUIRE family of macros to the C interface. These help 456 in checking for fatal test conditions. The old ATF_CHECK macros now 457 perform non-fatal checks only. I.e. by using ATF_CHECK, the test case 458 can now continue its execution and the failures will not be reported 459 until the end of the whole run. 460 461* Extended the amount of ATF_CHECK_* C macros with new ones to provide 462 more features to the developer. These also have their corresponding 463 counterparts in the ATF_REQUIRE_* family. The new macros (listing the 464 suffixes only) are: _EQ (replaces _EQUAL), _EQ_MSG, _STREQ and 465 _STREQ_MSG. 466 467 468Changes in version 0.5 469********************** 470 471Experimental version released on May 1st, 2008. 472 473* Clauses 3 and 4 of the BSD license used by the project were dropped. 474 All the code is now under a 2-clause BSD license compatible with the GNU 475 General Public License (GPL). 476 477* Added a C-only binding so that binary test programs do not need to be 478 tied to C++ at all. This binding is now known as the atf-c library. 479 480* Renamed the C++ binding to atf-c++ for consistency with the new atf-c. 481 482* Renamed the POSIX shell binding to atf-sh for consistency with the new 483 atf-c and atf-c++. 484 485* Added a -w flag to test programs through which it is possible to 486 specify the work directory to be used. This was possible in prior 487 releases by defining the workdir configuration variable (-v workdir=...), 488 but was a conceptually incorrect mechanism. 489 490* Test programs now preserve the execution order of test cases when they 491 are given in the command line. Even those mentioned more than once are 492 executed multiple times to comply with the user's requests. 493 494 495Changes in version 0.4 496********************** 497 498Experimental version released on February 4th, 2008. 499 500* Added two new manual pages, atf-c++-api and atf-sh-api, describing the 501 C++ and POSIX shell interfaces used to write test programs. 502 503* Added a pkg-config file, useful to get the flags to build against the 504 C++ library or to easily detect the presence of ATF. 505 506* Added a way for test cases to require a specific architecture and/or 507 machine type through the new 'require.arch' and 'require.machine' 508 meta-data properties, respectively. 509 510* Added the 'timeout' property to test cases, useful to set an 511 upper-bound limit for the test's run time and thus prevent global test 512 program stalls due to the test case's misbehavior. 513 514* Added the atf-exec(1) internal utility, used to execute a command 515 after changing the process group it belongs to. 516 517* Added the atf-killpg(1) internal utility, used to kill process groups. 518 519* Multiple portability fixes. Of special interest, full support for 520 SunOS (Solaris Express Developer Edition 2007/09) using the Sun Studio 12 521 C++ compiler. 522 523* Fixed a serious bug that prevented atf-run(1) from working at all 524 under Fedora 8 x86_64. Due to the nature of the bug, other platforms 525 were likely affected too. 526 527 528Changes in version 0.3 529********************** 530 531Experimental version released on November 11th, 2007. 532 533* Added XML output support to atf-report. This is accompanied by a DTD 534 for the format's structure and sample XSLT/CSS files to post-process this 535 output and convert it to a plain HTML report. 536 537* Changed atf-run to add system information to the report it generates. 538 This is currently used by atf-report's XML output only, and is later 539 printed in the HTML reports in a nice and useful summary table. The user 540 and system administrator are allowed to tune this feature by means of 541 hooks. 542 543* Removed the test cases' 'isolated' property. This was intended to 544 avoid touching the file system at all when running the related test case, 545 but this has not been true for a long while: some control files are 546 unconditionally required for several purposes, and we cannot easily get 547 rid of them. This way we remove several critical and delicate pieces of 548 code. 549 550* Improved atf-report's CSV output format to include information about 551 test programs too. 552 553* Fixed the tests that used atf-compile to not require this tool as a 554 helper. Avoids systems without build-time utilities to skip many tests 555 that could otherwise be run. (E.g. NetBSD without the comp.tgz set 556 installed.) 557 558* Many general cleanups: Fixed many pieces of code marked as ugly and/or 559 incomplete. 560 561 562Changes in version 0.2 563********************** 564 565Experimental version released on September 20th, 2007. 566 567* Test cases now get a known umask on entry. 568 569* atf-run now detects many unexpected failures caused by test programs and 570 reports them as bogus tests. atf-report is able to handle these new 571 errors and nicely reports them to the user. 572 573* All the data formats read and written by the tools have been 574 documented and cleaned up. These include those grammars that define how 575 the different components communicate with each other as well as the 576 format of files written by the developers and users: the Atffiles and the 577 configuration files. 578 579* Added the atf-version tool, a utility that displays information about 580 the currently installed version of ATF. 581 582* Test cases can now define an optional cleanup routine to undo their 583 actions regardless of their exit status. 584 585* atf-report now summarizes the list of failed (bogus) test programs 586 when using the ticker output format. 587 588* Test programs now capture some termination signals and clean up any 589 temporary files before exiting the program. 590 591* Multiple bug fixes and improvements all around. 592 593 594Changes in version 0.1 595********************** 596 597Experimental version released on August 20th, 2007. 598 599* First public version. This was released coinciding with the end of the 600 Google Summer of Code 2007 program. 601 602 603=========================================================================== 604vim: filetype=text:textwidth=75:expandtab:shiftwidth=2:softtabstop=2 605