2021-08-24 18:21:24 +02:00
|
|
|
import net.http
|
2021-08-19 10:19:49 +02:00
|
|
|
import time
|
|
|
|
|
|
|
|
fn test_server_stop() ? {
|
2021-08-24 18:21:24 +02:00
|
|
|
mut server := &http.Server{
|
2021-08-19 10:19:49 +02:00
|
|
|
accept_timeout: 1 * time.second
|
|
|
|
}
|
|
|
|
t := go server.listen_and_serve()
|
|
|
|
time.sleep(250 * time.millisecond)
|
|
|
|
mut watch := time.new_stopwatch()
|
|
|
|
server.stop()
|
2021-08-24 18:21:24 +02:00
|
|
|
assert server.status() == .stopped
|
2021-08-19 10:19:49 +02:00
|
|
|
assert watch.elapsed() < 100 * time.millisecond
|
2022-05-13 05:56:21 +02:00
|
|
|
t.wait()?
|
2021-08-19 10:19:49 +02:00
|
|
|
assert watch.elapsed() < 999 * time.millisecond
|
|
|
|
}
|
2021-08-24 18:21:24 +02:00
|
|
|
|
|
|
|
fn test_server_close() ? {
|
|
|
|
mut server := &http.Server{
|
|
|
|
accept_timeout: 1 * time.second
|
|
|
|
handler: MyHttpHandler{}
|
|
|
|
}
|
|
|
|
t := go server.listen_and_serve()
|
|
|
|
time.sleep(250 * time.millisecond)
|
|
|
|
mut watch := time.new_stopwatch()
|
|
|
|
server.close()
|
|
|
|
assert server.status() == .closed
|
|
|
|
assert watch.elapsed() < 100 * time.millisecond
|
2022-05-13 05:56:21 +02:00
|
|
|
t.wait()?
|
2021-08-24 18:21:24 +02:00
|
|
|
assert watch.elapsed() < 999 * time.millisecond
|
|
|
|
}
|
|
|
|
|
|
|
|
struct MyHttpHandler {
|
|
|
|
mut:
|
|
|
|
counter int
|
|
|
|
oks int
|
|
|
|
not_founds int
|
|
|
|
}
|
|
|
|
|
|
|
|
fn (mut handler MyHttpHandler) handle(req http.Request) http.Response {
|
|
|
|
handler.counter++
|
|
|
|
// eprintln('$time.now() | counter: $handler.counter | $req.method $req.url\n$req.header\n$req.data - 200 OK\n')
|
|
|
|
mut r := http.Response{
|
2022-05-29 19:27:18 +02:00
|
|
|
body: req.data + ', $req.url'
|
2021-08-24 18:21:24 +02:00
|
|
|
header: req.header
|
|
|
|
}
|
|
|
|
match req.url.all_before('?') {
|
|
|
|
'/endpoint', '/another/endpoint' {
|
|
|
|
r.set_status(.ok)
|
|
|
|
handler.oks++
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
r.set_status(.not_found)
|
|
|
|
handler.not_founds++
|
|
|
|
}
|
|
|
|
}
|
|
|
|
r.set_version(req.version)
|
|
|
|
return r
|
|
|
|
}
|
|
|
|
|
|
|
|
const cport = 8198
|
|
|
|
|
|
|
|
fn test_server_custom_handler() ? {
|
|
|
|
mut handler := MyHttpHandler{}
|
|
|
|
mut server := &http.Server{
|
|
|
|
accept_timeout: 1 * time.second
|
|
|
|
handler: handler
|
|
|
|
port: cport
|
|
|
|
}
|
|
|
|
t := go server.listen_and_serve()
|
|
|
|
for server.status() != .running {
|
|
|
|
time.sleep(10 * time.millisecond)
|
|
|
|
}
|
2022-05-13 05:56:21 +02:00
|
|
|
x := http.fetch(url: 'http://localhost:$cport/endpoint?abc=xyz', data: 'my data')?
|
2022-05-29 19:27:18 +02:00
|
|
|
assert x.body == 'my data, /endpoint?abc=xyz'
|
2021-08-24 18:21:24 +02:00
|
|
|
assert x.status_code == 200
|
|
|
|
assert x.http_version == '1.1'
|
2022-05-13 05:56:21 +02:00
|
|
|
y := http.fetch(url: 'http://localhost:$cport/another/endpoint', data: 'abcde')?
|
2022-05-29 19:27:18 +02:00
|
|
|
assert y.body == 'abcde, /another/endpoint'
|
2021-08-24 18:21:24 +02:00
|
|
|
assert y.status_code == 200
|
|
|
|
assert y.status() == .ok
|
|
|
|
assert y.http_version == '1.1'
|
|
|
|
//
|
2022-05-13 05:56:21 +02:00
|
|
|
http.fetch(url: 'http://localhost:$cport/something/else')?
|
2021-08-24 18:21:24 +02:00
|
|
|
server.stop()
|
2022-05-13 05:56:21 +02:00
|
|
|
t.wait()?
|
2021-08-24 18:21:24 +02:00
|
|
|
assert handler.counter == 3
|
|
|
|
assert handler.oks == 2
|
|
|
|
assert handler.not_founds == 1
|
|
|
|
}
|