diff options
author | Stefan Monnier <monnier@iro.umontreal.ca> | 2022-09-25 16:15:16 -0400 |
---|---|---|
committer | Stefan Monnier <monnier@iro.umontreal.ca> | 2022-09-25 16:15:16 -0400 |
commit | 650c20f1ca4e07591a727e1cfcc74b3363d15985 (patch) | |
tree | 85d11f6437cde22f410c25e0e5f71a3131ebd07d /test/README | |
parent | 8869332684c2302b5ba1ead4568bbc7ba1c0183e (diff) | |
parent | 4b85ae6a24380fb67a3315eaec9233f17a872473 (diff) | |
download | emacs-650c20f1ca4e07591a727e1cfcc74b3363d15985.tar.gz emacs-650c20f1ca4e07591a727e1cfcc74b3363d15985.tar.bz2 emacs-650c20f1ca4e07591a727e1cfcc74b3363d15985.zip |
Merge 'master' into noverlay
Diffstat (limited to 'test/README')
-rw-r--r-- | test/README | 118 |
1 files changed, 109 insertions, 9 deletions
diff --git a/test/README b/test/README index aced1a4414e..17783a4bacf 100644 --- a/test/README +++ b/test/README @@ -1,4 +1,4 @@ -Copyright (C) 2008-2017 Free Software Foundation, Inc. +Copyright (C) 2008-2022 Free Software Foundation, Inc. See the end of the file for license conditions. This directory contains files intended to test various aspects of @@ -7,16 +7,37 @@ Emacs's functionality. Please help add tests! See the file file-organization.org for the details of the directory structure and file-naming conventions. +For tests in the manual/ subdirectory, look there for separate README +files, or look for instructions in the test files themselves. + Emacs uses ERT, Emacs Lisp Regression Testing, for testing. See (info "(ert)") or https://www.gnu.org/software/emacs/manual/html_node/ert/ for more information on writing and running tests. -The Makefile in this directory supports the following targets: +Tests could be tagged by the developer. In this test directory, the +following tags are recognized: + +* :expensive-test + The test needs a serious amount of time to run. It is not intended + to run on a regular basis by users. Instead, it runs on demand + only, or during regression tests. + +* :nativecomp + The test runs only if Emacs is configured with Lisp native compiler + support. + +* :unstable + The test is under development. It shall run on demand only. + +The Makefile sets the environment variable $EMACS_TEST_DIRECTORY, +which points to this directory. This environment variable does not +exist when the tests are run outside make. The Makefile supports the +following targets: * make check - Run all tests as defined in the directory. Expensive tests are - suppressed. The result of the tests for <filename>.el is stored in - <filename>.log. + Run all tests as defined in the directory. Expensive and unstable + tests are suppressed. The result of the tests for <filename>.el is + stored in <filename>.log. * make check-maybe Like "make check", but run only the tests for files which have @@ -25,11 +46,22 @@ The Makefile in this directory supports the following targets: * make check-expensive Like "make check", but run also the tests marked as expensive. -* make <filename> or make <filename>.log +* make check-all + Like "make check", but run all tests. + +* make check-<dirname> + Like "make check", but run only the tests in test/<dirname>/*.el. + <dirname> is a relative directory path, which has replaced "/" by "-", + like in "check-src" or "check-lisp-net". + +* make <filename> -or- make <filename>.log Run all tests declared in <filename>.el. This includes expensive tests. In the former case the output is shown on the terminal, in the latter case the output is written to <filename>.log. +<filename> could be either a relative file name like +"lisp/files-tests", or a package name like "files-tests". + ERT offers selectors, which make it possible to filter out which test cases shall run. The make variable $(SELECTOR) gives you a simple mean to use your own selectors. The ERT manual describes how @@ -38,14 +70,82 @@ https://www.gnu.org/software/emacs/manual/html_node/ert/Test-Selectors.html You could use predefined selectors of the Makefile. "make <filename> SELECTOR='$(SELECTOR_DEFAULT)'" runs all tests for <filename>.el -except the tests tagged as expensive. +except the tests tagged as expensive or unstable. Other predefined +selectors are $(SELECTOR_EXPENSIVE) (run all tests except unstable +ones) and $(SELECTOR_ALL) (run all tests). If your test file contains the tests "test-foo", "test2-foo" and "test-foo-remote", and you want to run only the former two tests, you -could use a selector regexp: "make <filename> SELECTOR='\"foo$$\"'". +could use a selector regexp (note that the "$" needs to be doubled to +protect against "make" variable expansion): + + make <filename> SELECTOR='"foo$$"' + +In case you want to use the symbol name of a test as selector, you can +use it directly: + + make <filename> SELECTOR='test-foo-remote' + +Note that although the test files are always compiled (unless they set +no-byte-compile), the source files will be run when expensive or +unstable tests are involved, to give nicer backtraces. To run the +compiled version of a test use + + make TEST_LOAD_EL=no ... + +Some tests might take long time to run. In order to summarize the +<nn> tests with the longest duration, call + + make SUMMARIZE_TESTS=<nn> ... + +The backtrace of failing tests are truncated to the default value of +'ert-batch-backtrace-right-margin'. To see more of the backtrace, use + + make TEST_BACKTRACE_LINE_LENGTH=<nn> ... + +The tests are run in batch mode by default; sometimes it's useful to +get precisely the same environment but run in interactive mode for +debugging. To do that, use + + make TEST_INTERACTIVE=yes ... + +By default, ERT test failure summaries are quite brief in batch +mode--only the names of the failed tests are listed. If the +$EMACS_TEST_VERBOSE environment variable is set and non-empty, the +failure summaries will also include the data from the failing test. + +If the $EMACS_TEST_JUNIT_REPORT environment variable is set to a file +name, a JUnit test report is generated under this name. + +Some of the tests require a remote temporary directory +(autorevert-tests.el, dnd-tests.el, filenotify-tests.el, +shadowfile-tests.el and tramp-tests.el). Per default, a mock-up +connection method is used (this might not be possible when running on +MS Windows). If you want to test a real remote connection, set +$REMOTE_TEMPORARY_FILE_DIRECTORY to a suitable value in order to +overwrite the default value: + + env REMOTE_TEMPORARY_FILE_DIRECTORY=/ssh:host:/tmp make ... + + +There are also continuous integration tests on +<https://hydra.nixos.org/jobset/gnu/emacs-trunk> (see +admin/notes/hydra) and <https://emba.gnu.org/emacs/emacs> (see +admin/notes/emba). Both environments provide an environment variable, +which could be used to determine, whether the tests run in one of +these test environments. + +$EMACS_HYDRA_CI indicates the hydra environment, and $EMACS_EMBA_CI +indicates the emba environment, respectively. + +If tests on these premises take too long, and it is needed to create a +core dump for further analysis, the environment variable +$EMACS_TEST_TIMEOUT could set a limit (in seconds) when this shall +happen. -(Also, see etc/compilation.txt for compilation mode font lock tests.) +(Also, see etc/compilation.txt for compilation mode font lock tests +and etc/grep.txt for grep mode font lock tests.) This file is part of GNU Emacs. |