ci: fix compilation of the test infrastructure

pull/7430/head^2
Delyan Angelov 2020-12-20 18:27:42 +02:00
parent 50a6976b5e
commit 969f8f1a75
2 changed files with 16 additions and 21 deletions

View File

@ -5,8 +5,8 @@ import os.cmdline
import testing import testing
fn main() { fn main() {
args := os.args args := os.args.clone()
if args.last() == 'test' { if os.args.last() == 'test' {
println('Usage:') println('Usage:')
println(' A)') println(' A)')
println(' v test folder/ : run all v tests in the given folder.') println(' v test folder/ : run all v tests in the given folder.')

View File

@ -47,10 +47,14 @@ fn test_all() {
mut tasks := []TaskDescription{} mut tasks := []TaskDescription{}
tasks.add(vexe, parser_dir, '-prod', '.out', parser_tests, false) tasks.add(vexe, parser_dir, '-prod', '.out', parser_tests, false)
tasks.add(vexe, checker_dir, '-prod', '.out', checker_tests, false) tasks.add(vexe, checker_dir, '-prod', '.out', checker_tests, false)
tasks.add(vexe, checker_dir, '-d mysymbol run', '.mysymbol.run.out', ['custom_comptime_define_error.vv'], false) tasks.add(vexe, checker_dir, '-d mysymbol run', '.mysymbol.run.out', ['custom_comptime_define_error.vv'],
tasks.add(vexe, checker_dir, '-d mydebug run', '.mydebug.run.out', ['custom_comptime_define_if_flag.vv'], false) false)
tasks.add(vexe, checker_dir, '-d nodebug run', '.nodebug.run.out', ['custom_comptime_define_if_flag.vv'], false) tasks.add(vexe, checker_dir, '-d mydebug run', '.mydebug.run.out', ['custom_comptime_define_if_flag.vv'],
tasks.add(vexe, checker_dir, '--enable-globals run', '.run.out', ['globals_error.vv'], false) false)
tasks.add(vexe, checker_dir, '-d nodebug run', '.nodebug.run.out', ['custom_comptime_define_if_flag.vv'],
false)
tasks.add(vexe, checker_dir, '--enable-globals run', '.run.out', ['globals_error.vv'],
false)
tasks.add(vexe, global_dir, '--enable-globals', '.out', global_tests, false) tasks.add(vexe, global_dir, '--enable-globals', '.out', global_tests, false)
tasks.add(vexe, module_dir, '-prod run', '.out', module_tests, true) tasks.add(vexe, module_dir, '-prod run', '.out', module_tests, true)
tasks.add(vexe, run_dir, 'run', '.run.out', run_tests, false) tasks.add(vexe, run_dir, 'run', '.run.out', run_tests, false)
@ -58,9 +62,7 @@ fn test_all() {
} }
fn (mut tasks []TaskDescription) add(vexe string, dir string, voptions string, result_extension string, tests []string, is_module bool) { fn (mut tasks []TaskDescription) add(vexe string, dir string, voptions string, result_extension string, tests []string, is_module bool) {
paths := vtest.filter_vtest_only(tests, { paths := vtest.filter_vtest_only(tests, basepath: dir)
basepath: dir
})
for path in paths { for path in paths {
tasks << TaskDescription{ tasks << TaskDescription{
vexe: vexe vexe: vexe
@ -73,7 +75,6 @@ fn (mut tasks []TaskDescription) add(vexe string, dir string, voptions string, r
} }
} }
fn bstep_message(mut bench benchmark.Benchmark, label string, msg string, sduration time.Duration) string { fn bstep_message(mut bench benchmark.Benchmark, label string, msg string, sduration time.Duration) string {
return bench.step_message_with_label_and_duration(label, msg, sduration) return bench.step_message_with_label_and_duration(label, msg, sduration)
} }
@ -85,7 +86,7 @@ fn (mut tasks []TaskDescription) run() {
bench.set_total_expected_steps(tasks.len) bench.set_total_expected_steps(tasks.len)
mut work := sync.new_channel<TaskDescription>(tasks.len) mut work := sync.new_channel<TaskDescription>(tasks.len)
mut results := sync.new_channel<TaskDescription>(tasks.len) mut results := sync.new_channel<TaskDescription>(tasks.len)
mut m_skip_files := skip_files mut m_skip_files := skip_files.clone()
$if noskip ? { $if noskip ? {
m_skip_files = [] m_skip_files = []
} }
@ -161,9 +162,7 @@ fn (mut task TaskDescription) execute() {
} }
program := task.path program := task.path
cli_cmd := '$task.vexe $task.voptions $program' cli_cmd := '$task.vexe $task.voptions $program'
res := os.exec(cli_cmd) or { res := os.exec(cli_cmd) or { panic(err) }
panic(err)
}
mut expected := os.read_file(program.replace('.vv', '') + task.result_extension) or { mut expected := os.read_file(program.replace('.vv', '') + task.result_extension) or {
panic(err) panic(err)
} }
@ -189,19 +188,15 @@ fn clean_line_endings(s string) string {
} }
fn diff_content(s1 string, s2 string) { fn diff_content(s1 string, s2 string) {
diff_cmd := util.find_working_diff_command() or { diff_cmd := util.find_working_diff_command() or { return }
return
}
println('diff: ') println('diff: ')
println(util.color_compare_strings(diff_cmd, s1, s2)) println(util.color_compare_strings(diff_cmd, s1, s2))
println('============\n') println('============\n')
} }
fn get_tests_in_dir(dir string, is_module bool) []string { fn get_tests_in_dir(dir string, is_module bool) []string {
files := os.ls(dir) or { files := os.ls(dir) or { panic(err) }
panic(err) mut tests := files.clone()
}
mut tests := files
if !is_module { if !is_module {
tests = files.filter(it.ends_with('.vv')) tests = files.filter(it.ends_with('.vv'))
} else { } else {