2020-09-07 13:48:15 +02:00
|
|
|
# Automated tests
|
|
|
|
|
2022-01-18 13:55:02 +01:00
|
|
|
TLDR: do run `v test-all` locally, after making your changes,
|
2021-01-17 15:04:08 +01:00
|
|
|
and before submitting PRs.
|
|
|
|
|
2022-01-18 13:55:02 +01:00
|
|
|
Tip: use `v -cc tcc` when compiling tests, because TCC is much faster,
|
|
|
|
compared to most other C compilers like clang/gcc/msvc. Most test commands
|
|
|
|
will use the V compiler and the V tools many times, potentially
|
|
|
|
hundreds/thousands of times.
|
2020-09-07 13:48:15 +02:00
|
|
|
|
2022-01-18 13:55:02 +01:00
|
|
|
## `v test-all`
|
|
|
|
|
|
|
|
Test and build *everything*. Usefull to verify *locally*, that the CI will
|
|
|
|
most likely pass. Slowest, but most comprehensive.
|
|
|
|
|
|
|
|
It works, by running these in succession:
|
|
|
|
* `v test-cleancode`
|
|
|
|
* `v test-self`
|
|
|
|
* `v test-fmt`
|
|
|
|
* `v build-tools`
|
|
|
|
* `v build-examples`
|
|
|
|
* `v check-md -hide-warnings .`
|
|
|
|
* `v install nedpals.args`
|
|
|
|
|
|
|
|
# Details:
|
|
|
|
In the `v` repo there are many tests. The main types are:
|
|
|
|
|
|
|
|
## `_test.v` tests - these are the normal V test files.
|
|
|
|
All `test_` functions in these files, will be ran automatically by
|
|
|
|
V's test framework.
|
|
|
|
|
|
|
|
NB 1: You can run test files one by one, with:
|
|
|
|
`v file_test.v` - this will run the test_ functions in file_test.v,
|
|
|
|
and will exit with a 0 exit code, if they all had 0 failing assertions.
|
|
|
|
|
|
|
|
`v -stats file_test.v` - this will run the test_ functions, and show a
|
|
|
|
report about how much time it took to run each of them too.
|
|
|
|
|
|
|
|
NB 2: You can also run many test files at once (in parallel, depending on
|
|
|
|
how many cores you have), with:
|
|
|
|
`v test folder` - this will run *all* `_test.v` files in `folder`,
|
|
|
|
recursively.
|
2020-09-07 13:48:15 +02:00
|
|
|
|
2022-01-18 13:55:02 +01:00
|
|
|
`v -stats test folder` - same, but will also produce timing reports
|
|
|
|
about how fast each test_ function in each _test.v file ran.
|
2020-09-07 13:48:15 +02:00
|
|
|
|
|
|
|
|
2022-01-18 13:55:02 +01:00
|
|
|
## `v test vlib/v/tests`:
|
2020-09-07 13:48:15 +02:00
|
|
|
|
2022-01-18 13:55:02 +01:00
|
|
|
This folder contains _test.v files, testing the different features of the V
|
|
|
|
compiler. Each of them will be compiled, and all the features in them have
|
|
|
|
to work (verified by assertions).
|
2021-02-22 13:54:24 +01:00
|
|
|
|
2022-01-18 13:55:02 +01:00
|
|
|
## `v vlib/v/tests/inout/compiler_test.v`
|
2021-02-22 13:54:24 +01:00
|
|
|
|
2022-01-18 13:55:02 +01:00
|
|
|
This is a *test runner*, that checks whether the output of running a V program,
|
|
|
|
matches an expected .out file. You can also check for code that does panic
|
|
|
|
using this test runner - just paste the start of the `panic()` output in the
|
|
|
|
corresponding .out file.
|
2021-07-31 11:29:22 +02:00
|
|
|
|
2022-01-18 13:55:02 +01:00
|
|
|
NB: these tests, expect to find a pair of `.vv` and `.out` files, in the folder:
|
|
|
|
vlib/v/tests/inout
|
2021-07-31 11:29:22 +02:00
|
|
|
|
2022-01-18 13:55:02 +01:00
|
|
|
The test runner will run each `.vv` file, and will check that its output, matches
|
|
|
|
the contents of the `.out` file with the same base name. This is particularly useful
|
|
|
|
for checking that errors and panics are printed.
|
|
|
|
|
|
|
|
## `v vlib/v/gen/c/coutput_test.v`
|
|
|
|
|
|
|
|
coutput_test.v is a *test runner*, that checks whether the generated C source
|
|
|
|
code matches *all* expectations, specified in *.c.must_have files, in the
|
|
|
|
folder vlib/v/gen/c/testdata/ .
|
|
|
|
|
|
|
|
Each `.c.must_have` file, *has* to have a corresponding `.vv` file.
|
2021-07-31 11:29:22 +02:00
|
|
|
|
|
|
|
Each `.c.must_have` file, consists of multiple lines. Each of these
|
|
|
|
lines, *should* be present *at least once* in the output, when the .vv
|
|
|
|
file is compiled with `-o -` .
|
|
|
|
|
2022-01-18 13:55:02 +01:00
|
|
|
## `v vlib/v/tests/run_project_folders_test.v`
|
|
|
|
This *test runner*, checks whether whole project folders, can be compiled, and run.
|
|
|
|
|
|
|
|
NB: Each project in these folders, should finish with an exit code of 0,
|
2021-05-06 20:08:33 +02:00
|
|
|
and it should output `OK` as its last stdout line.
|
|
|
|
|
2022-04-03 11:44:22 +02:00
|
|
|
## `v vlib/v/tests/known_errors/known_errors_test.v`
|
|
|
|
This *test runner*, checks whether a known program, that was expected to compile,
|
|
|
|
but did NOT, due to a buggy checker, parser or cgen, continues to fail.
|
|
|
|
The negative programs are collected in the `vlib/v/tests/known_errors/testdata/` folder.
|
|
|
|
Each of them should FAIL to compile, due to a known/confirmed compiler bug/limitation.
|
|
|
|
|
|
|
|
The intended use of this, is for providing samples, that currently do NOT compile,
|
|
|
|
but that a future compiler improvement WILL be able to compile, and to
|
|
|
|
track, whether they were not fixed incidentally, due to an unrelated
|
|
|
|
change/improvement. For example, code that triggers generating invalid C code can go here,
|
|
|
|
and later when a bug is fixed, can be moved to a proper _test.v or .vv/.out pair, outside of
|
|
|
|
the `vlib/v/tests/known_errors/testdata/` folder.
|
|
|
|
|
|
|
|
|
2021-01-17 15:04:08 +01:00
|
|
|
## Test building of actual V programs (examples, tools, V itself)
|
2020-09-07 13:48:15 +02:00
|
|
|
|
|
|
|
* `v build-tools`
|
2021-01-17 15:04:08 +01:00
|
|
|
* `v build-examples`
|
|
|
|
* `v build-vbinaries`
|
2020-09-07 13:48:15 +02:00
|
|
|
|
2022-01-18 13:55:02 +01:00
|
|
|
## Formatting tests
|
2020-09-07 13:48:15 +02:00
|
|
|
|
2022-01-18 13:55:02 +01:00
|
|
|
In `vlib/v/fmt/` there are:
|
2020-09-07 13:48:15 +02:00
|
|
|
|
2021-01-17 15:04:08 +01:00
|
|
|
* `v vlib/v/fmt/fmt_test.v`
|
2020-09-07 13:48:15 +02:00
|
|
|
|
|
|
|
This checks `.out` tests.
|
|
|
|
|
2021-01-17 15:04:08 +01:00
|
|
|
* `v vlib/v/fmt/fmt_keep_test.v`
|
2020-09-07 13:48:15 +02:00
|
|
|
|
2022-01-18 13:55:02 +01:00
|
|
|
This verifies that all `_keep.vv` files in the `vlib/v/fmt/tests/` folder,
|
|
|
|
would be unchanged by `v fmt -w`, i.e. that the v source code formatter,
|
|
|
|
generates a stable source output, that does not change, once it is already
|
|
|
|
formatted once.
|
2020-09-07 13:48:15 +02:00
|
|
|
|
2021-01-17 15:04:08 +01:00
|
|
|
* `v vlib/v/fmt/fmt_vlib_test.v`
|
2020-09-07 13:48:15 +02:00
|
|
|
|
2022-01-18 13:55:02 +01:00
|
|
|
This checks that all V source files are formatted, and prints a summary.
|
2021-01-17 15:04:08 +01:00
|
|
|
This is not required.
|
2020-09-07 13:48:15 +02:00
|
|
|
|
2022-01-18 13:55:02 +01:00
|
|
|
* `v test-cleancode`
|
|
|
|
|
|
|
|
Check that most .v files, are invariant of `v fmt` runs.
|
|
|
|
|
2020-09-07 13:48:15 +02:00
|
|
|
* `v test-fmt`
|
|
|
|
|
2022-01-18 13:55:02 +01:00
|
|
|
This tests that all .v files in the current folder are already formatted.
|
|
|
|
It is useful for adding to CI jobs, to guarantee, that future contributions
|
|
|
|
will keep the existing source nice and clean.
|
2020-09-07 13:48:15 +02:00
|
|
|
|
2022-01-18 13:55:02 +01:00
|
|
|
## Markdown/documentation checks:
|
2021-02-22 13:54:24 +01:00
|
|
|
|
2021-02-05 16:46:20 +01:00
|
|
|
* `v check-md -hide-warnings .`
|
2021-01-17 15:04:08 +01:00
|
|
|
|
|
|
|
Ensure that all .md files in the project are formatted properly,
|
|
|
|
and that the V code block examples in them can be compiled/formatted too.
|
|
|
|
|
2021-01-19 09:41:51 +01:00
|
|
|
## `v test-self`
|
2021-01-17 15:04:08 +01:00
|
|
|
|
|
|
|
Run `vlib` module tests, *including* the compiler tests.
|
|
|
|
|
|
|
|
## `v vlib/v/compiler_errors_test.v`
|
|
|
|
|
|
|
|
This runs tests for:
|
2022-01-18 13:55:02 +01:00
|
|
|
* `vlib/v/scanner/tests/*.vv`
|
2021-06-26 00:18:51 +02:00
|
|
|
* `vlib/v/checker/tests/*.vv`
|
|
|
|
* `vlib/v/parser/tests/*.vv`
|
|
|
|
|
2022-01-18 13:55:02 +01:00
|
|
|
NB: there are special folders, that compiler_errors_test.v will try to
|
2021-06-26 00:18:51 +02:00
|
|
|
run/compile with specific options:
|
|
|
|
|
|
|
|
vlib/v/checker/tests/globals_run/ - `-enable-globals run`;
|
|
|
|
results stored in `.run.out` files, matching the .vv ones.
|
2021-01-17 15:04:08 +01:00
|
|
|
|
2022-01-18 13:55:02 +01:00
|
|
|
NB 2: in case you need to modify many .out files, run *twice* in a row:
|
|
|
|
`VAUTOFIX=1 ./v vlib/v/compiler_errors_test.v`
|
|
|
|
This will fail the first time, but it will record the new output for each
|
|
|
|
.vv file, and store it into the corresponding .out file. The second run
|
|
|
|
should be now successfull, and so you can inspect the difference, and
|
|
|
|
commit the new .out files with minimum manual effort.
|
2021-01-17 15:04:08 +01:00
|
|
|
|
2022-01-18 13:55:02 +01:00
|
|
|
NB 3: To run only some of the tests, use:
|
|
|
|
`VTEST_ONLY=mismatch ./v vlib/v/compiler_errors_test.v`
|
|
|
|
This will check only the .vv files, whose paths match the given filter.
|
2021-01-17 15:04:08 +01:00
|
|
|
|
2022-01-18 13:55:02 +01:00
|
|
|
## `.github/workflows/ci.yml`
|
|
|
|
|
|
|
|
This is a Github Actions configuration file, that runs various CI
|
|
|
|
tests in the main V repository, for example:
|
|
|
|
|
|
|
|
* `v vet vlib/v` - run a style checker.
|
|
|
|
* `v test-self` (run self tests) in various compilation modes.
|