diff --git a/vlib/vweb/tests/vweb_test.v b/vlib/vweb/tests/vweb_test.v index e222cc2e299f62..62df331f50428c 100644 --- a/vlib/vweb/tests/vweb_test.v +++ b/vlib/vweb/tests/vweb_test.v @@ -1,60 +1,19 @@ -import os -import time +import io import json +import time import net import net.http -import io +import vweb.tests.vweb_test_server const sport = 12380 const localserver = '127.0.0.1:${sport}' -const exit_after_time = 12000 // milliseconds +const exit_after_time = 12 * time.second -const vexe = os.getenv('VEXE') -const vweb_logfile = os.getenv('VWEB_LOGFILE') -const vroot = os.dir(vexe) -const serverexe = os.join_path(os.cache_dir(), 'vweb_test_server.exe') const tcp_r_timeout = 30 * time.second const tcp_w_timeout = 30 * time.second -// setup of vweb webserver -fn testsuite_begin() { - os.chdir(vroot) or {} - if os.exists(serverexe) { - os.rm(serverexe) or {} - } -} - -fn test_a_simple_vweb_app_can_be_compiled() { - // did_server_compile := os.system('${os.quoted_path(vexe)} -g -o ${os.quoted_path(serverexe)} vlib/vweb/tests/vweb_test_server.v') - // TODO: find out why it does not compile with -usecache and -g - did_server_compile := os.system('${os.quoted_path(vexe)} -o ${os.quoted_path(serverexe)} vlib/vweb/tests/vweb_test_server.v') - assert did_server_compile == 0 - assert os.exists(serverexe) -} - fn test_a_simple_vweb_app_runs_in_the_background() { - mut suffix := '' - $if !windows { - suffix = ' > /dev/null &' - } - if vweb_logfile != '' { - suffix = ' 2>> ${os.quoted_path(vweb_logfile)} >> ${os.quoted_path(vweb_logfile)} &' - } - server_exec_cmd := '${os.quoted_path(serverexe)} ${sport} ${exit_after_time} ${suffix}' - $if debug_net_socket_client ? { - eprintln('running:\n${server_exec_cmd}') - } - $if windows { - spawn os.system(server_exec_cmd) - } $else { - res := os.system(server_exec_cmd) - assert res == 0 - } - $if macos { - time.sleep(1000 * time.millisecond) - } $else { - time.sleep(100 * time.millisecond) - } + vweb_test_server.start_in_background(sport, exit_after_time)! } // web client tests follow diff --git a/vlib/vweb/tests/vweb_test_server.v b/vlib/vweb/tests/vweb_test_server/server.v similarity index 61% rename from vlib/vweb/tests/vweb_test_server.v rename to vlib/vweb/tests/vweb_test_server/server.v index 627e929d9bc318..b570e04d1f9201 100644 --- a/vlib/vweb/tests/vweb_test_server.v +++ b/vlib/vweb/tests/vweb_test_server/server.v @@ -1,54 +1,60 @@ -module main +module vweb_test_server import os +import log import vweb import time -const known_users = ['bilbo', 'kent'] - -struct App { - vweb.Context - port int - timeout int - global_config shared Config -} - -struct Config { - max_ping int +@[if verbose_vweb_server ?] +fn linfo(s string) { + log.info(s) } -fn exit_after_timeout(timeout_in_ms int) { - time.sleep(timeout_in_ms * time.millisecond) - println('>> webserver: pid: ${os.getpid()}, exiting ...') - exit(0) -} - -fn main() { - if os.args.len != 3 { - panic('Usage: `vweb_test_server.exe PORT TIMEOUT_IN_MILLISECONDS`') - } - http_port := os.args[1].int() +pub fn start_in_background(http_port int, timeout time.Duration) ! { + linfo('>> ${@FN}, http_port: ${http_port}, timeout: ${timeout}') assert http_port > 0 - timeout := os.args[2].int() assert timeout > 0 - spawn exit_after_timeout(timeout) // + spawn fn (timeout time.Duration) { + time.sleep(timeout) + linfo('>> webserver: pid: ${os.getpid()}, exiting cleanly after ${timeout.milliseconds()}ms ...') + exit(0) + }(timeout) shared config := &Config{ max_ping: 50 } app := &App{ port: http_port - timeout: timeout global_config: config } - eprintln('>> webserver: pid: ${os.getpid()}, started on http://localhost:${app.port}/ , with maximum runtime of ${app.timeout} milliseconds.') - vweb.run_at(app, host: 'localhost', port: http_port, family: .ip)! + linfo('>> webserver: pid: ${os.getpid()}, started on http://localhost:${app.port}/ , with maximum runtime of ${timeout.milliseconds()} ms.') + spawn fn (app &App, http_port int) { + vweb.run_at(app, host: 'localhost', port: http_port, family: .ip) or {} + }(app, http_port) + _ := <-app.is_ready + log.info('>> ${@FN} finished, http_port: ${http_port}, timeout: ${timeout}') } -// pub fn (mut app App) init_server() { -//} +const known_users = ['bilbo', 'kent'] + +struct App { + vweb.Context + port int + global_config shared Config + is_ready chan bool +} + +struct Config { + max_ping int +} + +pub fn (mut app App) before_accept_loop() { + linfo('>>>>> ${@LOCATION}') + app.is_ready <- true +} pub fn (mut app App) index() vweb.Result { + linfo('>>>>> ${@LOCATION}') rlock app.global_config { assert app.global_config.max_ping == 50 } @@ -56,17 +62,20 @@ pub fn (mut app App) index() vweb.Result { } pub fn (mut app App) simple() vweb.Result { + linfo('>>>>> ${@LOCATION}') return app.text('A simple result') } pub fn (mut app App) html_page() vweb.Result { + linfo('>>>>> ${@LOCATION}') return app.html('