summaryrefslogtreecommitdiff
path: root/pkg/test/hook_test.go
diff options
context:
space:
mode:
authorMikhail Osipov <mike.osipov@gmail.com>2020-12-16 15:27:48 +0300
committerMikhail Osipov <mike.osipov@gmail.com>2020-12-16 15:27:48 +0300
commit6fed9dd0dd62718f78eca11e30a71c2712636fbd (patch)
tree8d1f90b96efbe8ea8aea350c283325adc216ef9d /pkg/test/hook_test.go
parent050ea053dd549f0dd01beddfcd74989858391fd7 (diff)
hook and socket args check fix, tests
Diffstat (limited to 'pkg/test/hook_test.go')
-rw-r--r--pkg/test/hook_test.go59
1 files changed, 59 insertions, 0 deletions
diff --git a/pkg/test/hook_test.go b/pkg/test/hook_test.go
new file mode 100644
index 0000000..06204bb
--- /dev/null
+++ b/pkg/test/hook_test.go
@@ -0,0 +1,59 @@
+package test
+
+import (
+ "testing"
+
+ "encoding/hex"
+ "strings"
+)
+
+func TestUpperHook(t *testing.T) {
+ const msg = "Hello, World!"
+
+ c, s := newClientServer(t)
+ defer closeClientServer(c, s)
+
+ tunnel := "add name %s listen,addr=127.0.0.1:0 upper loop"
+ c.Exec(tunnel, t.Name())
+
+ addr := c.Send("get tunnel.%s.listen", t.Name())
+
+ conn := xDial(t, "tcp", addr)
+ defer conn.Close()
+
+ xWrite(t, conn, msg)
+
+ buf := make([]byte, len(msg))
+ xReadFull(t, conn, buf)
+
+ if r := string(buf); r != strings.ToUpper(msg) {
+ t.Fatalf("wrong reply: send '%s', recv '%s'", msg, r)
+ }
+}
+
+func TestHexHook(t *testing.T) {
+ const msg = "Hello, World!"
+
+ c, s := newClientServer(t)
+ defer closeClientServer(c, s)
+
+ listen := xListen(t, "tcp", "127.0.0.1:0")
+ defer listen.Close()
+
+ addr := c.AddListenTunnel(t.Name(), "hex dial,addr=%s", listen.Addr())
+
+ out := xDial(t, "tcp", addr)
+ defer out.Close()
+
+ in := xAccept(t, listen)
+ defer in.Close()
+
+ xWrite(t, out, msg)
+
+ buf := make([]byte, 2*len(msg))
+ xReadFull(t, in, buf)
+
+ if r := string(buf); r != hex.EncodeToString([]byte(msg)) {
+ t.Fatalf("wrong reply: send '%s', recv '%s'", msg, r)
+ }
+}