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