lyx_mirror/development/autotests
Scott Kostyshak 1aa4987b2f Address failures of Seminar examples on new TL20
Compilation of our Seminar example file fails on updated TL20. The
maintainer of "Seminar" is not planning to fix the core issue and
states the following (in a private email with permission to quote):

  it is a problem with the new hook management of the current latex.ltx
  seminar is a quite old package and there is no reason to use it with a
  new LaTeX format. It won't be fixed, so the usual way is to use the
  package latexrealease to get the old hook management.

This commit adds a note to the example files explaining the
workaround of exporting to a .tex file and prepending the following
line:

  \RequirePackage[2020-02-02]{latexrelease}

We now invert the relevant tests.
2020-10-29 23:29:26 -04:00
..
xvkbd
beginEndStructureCheck.pl
bug-7673-in.txt
bug-7673.lyx
bug-7673b-in.txt
bug-8370-in.txt
bug-8370.lyx
bug-8482-in.txt
bug-8540-in.txt
bug-8684-in.txt
bug-8684.lyx
bug-10636-in.txt Modify 2 tests to reflect actual GUI 2020-05-30 11:14:26 +02:00
bug-10636.lyx
bug-export-latex-in.txt Modify 2 tests to reflect actual GUI 2020-05-30 11:14:26 +02:00
bug-math-undo-in.txt
check_load.cmake
CheckLoadErrors.cmake
CMakeLists.txt vcs_info_export moved to new directory, part 2 2018-01-17 12:25:22 +01:00
examineXmllintOutput.pl Cmake export xhtml tests: load dtd if checking ouput with xmllint 2020-09-20 11:47:04 +02:00
export-in.sh
export.cmake Cmake tests: Amend 667c0647: Use jing to test only docbook5 exports 2020-10-13 15:42:29 +02:00
ExportTests.cmake Amend 31ad4d6e: DocBook: move tests to inverted instead of ignored. 2020-10-17 12:58:30 +02:00
filterCheckWarnings Some more tests which are not failin anymore 2019-03-25 19:32:59 +01:00
filterXml4Sax.pl Fix filterXml4Sax.pl to work under Windows 2020-10-13 21:38:38 +02:00
findadv-01-in.txt Changes to match math equations 2018-10-28 19:40:14 +01:00
findadv-02-in.txt Changes to match math equations 2018-10-28 19:40:14 +01:00
findadv-03-in.txt
findadv-04-in.txt
findadv-05-in.txt FindAdv: Correct some testcases 2020-05-29 14:22:34 +02:00
findadv-06-in.txt FindAdv: Correct some testcases 2020-05-29 14:22:34 +02:00
findadv-07-in.txt FindAdv: Correct some testcases 2020-05-29 14:22:34 +02:00
findadv-08-in.txt findadv tests: Adapt one test for the new greedy behaviour 2018-11-26 16:00:27 +01:00
findadv-09-in.txt FindAdv: Correct some testcases 2020-05-29 14:22:34 +02:00
findadv-10-in.txt FindAdv: Correct some testcases 2020-05-29 14:22:34 +02:00
findadv-11-in.txt FindAdv: Correct some testcases 2020-05-29 14:22:34 +02:00
findadv-12-in.txt
findadv-13-in.txt
findadv-14-in.txt FindAdv: Correct some testcases 2020-05-29 14:22:34 +02:00
findadv-15-in.txt FindAdv: Correct some testcases 2020-05-29 14:22:34 +02:00
findadv-16-in.txt FindAdv: Correct next test (keytest/findadv-16) 2020-05-29 20:04:57 +02:00
findadv-17-in.txt FindAdv: next 3 tests working 2020-05-29 20:18:45 +02:00
findadv-18-in.txt
findadv-19-in.txt Changes to match math equations 2018-10-28 19:40:14 +01:00
findadv-20-in.txt
findadv-21-in.txt FindAdv: next 3 tests working 2020-05-29 20:18:45 +02:00
findadv-22-in.txt FindAdv: next 3 tests working 2020-05-29 20:18:45 +02:00
findadv-combined-in.txt Findadv: Remaining findadv tests pass now 2018-10-29 13:17:54 +01:00
findadv-crash-in.txt
findadv-logo-in.txt FindAdv: Remaining tests working now again 2020-05-29 20:56:38 +02:00
findadv-re-01-in.txt FindAdv: Correct some testcases 2020-05-29 14:22:34 +02:00
findadv-re-02-in.txt FindAdv: Remaining tests working now again 2020-05-29 20:56:38 +02:00
findadv-re-03-in.txt FindAdv: Remaining tests working now again 2020-05-29 20:56:38 +02:00
findadv-re-04-in.txt FindAdv: Remaining tests working now again 2020-05-29 20:56:38 +02:00
findadv-re-05-in.txt
findadv-re-06-in.txt FindAdv: Remaining tests working now again 2020-05-29 20:56:38 +02:00
first-time-in.txt
getTempDir.pl
hello-world-in.txt
ignoredTests ctests: ignore zh_CN dvi3_systemF tests 2020-10-27 23:08:25 -04:00
ignoreLatexErrorsTests Revert "Ignore missing glyphs for fr/Customization.lyx" 2020-08-29 15:20:49 +02:00
invertedTests Address failures of Seminar examples on new TL20 2020-10-29 23:29:26 -04:00
keytest.py Changes to match math equations 2018-10-28 19:40:14 +01:00
lyx2lyxtest.cmake
lyxStatus.pm Cmake export tests: Set \origin also for unavailable 2019-03-31 18:17:04 +02:00
Makefile
README
run-tests.sh
searchPatterns.pl
single-test.cmake
single-test.sh
stop_autotests.tcl
stop.gif
suspendedTests Cmake export tests: Suspend some Foils compilations with system fonts 2019-12-16 11:59:02 +01:00
tabular-footnote-in.txt
unreliableTests ctests: ignore zh_CN dvi3_systemF tests 2020-10-27 23:08:25 -04:00
useSystemFonts.pl Cmake export tests: Set \origin also for unavailable 2019-03-31 18:17:04 +02:00
xmlParser.pl Cmake docbook tests: Check for correct use of namespaces 2020-08-22 17:40:34 +02:00

Automated tests based on the "MonKey Testing" keytest program.
======================================================================

WARNING!!
----------------------------------------------------------------------
Running the tests in this folder may cause abrupt kill of existing
LyX instances on your system. In order to avoid any possible data
loss, quit any running instance of LyX in which you're carrying out
real work. Also, although precautions have been taken in order to not
allow the key presses to reach non-LyX windows, this may sometimes
happen anyway. Please, close any running application that is not
strictly needed.


DEPENDENCIES
----------------------------------------------------------------------
The following programs are needed by the testing framework:
- xvkbd: a modified copy of xvkbd is included in this folder, and should
         be built before running the tests
- wmctrl
- pcregrep
- Tcl/Tk (wish8.5)


USAGE
----------------------------------------------------------------------
In order to launch all the tests available in this folder, just run

  make

and do not interact with your computer while the tests are running.

If you wish to launch one or more specific tests, then provide them
as argument to the run-tests.sh script, e.g.:

  ./run-tests.sh <whatever>*-in.txt

For failed tests you get a folder with the logs that help you identify
the problem.

Despite the efforts to avoid it, sometimes a test fails simply because
the key presses provided to the process are someway lost due to slow
hardware, slow window manager, too beautiful and animated desktop,...
When this happens, the tests should be run with a higher delay among
key presses. The default of 100 milliseconds can be changed by setting
the XVKBD_DELAY environment variable.

The standard xvkbd available on your system may be used to run the
tests. However, a custom xvkbd may optionally be used that forbids the
testing framework to type into non-LyX windows and may mitigate the
issue described right above. This option can be activated by defining
the XVKBD_HACKED environment variable to any value.


SYNTAX
----------------------------------------------------------------------
Each test-case script should be named as xxx-in.txt. The syntax of the
script is described in detail in the sample test-case script
hello-world-in.txt.

Alternatively, a test-case can be an arbitrary executable script with
name ending in "-in.sh", that is launched inside a dedicated folder,
and to which the variables LYX_ROOT and LYX_EXE are exported, so that
you can easily reference the root LyX sources folder and the program
executable. The test script needs to complete with a no-error return
value (zero), otherwise a failure is reported (see export-in.sh for
an example).

Whenever LyX is launched, in both cases, the LYX_USERDIR variable is
set to autotests/out-home, in order to rely on clean preferences
settings (use make clean or make without arguments in order to let
that folder be created again).


TODO
----------------------------------------------------------------------
Speed-up the execution of the tests as much as possible (i.e., get rid
of heuristic waits when present and replace them with exact check of
the condition we're waiting for).

Allow for tests with multiple LyX instances, e.g., for copy&paste
across LyX instances, or multiple applications, i.e., for testing
the interaction between LyX and other applications.

The modified xvkbd forces the focus on the specified target window
(for safety reasons).  Allow for a temporary disable of this within
the scripts, whenever we need to interact with a pop-up dialog.