From 40ecf2e535bb2cc1f8f8d1fa2003ad12ba88f683 Mon Sep 17 00:00:00 2001 From: Sir Darkrengarius Date: Wed, 19 Jun 2019 21:53:34 +0300 Subject: [PATCH] Finish tests, do cleanup --- pkg/dmsg/server_test.go | 67 +++++++++++++++++++++++++++++++++++++---- 1 file changed, 61 insertions(+), 6 deletions(-) diff --git a/pkg/dmsg/server_test.go b/pkg/dmsg/server_test.go index c0ea5e7dd8..4fd824e65c 100644 --- a/pkg/dmsg/server_test.go +++ b/pkg/dmsg/server_test.go @@ -594,8 +594,7 @@ func TestServer_Serve(t *testing.T) { // continue creating transports until the error occurs for { - //ctx := context.Background() - ctx, _ := context.WithTimeout(context.Background(), 100*time.Millisecond) + ctx := context.Background() if _, err = a.Dial(ctx, bPK); err != nil { break } @@ -605,8 +604,7 @@ func TestServer_Serve(t *testing.T) { // the same as above, transport is created by another client for { - //ctx := context.Background() - ctx, _ := context.WithTimeout(context.Background(), 100*time.Millisecond) + ctx := context.Background() if _, err = b.Dial(ctx, aPK); err != nil { break } @@ -640,9 +638,7 @@ func TestServer_Serve(t *testing.T) { err = a.Close() require.NoError(t, err) - b.log.Println("BEFORE CLOSING") err = b.Close() - b.log.Println("AFTER CLOSING") require.NoError(t, err) }) @@ -720,7 +716,66 @@ func TestServer_Serve(t *testing.T) { }) t.Run("test capped_transport_buffer_should_not_result_in_hang", func(t *testing.T) { + // generate keys for both clients + aPK, aSK := cipher.GenerateKeyPair() + bPK, bSK := cipher.GenerateKeyPair() + + // create remote + a := NewClient(aPK, aSK, dc) + a.SetLogger(logging.MustGetLogger("A")) + err = a.InitiateServerConnections(context.Background(), 1) + require.NoError(t, err) + + // create initiator + b := NewClient(bPK, bSK, dc) + b.SetLogger(logging.MustGetLogger("B")) + err = b.InitiateServerConnections(context.Background(), 1) + require.NoError(t, err) + + // create transports + aWrTransport, err := a.Dial(context.Background(), bPK) + require.NoError(t, err) + + _, err = b.Accept(context.Background()) + require.NoError(t, err) + + msg := []byte("Hello there!") + // exact iterations to fill the receiving buffer and hang `Write` + iterationsToDo := tpBufCap/len(msg) + 1 + + // fill the buffer, but no block yet + for i := 0; i < iterationsToDo-1; i++ { + _, err = aWrTransport.Write(msg) + require.NoError(t, err) + } + + // block on `Write` + go func() { + _, err = aWrTransport.Write(msg) + require.NoError(t, err) + }() + + // wait till it's definitely blocked + time.Sleep(1 * time.Second) + // create new transport from `B` to `A` + bWrTransport, err := b.Dial(context.Background(), aPK) + require.NoError(t, err) + + aRdTransport, err := a.Accept(context.Background()) + require.NoError(t, err) + + // try to write/read message via the new transports + for i := 0; i < 100; i++ { + _, err := bWrTransport.Write(msg) + require.NoError(t, err) + + recBuff := make([]byte, len(msg)) + _, err = aRdTransport.Read(recBuff) + require.NoError(t, err) + + require.Equal(t, recBuff, msg) + } }) }