Simon Krajewski ce6e328f68 run coro tests on HL CI 1 tahun lalu
..
benchs aff9c5182a [tests] clean up a bit 2 tahun lalu
display a45316cd3f allow `@:using` with Class and Enum (#11553) 1 tahun lalu
docgen f43f3cb8ed [ci] add tests for api documentation generation (#10950) 2 tahun lalu
misc 78a7cedc52 Make hl works for tests 1 tahun lalu
nullsafety 71f36636dc Make break/continue exprs not-nullable (#11269) 2 tahun lalu
optimization dbc9952adf don't double-throw all exceptions 1 tahun lalu
runci ce6e328f68 run coro tests on HL CI 1 tahun lalu
server bf3d81ad66 [tests] use coroutines for server tests 1 tahun lalu
sourcemaps 8fd670dae7 [typer] Prepare for typer creation delaying (#11324) 2 tahun lalu
sys 2dfc0d920b Remove C# and Java targets (#11551) 1 tahun lalu
threads 9717436a87 [eval] fix event loop (#11028) 2 tahun lalu
unit 4aa876b8ca [lua] Share metatables with other class instances (#11103) 1 tahun lalu
.gitattributes 08d190aab0 Preserve line-endings for all tests. 10 tahun lalu
Brewfile c3c206f3fc Fix macOS CI. (#11503) 1 tahun lalu
PHP.ini 28d6e1142e [hl, php] Enable sqlite tests and others (#10597) 3 tahun lalu
README.md 2dfc0d920b Remove C# and Java targets (#11551) 1 tahun lalu
RunCi.hx 72a202ca7b [ci] use utest fork coro branch for now 1 tahun lalu
RunCi.hxml da2836597b Clean up CLI usage/help output, standardize flag naming (#6862) 7 tahun lalu

README.md

Tests

We have a number of test suites, which are placed in their own folders in this directory.

"RunCi.hx" is the script used by our CIs to run all the test suites.

Local testing

It is possible to run it in local machines too:

  1. Change to this directory.
  2. Define the test target by export TEST=$TARGET (or set "TEST=$TARGET" on Windows), where $TARGET should be a comma-seperated list of targets, e.g. neko,macro. Possible targets are macro, neko, js, lua, php, cpp, cppia, flash, jvm, python, and hl.
  3. Run the script: haxe RunCi.hxml.

Note that the script will try to look for test dependencies and install them if they are not found. Look at the getXXXDependencies functions for the details.

Unit tests

The "unit" folder contains a set of unit tests for the Haxe std library. Unit tests can be run separately instead of using "RunCi.hx", which runs all test suites.

Assuming all test dependencies has been installed, we compile and run the unit tests for all targets at once as follows:

  1. Change to the "unit" directory.
  2. Compile: haxe compile.hxml.
  3. Start a dev server: nekotools server.
  4. Open http://localhost:2000/unit.html in your browser.

Cpp unit tests

Cpp unit tests are compiled with -D HXCPP_NO_DEBUG_LINK (removes debug symbols) to speed up compilation times. You can remove this from compile-cpp.hxml to be able to open the generated Test-debug.exe in Visual Studio and debug it. This is useful if it's difficult to figure out why a test is failing, or also which test is failing (for instance with a segmentation fault).

Sys tests

The "sys" folder contains tests for the system targets. It can also be run separately instead of using "RunCi.hx".

Assuming all test dependencies has been installed, we compile and run the sys tests for all targets at once as follows:

  1. Change to the "sys" directory.
  2. If you're on Windows, comment out the relevant lines in "run.hxml". haxe run.hxml.