tests: add a vlib/v/tests/known_errors/known_errors_test.v test runner
parent
0497b885dc
commit
a1e9cae5d2
14
TESTS.md
14
TESTS.md
|
@ -83,6 +83,20 @@ This *test runner*, checks whether whole project folders, can be compiled, and r
|
|||
NB: Each project in these folders, should finish with an exit code of 0,
|
||||
and it should output `OK` as its last stdout line.
|
||||
|
||||
## `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.
|
||||
|
||||
|
||||
## Test building of actual V programs (examples, tools, V itself)
|
||||
|
||||
* `v build-tools`
|
||||
|
|
|
@ -0,0 +1,36 @@
|
|||
import os
|
||||
|
||||
const vexe = @VEXE
|
||||
|
||||
const vroot = os.dir(vexe)
|
||||
|
||||
const testdata_folder = 'vlib/v/tests/known_errors/testdata'
|
||||
|
||||
fn test_known_errors_testdata_folder_exists() ? {
|
||||
os.chdir(vroot) ?
|
||||
assert os.is_dir(testdata_folder)
|
||||
}
|
||||
|
||||
fn test_known_failures_are_still_failures() ? {
|
||||
mut oks := []string{}
|
||||
mut files := os.walk_ext(testdata_folder, '.v')
|
||||
files << os.walk_ext(testdata_folder, '.vv')
|
||||
for f in files {
|
||||
cmd := '${os.quoted_path(vexe)} ${os.quoted_path(f)}'
|
||||
println('known compilation failure: $cmd')
|
||||
res := os.execute(cmd)
|
||||
if res.exit_code == 0 {
|
||||
oks << cmd
|
||||
println(' unexpectedly COMPILED: $cmd')
|
||||
} else {
|
||||
assert true
|
||||
}
|
||||
}
|
||||
println('Summary: $files.len files, $oks.len unexpectedly succeeded.')
|
||||
if oks.len != 0 {
|
||||
for cmd in oks {
|
||||
println(' expected to fail, but SUCCEEDED command: $cmd')
|
||||
}
|
||||
assert false
|
||||
}
|
||||
}
|
|
@ -0,0 +1,18 @@
|
|||
module main
|
||||
|
||||
import rand
|
||||
import rand.wyrand
|
||||
import rand.splitmix64
|
||||
|
||||
fn main() {
|
||||
mut wyrand_rng := &rand.PRNG(&wyrand.WyRandRNG{})
|
||||
mut splitmix_rng := &rand.PRNG(&splitmix64.SplitMix64RNG{})
|
||||
|
||||
mut generators := [wyrand_rng, splitmix_rng]
|
||||
for mut rng in generators {
|
||||
seed_len := rng.block_size() / 32
|
||||
// NB: `seed_len := (*rng).block_size() / 32` does compile
|
||||
dump(seed_len)
|
||||
println(rng.string(15))
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue