aboutsummaryrefslogtreecommitdiff
path: root/v_windows/v/old/vlib/net/unix/unix_test.v
diff options
context:
space:
mode:
authorIndrajith K L2022-12-03 17:00:20 +0530
committerIndrajith K L2022-12-03 17:00:20 +0530
commitf5c4671bfbad96bf346bd7e9a21fc4317b4959df (patch)
tree2764fc62da58f2ba8da7ed341643fc359873142f /v_windows/v/old/vlib/net/unix/unix_test.v
downloadcli-tools-windows-f5c4671bfbad96bf346bd7e9a21fc4317b4959df.tar.gz
cli-tools-windows-f5c4671bfbad96bf346bd7e9a21fc4317b4959df.tar.bz2
cli-tools-windows-f5c4671bfbad96bf346bd7e9a21fc4317b4959df.zip
Adds most of the toolsHEADmaster
Diffstat (limited to 'v_windows/v/old/vlib/net/unix/unix_test.v')
-rw-r--r--v_windows/v/old/vlib/net/unix/unix_test.v57
1 files changed, 57 insertions, 0 deletions
diff --git a/v_windows/v/old/vlib/net/unix/unix_test.v b/v_windows/v/old/vlib/net/unix/unix_test.v
new file mode 100644
index 0000000..007d62d
--- /dev/null
+++ b/v_windows/v/old/vlib/net/unix/unix_test.v
@@ -0,0 +1,57 @@
+import os
+import net.unix
+
+const test_port = os.join_path(os.temp_dir(), 'unix_domain_socket')
+
+fn testsuite_begin() {
+ os.rm(test_port) or {}
+}
+
+fn testsuite_end() {
+ os.rm(test_port) or {}
+}
+
+fn handle_conn(mut c unix.StreamConn) {
+ for {
+ mut buf := []byte{len: 100, init: 0}
+ read := c.read(mut buf) or {
+ println('Server: connection dropped')
+ return
+ }
+ c.write(buf[..read]) or {
+ println('Server: connection dropped')
+ return
+ }
+ }
+}
+
+fn echo_server(mut l unix.StreamListener) ? {
+ for {
+ mut new_conn := l.accept() or { continue }
+ go handle_conn(mut new_conn)
+ }
+}
+
+fn echo() ? {
+ mut c := unix.connect_stream(test_port) ?
+ defer {
+ c.close() or {}
+ }
+ data := 'Hello from vlib/net!'
+ c.write_string(data) ?
+ mut buf := []byte{len: 4096}
+ read := c.read(mut buf) ?
+ assert read == data.len
+ for i := 0; i < read; i++ {
+ assert buf[i] == data[i]
+ }
+ println('Got "$buf.bytestr()"')
+ return
+}
+
+fn test_tcp() {
+ mut l := unix.listen_stream(test_port) or { panic(err) }
+ go echo_server(mut l)
+ echo() or { panic(err) }
+ l.close() or {}
+}