From c03fc46a5150715bf6aee20ce4b89d9704141220 Mon Sep 17 00:00:00 2001 From: Jakob Unterwurzacher Date: Thu, 10 Nov 2016 23:32:51 +0100 Subject: ctlsock: implement EncryptPath for reverse mode, add tests --- tests/test_helpers/helpers.go | 31 +++++++++++++++++++++++++++++++ 1 file changed, 31 insertions(+) (limited to 'tests/test_helpers') diff --git a/tests/test_helpers/helpers.go b/tests/test_helpers/helpers.go index aec1f7c..1bbfdf3 100644 --- a/tests/test_helpers/helpers.go +++ b/tests/test_helpers/helpers.go @@ -3,15 +3,19 @@ package test_helpers import ( "crypto/md5" "encoding/hex" + "encoding/json" "fmt" "io/ioutil" + "net" "os" "os/exec" "path/filepath" "runtime" "syscall" "testing" + "time" + "github.com/rfjakob/gocryptfs/internal/ctlsock" "github.com/rfjakob/gocryptfs/internal/nametransform" ) @@ -323,3 +327,30 @@ func Du(t *testing.T, fd int) (nBytes int64) { // st.Blocks = number of 512-byte blocks return st.Blocks * 512 } + +// QueryCtlSock sends a request to the control socket at "socketPath" and +// returns the response. +func QueryCtlSock(t *testing.T, socketPath string, req ctlsock.RequestStruct) (response ctlsock.ResponseStruct) { + conn, err := net.DialTimeout("unix", socketPath, 1*time.Second) + if err != nil { + t.Fatal(err) + } + defer conn.Close() + conn.SetDeadline(time.Now().Add(time.Second)) + msg, err := json.Marshal(req) + if err != nil { + t.Fatal(err) + } + _, err = conn.Write(msg) + if err != nil { + t.Fatal(err) + } + buf := make([]byte, 2*syscall.PathMax) + n, err := conn.Read(buf) + if err != nil { + t.Fatal(err) + } + buf = buf[:n] + json.Unmarshal(buf, &response) + return response +} -- cgit v1.2.3