From e11ab8b92a7c44e2c94e5f3cb9041a7f57ddc25a Mon Sep 17 00:00:00 2001 From: Manuel Amstutz Date: Fri, 11 Sep 2020 15:34:09 +0200 Subject: [PATCH] Fix TrySendFrame if buffer is bigger than length --- .../OutgoingSocketExtensionsTests.cs | 19 +++++++++++++++++++ src/NetMQ/OutgoingSocketExtensions.cs | 2 +- 2 files changed, 20 insertions(+), 1 deletion(-) diff --git a/src/NetMQ.Tests/OutgoingSocketExtensionsTests.cs b/src/NetMQ.Tests/OutgoingSocketExtensionsTests.cs index 5b38e091e..cc43f72b6 100644 --- a/src/NetMQ.Tests/OutgoingSocketExtensionsTests.cs +++ b/src/NetMQ.Tests/OutgoingSocketExtensionsTests.cs @@ -1,4 +1,6 @@ using System; +using System.Linq; +using System.Text; using Xunit; namespace NetMQ.Tests @@ -322,5 +324,22 @@ public void TrySignalFailedTest() Assert.False(socket.TrySignalOK()); } + + [Fact] + public void TrySendFrameBiggerBufferThanLength() + { + var buffer = new byte[64]; + var data = Encoding.ASCII.GetBytes("Hello there"); + data.CopyTo(buffer, 0); + var socket = new MockOutgoingSocket((ref Msg msg, TimeSpan timeout, bool more) => + { + Assert.Equal(TimeSpan.Zero, timeout); + Assert.True(data.SequenceEqual(msg.ToArray())); + Assert.False(more); + return true; + }); + + Assert.True(socket.TrySendFrame(TimeSpan.Zero, buffer, data.Length)); + } } } diff --git a/src/NetMQ/OutgoingSocketExtensions.cs b/src/NetMQ/OutgoingSocketExtensions.cs index 322be0108..83dd3a339 100644 --- a/src/NetMQ/OutgoingSocketExtensions.cs +++ b/src/NetMQ/OutgoingSocketExtensions.cs @@ -104,7 +104,7 @@ public static bool TrySendFrame(this IOutgoingSocket socket, TimeSpan timeout, b { var msg = new Msg(); msg.InitPool(length); - data.CopyTo(msg); + data.Slice(0, length).CopyTo(msg); if (!socket.TrySend(ref msg, timeout, more)) { msg.Close();