Skip to content

Commit da09388

Browse files
committed
net.unix: make unix_socket_test.v trace its actions more thoroughly
1 parent dbc96b2 commit da09388

2 files changed

Lines changed: 97 additions & 63 deletions

File tree

‎vlib/net/unix/unix_socket_test.v‎

Lines changed: 97 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,97 @@
1+
import os
2+
import log
3+
import time
4+
import net.unix
5+
6+
const tfolder = os.join_path(os.temp_dir(), 'unix_socket_${os.getpid()}')
7+
const socket_path = os.join_path(tfolder, 'v_unix.sock')
8+
9+
fn testsuite_begin() {
10+
os.mkdir_all(tfolder) or {}
11+
}
12+
13+
fn testsuite_end() {
14+
os.rmdir_all(tfolder) or {}
15+
}
16+
17+
fn handle_conn(mut c unix.StreamConn) {
18+
log.warn(' handle_conn ${voidptr(c)} start')
19+
for {
20+
mut buf := []u8{len: 100, init: 0}
21+
log.warn(' handle_conn ${voidptr(c)}, reading data...')
22+
read := c.read(mut buf) or {
23+
log.warn(' handle_conn ${voidptr(c)}, reading failed, connection was dropped.')
24+
return
25+
}
26+
log.warn(' handle_conn ${voidptr(c)}, read: ${read} bytes')
27+
written := c.write(buf[..read]) or {
28+
log.warn(' handle_conn ${voidptr(c)}, writing failed, connection was dropped.')
29+
return
30+
}
31+
log.warn(' handle_conn ${voidptr(c)}, written: ${written} bytes')
32+
}
33+
}
34+
35+
fn echo_server(mut l unix.StreamListener) ! {
36+
log.warn('echo_server l: ${voidptr(l)}, start')
37+
for {
38+
log.warn('echo_server l: ${voidptr(l)}, waiting for connections...')
39+
mut new_conn := l.accept() or { continue }
40+
log.warn('echo_server l: ${voidptr(l)}, accepted new connection: ${voidptr(new_conn)}, spawning a new thread to handle it...')
41+
spawn handle_conn(mut new_conn)
42+
time.sleep(10 * time.millisecond)
43+
}
44+
}
45+
46+
fn echo() ! {
47+
log.info('echo: connecting to ${socket_path}...')
48+
mut c := unix.connect_stream(socket_path)!
49+
defer {
50+
log.info('echo: closing ${voidptr(c)} ...')
51+
c.close() or {}
52+
}
53+
data := 'Hello from vlib/net!'
54+
log.info('echo: writing `${data}` to ${voidptr(c)} ...')
55+
c.write_string(data)!
56+
mut buf := []u8{len: 4096}
57+
read := c.read(mut buf)!
58+
log.info('echo: read ${read} bytes from ${voidptr(c)} ...')
59+
assert read == data.len
60+
for i := 0; i < read; i++ {
61+
assert buf[i] == data[i]
62+
}
63+
log.info('echo: got `${buf.bytestr()}` back from ${voidptr(c)}.')
64+
return
65+
}
66+
67+
fn test_tcp() {
68+
log.use_stdout()
69+
unbuffer_stdout()
70+
os.rm(socket_path) or {}
71+
assert os.exists(socket_path) == false
72+
log.info('${@LOCATION}, setup complete')
73+
74+
log.info('>>> create listening socket at ${socket_path}...')
75+
mut l := unix.listen_stream(socket_path) or { panic(err) }
76+
log.info('>>> listening socket at ${socket_path} is ${voidptr(l)}.')
77+
println('')
78+
79+
log.info('>>> spawning server with connection ${voidptr(l)}...')
80+
spawn echo_server(mut l)
81+
println('')
82+
83+
for i in 0 .. 3 {
84+
log.info('>>> start echo to server, i: ${i}...')
85+
echo()!
86+
println('')
87+
}
88+
89+
log.info('>>> closing listening socket ${voidptr(l)}...')
90+
l.close() or {}
91+
println('')
92+
93+
// test if socket file is removed/unlinked
94+
assert os.exists(socket_path) == false
95+
96+
log.info('${@LOCATION}, done')
97+
}

‎vlib/net/unix/unix_test.v‎

Lines changed: 0 additions & 63 deletions
This file was deleted.

0 commit comments

Comments
 (0)