v/cmd/tools/vtimeout_test.v
Delyan Angelov 367eb9b995
Some checks are pending
Graphics CI / gg-regressions (push) Waiting to run
vlib modules CI / build-module-docs (push) Waiting to run
Shy and PV CI / v-compiles-puzzle-vibes (push) Waiting to run
sdl CI / v-compiles-sdl-examples (push) Waiting to run
Time CI / time-linux (push) Waiting to run
Time CI / time-macos (push) Waiting to run
Time CI / time-windows (push) Waiting to run
toml CI / toml-module-pass-external-test-suites (push) Waiting to run
Tools CI / tools-linux (clang) (push) Waiting to run
Tools CI / tools-linux (gcc) (push) Waiting to run
Tools CI / tools-linux (tcc) (push) Waiting to run
Tools CI / tools-macos (clang) (push) Waiting to run
Tools CI / tools-windows (gcc) (push) Waiting to run
Tools CI / tools-windows (msvc) (push) Waiting to run
Tools CI / tools-windows (tcc) (push) Waiting to run
Tools CI / tools-docker-ubuntu-musl (push) Waiting to run
vab CI / vab-compiles-v-examples (push) Waiting to run
vab CI / v-compiles-os-android (push) Waiting to run
ci: retry 3 times cmd/tools/vtimeout_test.v on windows, before failing
2025-08-30 02:24:16 +03:00

51 lines
1.4 KiB
V

// vtest retry: 3
import os
import time
const qvexe = os.quoted_path(@VEXE)
fn depend_on_command(cmd string) ? {
path := os.find_abs_path_of_executable(cmd) or {
println('skip: ${cmd} not found')
return none
}
res := os.execute('${os.quoted_path(path)} --version')
if res.exit_code != 0 {
println('skip: ${cmd} does not support --version')
return none
}
if !res.output.contains('GNU coreutils') {
println('skip: ${cmd} is not from coreutils')
return none
}
}
fn execute(cmd string) os.Result {
sw := time.new_stopwatch()
res := os.execute(cmd)
dt := sw.elapsed().milliseconds()
eprintln('>> command: `${cmd:-60s}`, took: ${dt:5} ms, exit_code: ${res.exit_code:3}, output.len: ${res.output.len}')
return res
}
fn test_normal_exit_without_timeout_echo() {
depend_on_command('echo') or { return }
ee := execute('${qvexe} timeout 0.5 echo')
assert ee.exit_code == 0, ee.output
res := execute('${qvexe} timeout 0.5 echo z123')
assert res.exit_code == 0, res.output
assert res.output.contains('z123')
}
fn test_normal_exit_without_timeout_sleep() {
depend_on_command('sleep') or { return }
res := execute('${qvexe} timeout 0.5 sleep 0.1')
assert res.exit_code == 0, res.output
assert res.output == ''
}
fn test_exit_with_timeout() {
depend_on_command('sleep') or { return }
res := execute('${qvexe} timeout 0.5 sleep 3')
assert res.exit_code == 124, res.output
}