From 56cd081fdb176cbd5ceab03a0c62ca1f9402f824 Mon Sep 17 00:00:00 2001 From: Anton Firszov Date: Thu, 28 Jan 2021 15:00:06 +0100 Subject: [PATCH 01/23] cherry pick testfix --- .../tests/FunctionalTests/ReceiveFrom.cs | 49 +++++++++++++------ .../FunctionalTests/ReceiveMessageFrom.cs | 49 +++++++++++++------ 2 files changed, 66 insertions(+), 32 deletions(-) diff --git a/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveFrom.cs b/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveFrom.cs index ce8e3f9fe2edb..51492518279ea 100644 --- a/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveFrom.cs +++ b/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveFrom.cs @@ -6,6 +6,7 @@ using System.Threading.Tasks; using Xunit; using Xunit.Abstractions; +using Xunit.Sdk; namespace System.Net.Sockets.Tests { @@ -99,7 +100,6 @@ public async Task ClosedBeforeOperation_Throws_ObjectDisposedException(bool clos [Theory] [InlineData(true)] [InlineData(false)] - [ActiveIssue("https://github.com/dotnet/runtime/issues/47561")] public async Task ClosedDuringOperation_Throws_ObjectDisposedExceptionOrSocketException(bool closeOrDispose) { if (UsesSync && PlatformDetection.IsOSX) @@ -109,25 +109,42 @@ public async Task ClosedDuringOperation_Throws_ObjectDisposedExceptionOrSocketEx return; } - using var socket = new Socket(AddressFamily.InterNetwork, SocketType.Dgram, ProtocolType.Udp); - socket.BindToAnonymousPort(IPAddress.Any); - - Task receiveTask = ReceiveFromAsync(socket, new byte[1], GetGetDummyTestEndpoint()); - await Task.Delay(100); - if (closeOrDispose) socket.Close(); - else socket.Dispose(); - - if (UsesApm) + int msDelay = 100; + if (UsesSync) { - await Assert.ThrowsAsync(() => receiveTask) - .TimeoutAfter(CancellationTestTimeout); + // In sync case Dispose may happen before the operation is started, + // in that case we would see an ObjectDisposedException instead of a SocketException. + // We may need to try the run a couple of times to deal with the timing race. + await RetryHelper.ExecuteAsync(() => RunTestAsync(), maxAttempts: 10, retryWhen: e => e is XunitException); } else { - SocketException ex = await Assert.ThrowsAsync(() => receiveTask) - .TimeoutAfter(CancellationTestTimeout); - SocketError expectedError = UsesSync ? SocketError.Interrupted : SocketError.OperationAborted; - Assert.Equal(expectedError, ex.SocketErrorCode); + await RunTestAsync(); + } + + async Task RunTestAsync() + { + using var socket = new Socket(AddressFamily.InterNetwork, SocketType.Dgram, ProtocolType.Udp); + socket.BindToAnonymousPort(IPAddress.Any); + + Task receiveTask = ReceiveFromAsync(socket, new byte[1], GetGetDummyTestEndpoint()); + await Task.Delay(msDelay); + msDelay *= 2; + if (closeOrDispose) socket.Close(); + else socket.Dispose(); + + if (DisposeDuringOperationResultsInDisposedException) + { + await Assert.ThrowsAsync(() => receiveTask) + .TimeoutAfter(CancellationTestTimeout); + } + else + { + SocketException ex = await Assert.ThrowsAsync(() => receiveTask) + .TimeoutAfter(CancellationTestTimeout); + SocketError expectedError = UsesSync ? SocketError.Interrupted : SocketError.OperationAborted; + Assert.Equal(expectedError, ex.SocketErrorCode); + } } } diff --git a/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveMessageFrom.cs b/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveMessageFrom.cs index f948b1be0c6d5..e9be72af9041c 100644 --- a/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveMessageFrom.cs +++ b/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveMessageFrom.cs @@ -7,6 +7,7 @@ using System.Threading.Tasks; using Xunit; using Xunit.Abstractions; +using Xunit.Sdk; namespace System.Net.Sockets.Tests { @@ -105,7 +106,6 @@ public async Task ClosedBeforeOperation_Throws_ObjectDisposedException(bool clos [Theory] [InlineData(true)] [InlineData(false)] - [ActiveIssue("https://github.com/dotnet/runtime/issues/47561")] public async Task ClosedDuringOperation_Throws_ObjectDisposedExceptionOrSocketException(bool closeOrDispose) { if (UsesSync && PlatformDetection.IsOSX) @@ -115,25 +115,42 @@ public async Task ClosedDuringOperation_Throws_ObjectDisposedExceptionOrSocketEx return; } - using var socket = new Socket(AddressFamily.InterNetwork, SocketType.Dgram, ProtocolType.Udp); - socket.BindToAnonymousPort(IPAddress.Any); - - Task receiveTask = ReceiveMessageFromAsync(socket, new byte[1], GetGetDummyTestEndpoint()); - await Task.Delay(100); - if (closeOrDispose) socket.Close(); - else socket.Dispose(); - - if (UsesApm) + int msDelay = 100; + if (UsesSync) { - await Assert.ThrowsAsync(() => receiveTask) - .TimeoutAfter(CancellationTestTimeout); + // In sync case Dispose may happen before the operation is started, + // in that case we would see an ObjectDisposedException instead of a SocketException. + // We may need to try the run a couple of times to deal with the timing race. + await RetryHelper.ExecuteAsync(() => RunTestAsync(), maxAttempts: 10, retryWhen: e => e is XunitException); } else { - SocketException ex = await Assert.ThrowsAsync(() => receiveTask) - .TimeoutAfter(CancellationTestTimeout); - SocketError expectedError = UsesSync ? SocketError.Interrupted : SocketError.OperationAborted; - Assert.Equal(expectedError, ex.SocketErrorCode); + await RunTestAsync(); + } + + async Task RunTestAsync() + { + using var socket = new Socket(AddressFamily.InterNetwork, SocketType.Dgram, ProtocolType.Udp); + socket.BindToAnonymousPort(IPAddress.Any); + + Task receiveTask = ReceiveMessageFromAsync(socket, new byte[1], GetGetDummyTestEndpoint()); + await Task.Delay(msDelay); + msDelay *= 2; + if (closeOrDispose) socket.Close(); + else socket.Dispose(); + + if (DisposeDuringOperationResultsInDisposedException) + { + await Assert.ThrowsAsync(() => receiveTask) + .TimeoutAfter(CancellationTestTimeout); + } + else + { + SocketException ex = await Assert.ThrowsAsync(() => receiveTask) + .TimeoutAfter(CancellationTestTimeout); + SocketError expectedError = UsesSync ? SocketError.Interrupted : SocketError.OperationAborted; + Assert.Equal(expectedError, ex.SocketErrorCode); + } } } From 91834bc610cbb5d42e02bbd5e1677c9bc99f189a Mon Sep 17 00:00:00 2001 From: Anton Firszov Date: Fri, 29 Jan 2021 14:38:47 +0100 Subject: [PATCH 02/23] SendTo + DELETEME notes --- .../Net/Sockets/BaseOverlappedAsyncResult.cs | 1 + .../Net/Sockets/OverlappedAsyncResult.cs | 6 +- .../ReceiveMessageOverlappedAsyncResult.cs | 1 + .../src/System/Net/Sockets/Socket.cs | 125 +----------------- .../src/System/Net/Sockets/SocketPal.Unix.cs | 14 -- .../System/Net/Sockets/SocketPal.Windows.cs | 27 ---- 6 files changed, 7 insertions(+), 167 deletions(-) diff --git a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/BaseOverlappedAsyncResult.cs b/src/libraries/System.Net.Sockets/src/System/Net/Sockets/BaseOverlappedAsyncResult.cs index 1cb1f60789995..0d3a9ffcc7acf 100644 --- a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/BaseOverlappedAsyncResult.cs +++ b/src/libraries/System.Net.Sockets/src/System/Net/Sockets/BaseOverlappedAsyncResult.cs @@ -22,6 +22,7 @@ internal partial class BaseOverlappedAsyncResult : ContextAwareResult return s_resultObjectSentinel; // return sentinel rather than boxing numBytes } + // DELETEME // Used instead of the base InternalWaitForCompletion when storing an Int32 result internal int InternalWaitForCompletionInt32Result() { diff --git a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/OverlappedAsyncResult.cs b/src/libraries/System.Net.Sockets/src/System/Net/Sockets/OverlappedAsyncResult.cs index 8ca9bca32929f..76b5450933fb6 100644 --- a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/OverlappedAsyncResult.cs +++ b/src/libraries/System.Net.Sockets/src/System/Net/Sockets/OverlappedAsyncResult.cs @@ -3,10 +3,7 @@ namespace System.Net.Sockets { - // OverlappedAsyncResult - // - // This class is used to take care of storage for async Socket operation - // from the BeginSend, BeginSendTo, BeginReceive, BeginReceiveFrom calls. + // !!! DELETEME!!! internal partial class OverlappedAsyncResult : BaseOverlappedAsyncResult { private Internals.SocketAddress? _socketAddress; @@ -23,6 +20,7 @@ internal Internals.SocketAddress? SocketAddress } } + // !!! DELETEME!!! internal sealed class OriginalAddressOverlappedAsyncResult : OverlappedAsyncResult { internal OriginalAddressOverlappedAsyncResult(Socket socket, object? asyncState, AsyncCallback? asyncCallback) : diff --git a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/ReceiveMessageOverlappedAsyncResult.cs b/src/libraries/System.Net.Sockets/src/System/Net/Sockets/ReceiveMessageOverlappedAsyncResult.cs index 7f330a6f726bc..25ef89d4d0cee 100644 --- a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/ReceiveMessageOverlappedAsyncResult.cs +++ b/src/libraries/System.Net.Sockets/src/System/Net/Sockets/ReceiveMessageOverlappedAsyncResult.cs @@ -3,6 +3,7 @@ namespace System.Net.Sockets { + // !!! DELETEME !!! internal unsafe sealed partial class ReceiveMessageOverlappedAsyncResult : BaseOverlappedAsyncResult { private Internals.SocketAddress? _socketAddressOriginal; diff --git a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/Socket.cs b/src/libraries/System.Net.Sockets/src/System/Net/Sockets/Socket.cs index fdd1055aaef55..81eff880daef3 100644 --- a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/Socket.cs +++ b/src/libraries/System.Net.Sockets/src/System/Net/Sockets/Socket.cs @@ -2230,26 +2230,6 @@ public void EndSendFile(IAsyncResult asyncResult) EndSendFileInternal(asyncResult); } - // Routine Description: - // - // BeginSendTo - Async implementation of SendTo, - // - // This routine may go pending at which time, - // but any case the callback Delegate will be called upon completion - // - // Arguments: - // - // WriteBuffer - Buffer to transmit - // Index - Offset into WriteBuffer to begin sending from - // Size - Size of Buffer to transmit - // Flags - Specific Socket flags to pass to winsock - // remoteEP - EndPoint to transmit To - // Callback - Delegate function that holds callback, called on completion of I/O - // State - State used to track callback, set by caller, not required - // - // Return Value: - // - // IAsyncResult - Async result used to retrieve result public IAsyncResult BeginSendTo(byte[] buffer, int offset, int size, SocketFlags socketFlags, EndPoint remoteEP, AsyncCallback? callback, object? state) { ThrowIfDisposed(); @@ -2259,113 +2239,14 @@ public IAsyncResult BeginSendTo(byte[] buffer, int offset, int size, SocketFlags throw new ArgumentNullException(nameof(remoteEP)); } - Internals.SocketAddress socketAddress = Serialize(ref remoteEP); - - // Set up the async result and indicate to flow the context. - OverlappedAsyncResult asyncResult = new OverlappedAsyncResult(this, state, callback); - asyncResult.StartPostingAsyncOp(false); - - // Post the send. - DoBeginSendTo(buffer, offset, size, socketFlags, remoteEP, socketAddress, asyncResult); - - // Finish, possibly posting the callback. The callback won't be posted before this point is reached. - asyncResult.FinishPostingAsyncOp(ref Caches.SendClosureCache); - - return asyncResult; - } - - private void DoBeginSendTo(byte[] buffer, int offset, int size, SocketFlags socketFlags, EndPoint endPointSnapshot, Internals.SocketAddress socketAddress, OverlappedAsyncResult asyncResult) - { - if (NetEventSource.Log.IsEnabled()) NetEventSource.Info(this, $"size:{size}"); - - EndPoint? oldEndPoint = _rightEndPoint; - - // Guarantee to call CheckAsyncCallOverlappedResult if we call SetUnamangedStructures with a cache in order to - // avoid a Socket leak in case of error. - SocketError errorCode = SocketError.SocketError; - try - { - if (_rightEndPoint == null) - { - _rightEndPoint = endPointSnapshot; - } - - errorCode = SocketPal.SendToAsync(_handle, buffer, offset, size, socketFlags, socketAddress, asyncResult); - - if (NetEventSource.Log.IsEnabled()) NetEventSource.Info(this, $"SendToAsync returns:{errorCode} size:{size} returning AsyncResult:{asyncResult}"); - } - catch (ObjectDisposedException) - { - _rightEndPoint = oldEndPoint; - _localEndPoint = null; - throw; - } - - // Throw an appropriate SocketException if the native call fails synchronously. - if (!CheckErrorAndUpdateStatus(errorCode)) - { - UpdateSendSocketErrorForDisposed(ref errorCode); - // Update the internal state of this socket according to the error before throwing. - _rightEndPoint = oldEndPoint; - _localEndPoint = null; - - throw new SocketException((int)errorCode); - } - - if (NetEventSource.Log.IsEnabled()) NetEventSource.Info(this, $"size:{size} returning AsyncResult:{asyncResult}"); + Task task = SendToAsync(buffer.AsMemory().Slice(offset, size), socketFlags, remoteEP).AsTask(); + return TaskToApm.Begin(task, callback, state); } - // Routine Description: - // - // EndSendTo - Called by user code after I/O is done or the user wants to wait. - // until Async completion, needed to retrieve error result from call - // - // Arguments: - // - // AsyncResult - the AsyncResult Returned from BeginSend call - // - // Return Value: - // - // int - Number of bytes transferred public int EndSendTo(IAsyncResult asyncResult) { ThrowIfDisposed(); - - // Validate input parameters. - if (asyncResult == null) - { - throw new ArgumentNullException(nameof(asyncResult)); - } - - OverlappedAsyncResult? castedAsyncResult = asyncResult as OverlappedAsyncResult; - if (castedAsyncResult == null || castedAsyncResult.AsyncObject != this) - { - throw new ArgumentException(SR.net_io_invalidasyncresult, nameof(asyncResult)); - } - if (castedAsyncResult.EndCalled) - { - throw new InvalidOperationException(SR.Format(SR.net_io_invalidendcall, "EndSendTo")); - } - - int bytesTransferred = castedAsyncResult.InternalWaitForCompletionInt32Result(); - castedAsyncResult.EndCalled = true; - - if (NetEventSource.Log.IsEnabled()) NetEventSource.Info(this, $"bytesTransferred:{bytesTransferred}"); - - // Throw an appropriate SocketException if the native call failed asynchronously. - SocketError errorCode = (SocketError)castedAsyncResult.ErrorCode; - if (errorCode != SocketError.Success) - { - UpdateSendSocketErrorForDisposed(ref errorCode); - UpdateStatusAfterSocketErrorAndThrowException(errorCode); - } - else if (SocketsTelemetry.Log.IsEnabled()) - { - SocketsTelemetry.Log.BytesSent(bytesTransferred); - if (SocketType == SocketType.Dgram) SocketsTelemetry.Log.DatagramSent(); - } - - return bytesTransferred; + return TaskToApm.End(asyncResult); } public IAsyncResult BeginReceive(byte[] buffer, int offset, int size, SocketFlags socketFlags, AsyncCallback? callback, object? state) diff --git a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/SocketPal.Unix.cs b/src/libraries/System.Net.Sockets/src/System/Net/Sockets/SocketPal.Unix.cs index 019bd5f165db7..b696bca48afd5 100644 --- a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/SocketPal.Unix.cs +++ b/src/libraries/System.Net.Sockets/src/System/Net/Sockets/SocketPal.Unix.cs @@ -1857,20 +1857,6 @@ public static async void SendPacketsAsync( } } - public static SocketError SendToAsync(SafeSocketHandle handle, byte[] buffer, int offset, int count, SocketFlags socketFlags, Internals.SocketAddress socketAddress, OverlappedAsyncResult asyncResult) - { - asyncResult.SocketAddress = socketAddress; - - int bytesSent; - int socketAddressLen = socketAddress.Size; - SocketError socketError = handle.AsyncContext.SendToAsync(buffer, offset, count, socketFlags, socketAddress.Buffer, ref socketAddressLen, out bytesSent, asyncResult.CompletionCallback); - if (socketError == SocketError.Success) - { - asyncResult.CompletionCallback(bytesSent, socketAddress.Buffer, socketAddressLen, SocketFlags.None, SocketError.Success); - } - return socketError; - } - public static SocketError ReceiveFromAsync(SafeSocketHandle handle, byte[] buffer, int offset, int count, SocketFlags socketFlags, Internals.SocketAddress socketAddress, OverlappedAsyncResult asyncResult) { asyncResult.SocketAddress = socketAddress; diff --git a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/SocketPal.Windows.cs b/src/libraries/System.Net.Sockets/src/System/Net/Sockets/SocketPal.Windows.cs index ab701286e435c..d9a4986f2156a 100644 --- a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/SocketPal.Windows.cs +++ b/src/libraries/System.Net.Sockets/src/System/Net/Sockets/SocketPal.Windows.cs @@ -1094,33 +1094,6 @@ public static unsafe SocketError SendFileAsync(SafeSocketHandle handle, FileStre } } - public static unsafe SocketError SendToAsync(SafeSocketHandle handle, byte[] buffer, int offset, int count, SocketFlags socketFlags, Internals.SocketAddress socketAddress, OverlappedAsyncResult asyncResult) - { - // Set up asyncResult for overlapped WSASendTo. - asyncResult.SetUnmanagedStructures(buffer, offset, count, socketAddress); - try - { - int bytesTransferred; - SocketError errorCode = Interop.Winsock.WSASendTo( - handle, - ref asyncResult._singleBuffer, - 1, // There is only ever 1 buffer being sent. - out bytesTransferred, - socketFlags, - asyncResult.GetSocketAddressPtr(), - asyncResult.SocketAddress!.Size, - asyncResult.DangerousOverlappedPointer, // SafeHandle was just created in SetUnmanagedStructures - IntPtr.Zero); - - return asyncResult.ProcessOverlappedResult(errorCode == SocketError.Success, bytesTransferred); - } - catch - { - asyncResult.ReleaseUnmanagedStructures(); - throw; - } - } - public static unsafe SocketError ReceiveAsync(SafeSocketHandle handle, IList> buffers, SocketFlags socketFlags, OverlappedAsyncResult asyncResult) { // Set up asyncResult for overlapped WSASend. From 68aca2a98a8937dbfa29ea29be06b51a832972cd Mon Sep 17 00:00:00 2001 From: Anton Firszov Date: Fri, 29 Jan 2021 17:53:53 +0100 Subject: [PATCH 03/23] WIP --- .../Net/Sockets/OverlappedAsyncResult.cs | 11 -- .../src/System/Net/Sockets/Socket.cs | 100 +----------------- .../src/System/Net/Sockets/SocketPal.Unix.cs | 15 --- .../System/Net/Sockets/SocketPal.Windows.cs | 27 ----- 4 files changed, 3 insertions(+), 150 deletions(-) diff --git a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/OverlappedAsyncResult.cs b/src/libraries/System.Net.Sockets/src/System/Net/Sockets/OverlappedAsyncResult.cs index 76b5450933fb6..784d5ed499b48 100644 --- a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/OverlappedAsyncResult.cs +++ b/src/libraries/System.Net.Sockets/src/System/Net/Sockets/OverlappedAsyncResult.cs @@ -19,15 +19,4 @@ internal Internals.SocketAddress? SocketAddress set { _socketAddress = value; } } } - - // !!! DELETEME!!! - internal sealed class OriginalAddressOverlappedAsyncResult : OverlappedAsyncResult - { - internal OriginalAddressOverlappedAsyncResult(Socket socket, object? asyncState, AsyncCallback? asyncCallback) : - base(socket, asyncState, asyncCallback) - { - } - - internal Internals.SocketAddress? SocketAddressOriginal { get; set; } - } } diff --git a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/Socket.cs b/src/libraries/System.Net.Sockets/src/System/Net/Sockets/Socket.cs index 81eff880daef3..9477b5ef3aeb3 100644 --- a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/Socket.cs +++ b/src/libraries/System.Net.Sockets/src/System/Net/Sockets/Socket.cs @@ -2494,34 +2494,13 @@ public int EndReceiveMessageFrom(IAsyncResult asyncResult, ref SocketFlags socke return bytesTransferred; } - // Routine Description: - // - // BeginReceiveFrom - Async implementation of RecvFrom call, - // - // Called when we want to start an async receive. - // We kick off the receive, and if it completes synchronously we'll - // call the callback. Otherwise we'll return an IASyncResult, which - // the caller can use to wait on or retrieve the final status, as needed. - // - // Uses Winsock 2 overlapped I/O. - // - // Arguments: - // - // ReadBuffer - status line that we wish to parse - // Index - Offset into ReadBuffer to begin reading from - // Request - Size of Buffer to recv - // Flags - Additional Flags that may be passed to the underlying winsock call - // remoteEP - EndPoint that are to receive from - // Callback - Delegate function that holds callback, called on completion of I/O - // State - State used to track callback, set by caller, not required - // - // Return Value: - // - // IAsyncResult - Async result used to retrieve result public IAsyncResult BeginReceiveFrom(byte[] buffer, int offset, int size, SocketFlags socketFlags, ref EndPoint remoteEP, AsyncCallback? callback, object? state) { ThrowIfDisposed(); ValidateBufferArguments(buffer, offset, size); + + var task = ReceiveFromAsync(new Memory(buffer, offset, size), socketFlags, remoteEP); + if (remoteEP == null) { throw new ArgumentNullException(nameof(remoteEP)); @@ -2535,79 +2514,6 @@ public IAsyncResult BeginReceiveFrom(byte[] buffer, int offset, int size, Socket throw new InvalidOperationException(SR.net_sockets_mustbind); } - SocketPal.CheckDualModeReceiveSupport(this); - - // We don't do a CAS demand here because the contents of remoteEP aren't used by - // WSARecvFrom; all that matters is that we generate a unique-to-this-call SocketAddress - // with the right address family - Internals.SocketAddress socketAddress = Serialize(ref remoteEP); - - // Set up the result and set it to collect the context. - var asyncResult = new OriginalAddressOverlappedAsyncResult(this, state, callback); - asyncResult.StartPostingAsyncOp(false); - - // Start the ReceiveFrom. - DoBeginReceiveFrom(buffer, offset, size, socketFlags, remoteEP, socketAddress, asyncResult); - - // Capture the context, maybe call the callback, and return. - asyncResult.FinishPostingAsyncOp(ref Caches.ReceiveClosureCache); - - if (asyncResult.CompletedSynchronously && !asyncResult.SocketAddressOriginal!.Equals(asyncResult.SocketAddress)) - { - try - { - remoteEP = remoteEP.Create(asyncResult.SocketAddress!); - } - catch - { - } - } - - return asyncResult; - } - - private void DoBeginReceiveFrom(byte[] buffer, int offset, int size, SocketFlags socketFlags, EndPoint endPointSnapshot, Internals.SocketAddress socketAddress, OriginalAddressOverlappedAsyncResult asyncResult) - { - EndPoint? oldEndPoint = _rightEndPoint; - - if (NetEventSource.Log.IsEnabled()) NetEventSource.Info(this, $"size:{size}"); - - // Guarantee to call CheckAsyncCallOverlappedResult if we call SetUnamangedStructures with a cache in order to - // avoid a Socket leak in case of error. - SocketError errorCode = SocketError.SocketError; - try - { - // Save a copy of the original EndPoint in the asyncResult. - asyncResult.SocketAddressOriginal = IPEndPointExtensions.Serialize(endPointSnapshot); - - if (_rightEndPoint == null) - { - _rightEndPoint = endPointSnapshot; - } - - errorCode = SocketPal.ReceiveFromAsync(_handle, buffer, offset, size, socketFlags, socketAddress, asyncResult); - - if (NetEventSource.Log.IsEnabled()) NetEventSource.Info(this, $"ReceiveFromAsync returns:{errorCode} size:{size} returning AsyncResult:{asyncResult}"); - } - catch (ObjectDisposedException) - { - _rightEndPoint = oldEndPoint; - _localEndPoint = null; - throw; - } - - // Throw an appropriate SocketException if the native call fails synchronously. - UpdateReceiveSocketErrorForDisposed(ref errorCode, bytesTransferred: 0); - if (!CheckErrorAndUpdateStatus(errorCode)) - { - // Update the internal state of this socket according to the error before throwing. - _rightEndPoint = oldEndPoint; - _localEndPoint = null; - - throw new SocketException((int)errorCode); - } - - if (NetEventSource.Log.IsEnabled()) NetEventSource.Info(this, $"size:{size} return AsyncResult:{asyncResult}"); } // Routine Description: diff --git a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/SocketPal.Unix.cs b/src/libraries/System.Net.Sockets/src/System/Net/Sockets/SocketPal.Unix.cs index b696bca48afd5..9741ecae4836b 100644 --- a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/SocketPal.Unix.cs +++ b/src/libraries/System.Net.Sockets/src/System/Net/Sockets/SocketPal.Unix.cs @@ -1857,21 +1857,6 @@ public static async void SendPacketsAsync( } } - public static SocketError ReceiveFromAsync(SafeSocketHandle handle, byte[] buffer, int offset, int count, SocketFlags socketFlags, Internals.SocketAddress socketAddress, OverlappedAsyncResult asyncResult) - { - asyncResult.SocketAddress = socketAddress; - - int socketAddressSize = socketAddress.InternalSize; - int bytesReceived; - SocketFlags receivedFlags; - SocketError socketError = handle.AsyncContext.ReceiveFromAsync(new Memory(buffer, offset, count), socketFlags, socketAddress.Buffer, ref socketAddressSize, out bytesReceived, out receivedFlags, asyncResult.CompletionCallback); - if (socketError == SocketError.Success) - { - asyncResult.CompletionCallback(bytesReceived, socketAddress.Buffer, socketAddressSize, receivedFlags, SocketError.Success); - } - return socketError; - } - public static SocketError ReceiveMessageFromAsync(Socket socket, SafeSocketHandle handle, byte[] buffer, int offset, int count, SocketFlags socketFlags, Internals.SocketAddress socketAddress, ReceiveMessageOverlappedAsyncResult asyncResult) { asyncResult.SocketAddress = socketAddress; diff --git a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/SocketPal.Windows.cs b/src/libraries/System.Net.Sockets/src/System/Net/Sockets/SocketPal.Windows.cs index d9a4986f2156a..0f93b47af0572 100644 --- a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/SocketPal.Windows.cs +++ b/src/libraries/System.Net.Sockets/src/System/Net/Sockets/SocketPal.Windows.cs @@ -1119,33 +1119,6 @@ public static unsafe SocketError ReceiveAsync(SafeSocketHandle handle, IList Date: Mon, 1 Feb 2021 14:10:26 +0100 Subject: [PATCH 04/23] ReceiveFrom --- .../src/System/Net/Sockets/Socket.cs | 79 ++----------------- 1 file changed, 8 insertions(+), 71 deletions(-) diff --git a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/Socket.cs b/src/libraries/System.Net.Sockets/src/System/Net/Sockets/Socket.cs index 9477b5ef3aeb3..e13898f08f030 100644 --- a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/Socket.cs +++ b/src/libraries/System.Net.Sockets/src/System/Net/Sockets/Socket.cs @@ -2499,36 +2499,15 @@ public IAsyncResult BeginReceiveFrom(byte[] buffer, int offset, int size, Socket ThrowIfDisposed(); ValidateBufferArguments(buffer, offset, size); - var task = ReceiveFromAsync(new Memory(buffer, offset, size), socketFlags, remoteEP); - - if (remoteEP == null) - { - throw new ArgumentNullException(nameof(remoteEP)); - } - if (!CanTryAddressFamily(remoteEP.AddressFamily)) - { - throw new ArgumentException(SR.Format(SR.net_InvalidEndPointAddressFamily, remoteEP.AddressFamily, _addressFamily), nameof(remoteEP)); - } - if (_rightEndPoint == null) + Task t = ReceiveFromAsync(new Memory(buffer, offset, size), socketFlags, remoteEP).AsTask(); + if (t.IsCompleted) { - throw new InvalidOperationException(SR.net_sockets_mustbind); + remoteEP = t.Result.RemoteEndPoint; } + return TaskToApm.Begin(t, callback, state); } - // Routine Description: - // - // EndReceiveFrom - Called when I/O is done or the user wants to wait. If - // the I/O isn't done, we'll wait for it to complete, and then we'll return - // the bytes of I/O done. - // - // Arguments: - // - // AsyncResult - the AsyncResult Returned from BeginReceiveFrom call - // - // Return Value: - // - // int - Number of bytes transferred public int EndReceiveFrom(IAsyncResult asyncResult, ref EndPoint endPoint) { ThrowIfDisposed(); @@ -2542,55 +2521,13 @@ public int EndReceiveFrom(IAsyncResult asyncResult, ref EndPoint endPoint) { throw new ArgumentException(SR.Format(SR.net_InvalidEndPointAddressFamily, endPoint.AddressFamily, _addressFamily), nameof(endPoint)); } - if (asyncResult == null) - { - throw new ArgumentNullException(nameof(asyncResult)); - } - - OverlappedAsyncResult? castedAsyncResult = asyncResult as OverlappedAsyncResult; - if (castedAsyncResult == null || castedAsyncResult.AsyncObject != this) - { - throw new ArgumentException(SR.net_io_invalidasyncresult, nameof(asyncResult)); - } - if (castedAsyncResult.EndCalled) - { - throw new InvalidOperationException(SR.Format(SR.net_io_invalidendcall, "EndReceiveFrom")); - } - Internals.SocketAddress socketAddressOriginal = Serialize(ref endPoint); - - int bytesTransferred = castedAsyncResult.InternalWaitForCompletionInt32Result(); - castedAsyncResult.EndCalled = true; - - // Update socket address size. - castedAsyncResult.SocketAddress!.InternalSize = castedAsyncResult.GetSocketAddressSize(); - - if (!socketAddressOriginal.Equals(castedAsyncResult.SocketAddress)) - { - try - { - endPoint = endPoint.Create(castedAsyncResult.SocketAddress); - } - catch - { - } - } - - if (NetEventSource.Log.IsEnabled()) NetEventSource.Info(this, $"bytesTransferred:{bytesTransferred}"); - - // Throw an appropriate SocketException if the native call failed asynchronously. - SocketError errorCode = (SocketError)castedAsyncResult.ErrorCode; - UpdateReceiveSocketErrorForDisposed(ref errorCode, bytesTransferred); - if (errorCode != SocketError.Success) - { - UpdateStatusAfterSocketErrorAndThrowException(errorCode); - } - else if (SocketsTelemetry.Log.IsEnabled()) + SocketReceiveFromResult result = TaskToApm.End(asyncResult); + if (!endPoint.Equals(result.RemoteEndPoint)) { - SocketsTelemetry.Log.BytesReceived(bytesTransferred); - if (SocketType == SocketType.Dgram) SocketsTelemetry.Log.DatagramReceived(); + endPoint = result.RemoteEndPoint; } - return bytesTransferred; + return result.ReceivedBytes; } // Routine Description: From 3d3e76297ffd37fd9d248d762ec9ec8498c1a4b1 Mon Sep 17 00:00:00 2001 From: Anton Firszov Date: Mon, 1 Feb 2021 14:30:08 +0100 Subject: [PATCH 05/23] ReceiveMessageFrom --- .../src/System/Net/Sockets/Socket.cs | 154 ++---------------- 1 file changed, 14 insertions(+), 140 deletions(-) diff --git a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/Socket.cs b/src/libraries/System.Net.Sockets/src/System/Net/Sockets/Socket.cs index e13898f08f030..2568475360478 100644 --- a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/Socket.cs +++ b/src/libraries/System.Net.Sockets/src/System/Net/Sockets/Socket.cs @@ -2333,97 +2333,14 @@ public IAsyncResult BeginReceiveMessageFrom(byte[] buffer, int offset, int size, ThrowIfDisposed(); ValidateBufferArguments(buffer, offset, size); - if (remoteEP == null) - { - throw new ArgumentNullException(nameof(remoteEP)); - } - if (!CanTryAddressFamily(remoteEP.AddressFamily)) - { - throw new ArgumentException(SR.Format(SR.net_InvalidEndPointAddressFamily, remoteEP.AddressFamily, _addressFamily), nameof(remoteEP)); - } - if (_rightEndPoint == null) - { - throw new InvalidOperationException(SR.net_sockets_mustbind); - } - - SocketPal.CheckDualModeReceiveSupport(this); - - // Set up the result and set it to collect the context. - ReceiveMessageOverlappedAsyncResult asyncResult = new ReceiveMessageOverlappedAsyncResult(this, state, callback); - asyncResult.StartPostingAsyncOp(false); - - // Start the ReceiveFrom. - EndPoint oldEndPoint = _rightEndPoint; - - // We don't do a CAS demand here because the contents of remoteEP aren't used by - // WSARecvMsg; all that matters is that we generate a unique-to-this-call SocketAddress - // with the right address family - Internals.SocketAddress socketAddress = Serialize(ref remoteEP); - - // Guarantee to call CheckAsyncCallOverlappedResult if we call SetUnamangedStructures with a cache in order to - // avoid a Socket leak in case of error. - SocketError errorCode = SocketError.SocketError; - try - { - // Save a copy of the original EndPoint in the asyncResult. - asyncResult.SocketAddressOriginal = IPEndPointExtensions.Serialize(remoteEP); - - SetReceivingPacketInformation(); - - if (_rightEndPoint == null) - { - _rightEndPoint = remoteEP; - } - - errorCode = SocketPal.ReceiveMessageFromAsync(this, _handle, buffer, offset, size, socketFlags, socketAddress, asyncResult); - - if (errorCode != SocketError.Success) - { - // WSARecvMsg() will never return WSAEMSGSIZE directly, since a completion is queued in this case. We wouldn't be able - // to handle this easily because of assumptions OverlappedAsyncResult makes about whether there would be a completion - // or not depending on the error code. If WSAEMSGSIZE would have been normally returned, it returns WSA_IO_PENDING instead. - // That same map is implemented here just in case. - if (errorCode == SocketError.MessageSize) - { - Debug.Fail("Returned WSAEMSGSIZE!"); - errorCode = SocketError.IOPending; - } - } - - if (NetEventSource.Log.IsEnabled()) NetEventSource.Info(this, $"ReceiveMessageFromAsync returns:{errorCode} size:{size} returning AsyncResult:{asyncResult}"); - } - catch (ObjectDisposedException) - { - _rightEndPoint = oldEndPoint; - _localEndPoint = null; - throw; - } - - // Throw an appropriate SocketException if the native call fails synchronously. - UpdateReceiveSocketErrorForDisposed(ref errorCode, bytesTransferred: 0); - if (!CheckErrorAndUpdateStatus(errorCode)) - { - // Update the internal state of this socket according to the error before throwing. - _rightEndPoint = oldEndPoint; - _localEndPoint = null; - - throw new SocketException((int)errorCode); - } - // Capture the context, maybe call the callback, and return. - asyncResult.FinishPostingAsyncOp(ref Caches.ReceiveClosureCache); - - if (asyncResult.CompletedSynchronously && !asyncResult.SocketAddressOriginal.Equals(asyncResult.SocketAddress)) + Task t = ReceiveMessageFromAsync(new Memory(buffer, offset, size), socketFlags, remoteEP).AsTask(); + if (t.IsCompletedSuccessfully) { - try - { - remoteEP = remoteEP.Create(asyncResult.SocketAddress!); - } - catch - { - } + EndPoint resultEp = t.Result.RemoteEndPoint; + if (!remoteEP.Equals(resultEp)) remoteEP = resultEp; } - + IAsyncResult asyncResult = TaskToApm.Begin(t, callback, state); if (NetEventSource.Log.IsEnabled()) NetEventSource.Info(this, $"size:{size} returning AsyncResult:{asyncResult}"); return asyncResult; } @@ -2439,59 +2356,15 @@ public int EndReceiveMessageFrom(IAsyncResult asyncResult, ref SocketFlags socke { throw new ArgumentException(SR.Format(SR.net_InvalidEndPointAddressFamily, endPoint.AddressFamily, _addressFamily), nameof(endPoint)); } - if (asyncResult == null) - { - throw new ArgumentNullException(nameof(asyncResult)); - } - - ReceiveMessageOverlappedAsyncResult? castedAsyncResult = asyncResult as ReceiveMessageOverlappedAsyncResult; - if (castedAsyncResult == null || castedAsyncResult.AsyncObject != this) - { - throw new ArgumentException(SR.net_io_invalidasyncresult, nameof(asyncResult)); - } - if (castedAsyncResult.EndCalled) - { - throw new InvalidOperationException(SR.Format(SR.net_io_invalidendcall, "EndReceiveMessageFrom")); - } - - Internals.SocketAddress socketAddressOriginal = Serialize(ref endPoint); - - int bytesTransferred = castedAsyncResult.InternalWaitForCompletionInt32Result(); - castedAsyncResult.EndCalled = true; - - // Update socket address size. - castedAsyncResult.SocketAddress!.InternalSize = castedAsyncResult.GetSocketAddressSize(); - - if (!socketAddressOriginal.Equals(castedAsyncResult.SocketAddress)) - { - try - { - endPoint = endPoint.Create(castedAsyncResult.SocketAddress); - } - catch - { - } - } - - if (NetEventSource.Log.IsEnabled()) NetEventSource.Info(this, $"bytesTransferred:{bytesTransferred}"); - SocketError errorCode = (SocketError)castedAsyncResult.ErrorCode; - UpdateReceiveSocketErrorForDisposed(ref errorCode, bytesTransferred); - // Throw an appropriate SocketException if the native call failed asynchronously. - if (errorCode != SocketError.Success && errorCode != SocketError.MessageSize) - { - UpdateStatusAfterSocketErrorAndThrowException(errorCode); - } - else if (SocketsTelemetry.Log.IsEnabled()) + SocketReceiveMessageFromResult result = TaskToApm.End(asyncResult); + if (!endPoint.Equals(result.RemoteEndPoint)) { - SocketsTelemetry.Log.BytesReceived(bytesTransferred); - if (errorCode == SocketError.Success && SocketType == SocketType.Dgram) SocketsTelemetry.Log.DatagramReceived(); + endPoint = result.RemoteEndPoint; } - - socketFlags = castedAsyncResult.SocketFlags; - ipPacketInformation = castedAsyncResult.IPPacketInformation; - - return bytesTransferred; + socketFlags = result.SocketFlags; + ipPacketInformation = result.PacketInformation; + return result.ReceivedBytes; } public IAsyncResult BeginReceiveFrom(byte[] buffer, int offset, int size, SocketFlags socketFlags, ref EndPoint remoteEP, AsyncCallback? callback, object? state) @@ -2500,9 +2373,10 @@ public IAsyncResult BeginReceiveFrom(byte[] buffer, int offset, int size, Socket ValidateBufferArguments(buffer, offset, size); Task t = ReceiveFromAsync(new Memory(buffer, offset, size), socketFlags, remoteEP).AsTask(); - if (t.IsCompleted) + if (t.IsCompletedSuccessfully) { - remoteEP = t.Result.RemoteEndPoint; + EndPoint resultEp = t.Result.RemoteEndPoint; + if (!remoteEP.Equals(resultEp)) remoteEP = resultEp; } return TaskToApm.Begin(t, callback, state); From 98e53c9af508de60b2d4046692f444dcaafcc098 Mon Sep 17 00:00:00 2001 From: Anton Firszov Date: Mon, 1 Feb 2021 15:57:26 +0100 Subject: [PATCH 06/23] WIP: consolidate ReceiveFrom argument validation tests --- .../ArgumentValidationTests.cs | 252 +++++++++--------- .../tests/FunctionalTests/ReceiveFrom.cs | 95 ++++++- .../tests/FunctionalTests/SocketTestHelper.cs | 7 + 3 files changed, 218 insertions(+), 136 deletions(-) diff --git a/src/libraries/System.Net.Sockets/tests/FunctionalTests/ArgumentValidationTests.cs b/src/libraries/System.Net.Sockets/tests/FunctionalTests/ArgumentValidationTests.cs index 470ff065748bf..9379eb8ba6eb9 100644 --- a/src/libraries/System.Net.Sockets/tests/FunctionalTests/ArgumentValidationTests.cs +++ b/src/libraries/System.Net.Sockets/tests/FunctionalTests/ArgumentValidationTests.cs @@ -330,50 +330,50 @@ public void Receive_Buffers_EmptyBuffers_Throws_Argument() AssertExtensions.Throws("buffers", () => GetSocket().Receive(new List>(), SocketFlags.None, out errorCode)); } - [Fact] - public void ReceiveFrom_NullBuffer_Throws_ArgumentNull() - { - EndPoint endpoint = new IPEndPoint(IPAddress.Loopback, 1); - Assert.Throws(() => GetSocket().ReceiveFrom(null, 0, 0, SocketFlags.None, ref endpoint)); - } - - [Fact] - public void ReceiveFrom_NullEndPoint_Throws_ArgumentNull() - { - EndPoint endpoint = null; - Assert.Throws(() => GetSocket().ReceiveFrom(s_buffer, 0, 0, SocketFlags.None, ref endpoint)); - } - - [Fact] - public void ReceiveFrom_AddressFamily_Throws_Argument() - { - EndPoint endpoint = new IPEndPoint(IPAddress.IPv6Loopback, 1); - AssertExtensions.Throws("remoteEP", () => GetSocket(AddressFamily.InterNetwork).ReceiveFrom(s_buffer, 0, 0, SocketFlags.None, ref endpoint)); - } - - [Fact] - public void ReceiveFrom_InvalidOffset_Throws_ArgumentOutOfRange() - { - EndPoint endpoint = new IPEndPoint(IPAddress.Loopback, 1); - Assert.Throws(() => GetSocket().ReceiveFrom(s_buffer, -1, s_buffer.Length, SocketFlags.None, ref endpoint)); - Assert.Throws(() => GetSocket().ReceiveFrom(s_buffer, s_buffer.Length + 1, s_buffer.Length, SocketFlags.None, ref endpoint)); - } - - [Fact] - public void ReceiveFrom_InvalidSize_Throws_ArgumentOutOfRange() - { - EndPoint endpoint = new IPEndPoint(IPAddress.Loopback, 1); - Assert.Throws(() => GetSocket().ReceiveFrom(s_buffer, 0, -1, SocketFlags.None, ref endpoint)); - Assert.Throws(() => GetSocket().ReceiveFrom(s_buffer, 0, s_buffer.Length + 1, SocketFlags.None, ref endpoint)); - Assert.Throws(() => GetSocket().ReceiveFrom(s_buffer, s_buffer.Length, 1, SocketFlags.None, ref endpoint)); - } - - [Fact] - public void ReceiveFrom_NotBound_Throws_InvalidOperation() - { - EndPoint endpoint = new IPEndPoint(IPAddress.Loopback, 1); - Assert.Throws(() => GetSocket().ReceiveFrom(s_buffer, 0, 0, SocketFlags.None, ref endpoint)); - } + //[Fact] + //public void ReceiveFrom_NullBuffer_Throws_ArgumentNull() + //{ + // EndPoint endpoint = new IPEndPoint(IPAddress.Loopback, 1); + // Assert.Throws(() => GetSocket().ReceiveFrom(null, 0, 0, SocketFlags.None, ref endpoint)); + //} + + //[Fact] + //public void ReceiveFrom_NullEndPoint_Throws_ArgumentNull() + //{ + // EndPoint endpoint = null; + // Assert.Throws(() => GetSocket().ReceiveFrom(s_buffer, 0, 0, SocketFlags.None, ref endpoint)); + //} + + //[Fact] + //public void ReceiveFrom_AddressFamily_Throws_Argument() + //{ + // EndPoint endpoint = new IPEndPoint(IPAddress.IPv6Loopback, 1); + // AssertExtensions.Throws("remoteEP", () => GetSocket(AddressFamily.InterNetwork).ReceiveFrom(s_buffer, 0, 0, SocketFlags.None, ref endpoint)); + //} + + //[Fact] + //public void ReceiveFrom_InvalidOffset_Throws_ArgumentOutOfRange() + //{ + // EndPoint endpoint = new IPEndPoint(IPAddress.Loopback, 1); + // Assert.Throws(() => GetSocket().ReceiveFrom(s_buffer, -1, s_buffer.Length, SocketFlags.None, ref endpoint)); + // Assert.Throws(() => GetSocket().ReceiveFrom(s_buffer, s_buffer.Length + 1, s_buffer.Length, SocketFlags.None, ref endpoint)); + //} + + //[Fact] + //public void ReceiveFrom_InvalidSize_Throws_ArgumentOutOfRange() + //{ + // EndPoint endpoint = new IPEndPoint(IPAddress.Loopback, 1); + // Assert.Throws(() => GetSocket().ReceiveFrom(s_buffer, 0, -1, SocketFlags.None, ref endpoint)); + // Assert.Throws(() => GetSocket().ReceiveFrom(s_buffer, 0, s_buffer.Length + 1, SocketFlags.None, ref endpoint)); + // Assert.Throws(() => GetSocket().ReceiveFrom(s_buffer, s_buffer.Length, 1, SocketFlags.None, ref endpoint)); + //} + + //[Fact] + //public void ReceiveFrom_NotBound_Throws_InvalidOperation() + //{ + // EndPoint endpoint = new IPEndPoint(IPAddress.Loopback, 1); + // Assert.Throws(() => GetSocket().ReceiveFrom(s_buffer, 0, 0, SocketFlags.None, ref endpoint)); + //} [Fact] public void ReceiveMessageFrom_NullBuffer_Throws_ArgumentNull() @@ -612,27 +612,27 @@ public void ReceiveAsync_NullAsyncEventArgs_Throws_ArgumentNull() Assert.Throws(() => GetSocket().ReceiveAsync(null)); } - [Fact] - public void ReceiveFromAsync_NullAsyncEventArgs_Throws_ArgumentNull() - { - Assert.Throws(() => GetSocket().ReceiveFromAsync(null)); - } + //[Fact] + //public void ReceiveFromAsync_NullAsyncEventArgs_Throws_ArgumentNull() + //{ + // Assert.Throws(() => GetSocket().ReceiveFromAsync(null)); + //} - [Fact] - public void ReceiveFromAsync_NullRemoteEndPoint_Throws_ArgumentException() - { - Assert.Throws("e", () => GetSocket().ReceiveFromAsync(s_eventArgs)); - } + //[Fact] + //public void ReceiveFromAsync_NullRemoteEndPoint_Throws_ArgumentException() + //{ + // Assert.Throws("e", () => GetSocket().ReceiveFromAsync(s_eventArgs)); + //} - [Fact] - public void ReceiveFromAsync_AddressFamily_Throws_Argument() - { - var eventArgs = new SocketAsyncEventArgs { - RemoteEndPoint = new IPEndPoint(IPAddress.IPv6Loopback, 1) - }; + //[Fact] + //public void ReceiveFromAsync_AddressFamily_Throws_Argument() + //{ + // var eventArgs = new SocketAsyncEventArgs { + // RemoteEndPoint = new IPEndPoint(IPAddress.IPv6Loopback, 1) + // }; - AssertExtensions.Throws("e", () => GetSocket(AddressFamily.InterNetwork).ReceiveFromAsync(eventArgs)); - } + // AssertExtensions.Throws("e", () => GetSocket(AddressFamily.InterNetwork).ReceiveFromAsync(eventArgs)); + //} [Fact] public void ReceiveMessageFromAsync_NullAsyncEventArgs_Throws_ArgumentNull() @@ -1313,70 +1313,70 @@ public void EndReceive_NullAsyncResult_Throws_ArgumentNull() Assert.Throws(() => GetSocket().EndReceive(null)); } - [Fact] - public void BeginReceiveFrom_NullBuffer_Throws_ArgumentNull() - { - EndPoint endpoint = new IPEndPoint(IPAddress.Loopback, 1); - Assert.Throws(() => GetSocket().BeginReceiveFrom(null, 0, 0, SocketFlags.None, ref endpoint, TheAsyncCallback, null)); - Assert.Throws(() => { GetSocket().ReceiveFromAsync(new ArraySegment(null, 0, 0), SocketFlags.None, endpoint); }); - } - - [Fact] - public void BeginReceiveFrom_NullEndPoint_Throws_ArgumentNull() - { - EndPoint endpoint = null; - Assert.Throws(() => GetSocket().BeginReceiveFrom(s_buffer, 0, 0, SocketFlags.None, ref endpoint, TheAsyncCallback, null)); - Assert.Throws(() => { GetSocket().ReceiveFromAsync(new ArraySegment(s_buffer, 0, 0), SocketFlags.None, endpoint); }); - } - - [Fact] - public void BeginReceiveFrom_AddressFamily_Throws_Argument() - { - EndPoint endpoint = new IPEndPoint(IPAddress.IPv6Loopback, 1); - AssertExtensions.Throws("remoteEP", () => GetSocket(AddressFamily.InterNetwork).BeginReceiveFrom(s_buffer, 0, 0, SocketFlags.None, ref endpoint, TheAsyncCallback, null)); - AssertExtensions.Throws("remoteEndPoint", () => { GetSocket(AddressFamily.InterNetwork).ReceiveFromAsync(new ArraySegment(s_buffer, 0, 0), SocketFlags.None, endpoint); }); - } - - [Fact] - public void BeginReceiveFrom_InvalidOffset_Throws_ArgumentOutOfRange() - { - EndPoint endpoint = new IPEndPoint(IPAddress.Loopback, 1); - - Assert.Throws(() => GetSocket().BeginReceiveFrom(s_buffer, -1, s_buffer.Length, SocketFlags.None, ref endpoint, TheAsyncCallback, null)); - Assert.Throws(() => GetSocket().BeginReceiveFrom(s_buffer, s_buffer.Length + 1, s_buffer.Length, SocketFlags.None, ref endpoint, TheAsyncCallback, null)); - - Assert.Throws(() => { GetSocket().ReceiveFromAsync(new ArraySegment(s_buffer, -1, s_buffer.Length), SocketFlags.None, endpoint); }); - Assert.ThrowsAny(() => { GetSocket().ReceiveFromAsync(new ArraySegment(s_buffer, s_buffer.Length + 1, s_buffer.Length), SocketFlags.None, endpoint); }); - } - - [Fact] - public void BeginReceiveFrom_InvalidSize_Throws_ArgumentOutOfRange() - { - EndPoint endpoint = new IPEndPoint(IPAddress.Loopback, 1); - - Assert.Throws(() => GetSocket().BeginReceiveFrom(s_buffer, 0, -1, SocketFlags.None, ref endpoint, TheAsyncCallback, null)); - Assert.Throws(() => GetSocket().BeginReceiveFrom(s_buffer, 0, s_buffer.Length + 1, SocketFlags.None, ref endpoint, TheAsyncCallback, null)); - Assert.Throws(() => GetSocket().BeginReceiveFrom(s_buffer, s_buffer.Length, 1, SocketFlags.None, ref endpoint, TheAsyncCallback, null)); - - Assert.Throws(() => { GetSocket().ReceiveFromAsync(new ArraySegment(s_buffer, 0, -1), SocketFlags.None, endpoint); }); - Assert.ThrowsAny(() => { GetSocket().ReceiveFromAsync(new ArraySegment(s_buffer, 0, s_buffer.Length + 1), SocketFlags.None, endpoint); }); - Assert.ThrowsAny(() => { GetSocket().ReceiveFromAsync(new ArraySegment(s_buffer, s_buffer.Length, 1), SocketFlags.None, endpoint); }); - } - - [Fact] - public void BeginReceiveFrom_NotBound_Throws_InvalidOperation() - { - EndPoint endpoint = new IPEndPoint(IPAddress.Loopback, 1); - Assert.Throws(() => GetSocket().BeginReceiveFrom(s_buffer, 0, 0, SocketFlags.None, ref endpoint, TheAsyncCallback, null)); - Assert.Throws(() => { GetSocket().ReceiveFromAsync(new ArraySegment(s_buffer, 0, 0), SocketFlags.None, endpoint); }); - } - - [Fact] - public void EndReceiveFrom_NullAsyncResult_Throws_ArgumentNull() - { - EndPoint endpoint = new IPEndPoint(IPAddress.Loopback, 1); - Assert.Throws(() => GetSocket().EndReceiveFrom(null, ref endpoint)); - } + //[Fact] + //public void BeginReceiveFrom_NullBuffer_Throws_ArgumentNull() + //{ + // EndPoint endpoint = new IPEndPoint(IPAddress.Loopback, 1); + // Assert.Throws(() => GetSocket().BeginReceiveFrom(null, 0, 0, SocketFlags.None, ref endpoint, TheAsyncCallback, null)); + // Assert.Throws(() => { GetSocket().ReceiveFromAsync(new ArraySegment(null, 0, 0), SocketFlags.None, endpoint); }); + //} + + //[Fact] + //public void BeginReceiveFrom_NullEndPoint_Throws_ArgumentNull() + //{ + // EndPoint endpoint = null; + // Assert.Throws(() => GetSocket().BeginReceiveFrom(s_buffer, 0, 0, SocketFlags.None, ref endpoint, TheAsyncCallback, null)); + // Assert.Throws(() => { GetSocket().ReceiveFromAsync(new ArraySegment(s_buffer, 0, 0), SocketFlags.None, endpoint); }); + //} + + //[Fact] + //public void BeginReceiveFrom_AddressFamily_Throws_Argument() + //{ + // EndPoint endpoint = new IPEndPoint(IPAddress.IPv6Loopback, 1); + // AssertExtensions.Throws("remoteEP", () => GetSocket(AddressFamily.InterNetwork).BeginReceiveFrom(s_buffer, 0, 0, SocketFlags.None, ref endpoint, TheAsyncCallback, null)); + // AssertExtensions.Throws("remoteEndPoint", () => { GetSocket(AddressFamily.InterNetwork).ReceiveFromAsync(new ArraySegment(s_buffer, 0, 0), SocketFlags.None, endpoint); }); + //} + + //[Fact] + //public void BeginReceiveFrom_InvalidOffset_Throws_ArgumentOutOfRange() + //{ + // EndPoint endpoint = new IPEndPoint(IPAddress.Loopback, 1); + + // Assert.Throws(() => GetSocket().BeginReceiveFrom(s_buffer, -1, s_buffer.Length, SocketFlags.None, ref endpoint, TheAsyncCallback, null)); + // Assert.Throws(() => GetSocket().BeginReceiveFrom(s_buffer, s_buffer.Length + 1, s_buffer.Length, SocketFlags.None, ref endpoint, TheAsyncCallback, null)); + + // Assert.Throws(() => { GetSocket().ReceiveFromAsync(new ArraySegment(s_buffer, -1, s_buffer.Length), SocketFlags.None, endpoint); }); + // Assert.ThrowsAny(() => { GetSocket().ReceiveFromAsync(new ArraySegment(s_buffer, s_buffer.Length + 1, s_buffer.Length), SocketFlags.None, endpoint); }); + //} + + //[Fact] + //public void BeginReceiveFrom_InvalidSize_Throws_ArgumentOutOfRange() + //{ + // EndPoint endpoint = new IPEndPoint(IPAddress.Loopback, 1); + + // Assert.Throws(() => GetSocket().BeginReceiveFrom(s_buffer, 0, -1, SocketFlags.None, ref endpoint, TheAsyncCallback, null)); + // Assert.Throws(() => GetSocket().BeginReceiveFrom(s_buffer, 0, s_buffer.Length + 1, SocketFlags.None, ref endpoint, TheAsyncCallback, null)); + // Assert.Throws(() => GetSocket().BeginReceiveFrom(s_buffer, s_buffer.Length, 1, SocketFlags.None, ref endpoint, TheAsyncCallback, null)); + + // Assert.Throws(() => { GetSocket().ReceiveFromAsync(new ArraySegment(s_buffer, 0, -1), SocketFlags.None, endpoint); }); + // Assert.ThrowsAny(() => { GetSocket().ReceiveFromAsync(new ArraySegment(s_buffer, 0, s_buffer.Length + 1), SocketFlags.None, endpoint); }); + // Assert.ThrowsAny(() => { GetSocket().ReceiveFromAsync(new ArraySegment(s_buffer, s_buffer.Length, 1), SocketFlags.None, endpoint); }); + //} + + //[Fact] + //public void BeginReceiveFrom_NotBound_Throws_InvalidOperation() + //{ + // EndPoint endpoint = new IPEndPoint(IPAddress.Loopback, 1); + // Assert.Throws(() => GetSocket().BeginReceiveFrom(s_buffer, 0, 0, SocketFlags.None, ref endpoint, TheAsyncCallback, null)); + // Assert.Throws(() => { GetSocket().ReceiveFromAsync(new ArraySegment(s_buffer, 0, 0), SocketFlags.None, endpoint); }); + //} + + //[Fact] + //public void EndReceiveFrom_NullAsyncResult_Throws_ArgumentNull() + //{ + // EndPoint endpoint = new IPEndPoint(IPAddress.Loopback, 1); + // Assert.Throws(() => GetSocket().EndReceiveFrom(null, ref endpoint)); + //} [Fact] public void BeginReceiveMessageFrom_NullBuffer_Throws_ArgumentNull() diff --git a/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveFrom.cs b/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveFrom.cs index 51492518279ea..521abac8dc117 100644 --- a/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveFrom.cs +++ b/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveFrom.cs @@ -2,6 +2,7 @@ // The .NET Foundation licenses this file to you under the MIT license. using System.Collections.Generic; +using System.Diagnostics; using System.Threading; using System.Threading.Tasks; using Xunit; @@ -12,21 +13,26 @@ namespace System.Net.Sockets.Tests { public abstract class ReceiveFrom : SocketTestHelperBase where T : SocketHelperBase, new() { + protected static Socket CreateSocket(AddressFamily addressFamily = AddressFamily.InterNetwork) => new Socket(addressFamily, SocketType.Dgram, ProtocolType.Udp); + protected static IPEndPoint GetGetDummyTestEndpoint(AddressFamily addressFamily = AddressFamily.InterNetwork) => addressFamily == AddressFamily.InterNetwork ? new IPEndPoint(IPAddress.Parse("1.2.3.4"), 1234) : new IPEndPoint(IPAddress.Parse("1:2:3::4"), 1234); protected static readonly TimeSpan CancellationTestTimeout = TimeSpan.FromSeconds(30); + protected virtual string RemoteEndPointArgumentName => "remoteEP"; + protected ReceiveFrom(ITestOutputHelper output) : base(output) { } [Theory] [InlineData(1, -1, 0)] // offset low [InlineData(1, 2, 0)] // offset high [InlineData(1, 0, -1)] // count low - [InlineData(1, 1, 2)] // count high - public async Task OutOfRange_Throws(int length, int offset, int count) + [InlineData(1, 0, 2)] // count high + [InlineData(1, 1, 1)] // count high + public async Task OutOfRange_Throws_ArgumentOutOfRangeException(int length, int offset, int count) { - using var socket = new Socket(AddressFamily.InterNetwork, SocketType.Dgram, ProtocolType.Udp); + using Socket socket = CreateSocket(); ArraySegment buffer = new FakeArraySegment { @@ -39,20 +45,40 @@ public async Task OutOfRange_Throws(int length, int offset, int count) } [Fact] - public async Task NullBuffer_Throws() + public async Task NullBuffer_Throws_ArgumentNullException() { if (!ValidatesArrayArguments) return; - using var socket = new Socket(AddressFamily.InterNetwork, SocketType.Dgram, ProtocolType.Udp); - + using Socket socket = CreateSocket(); await Assert.ThrowsAsync(() => ReceiveFromAsync(socket, null, GetGetDummyTestEndpoint())); } [Fact] - public async Task NullEndpoint_Throws() + public async Task NullEndpoint_Throws_ArgumentException() { - using var socket = new Socket(AddressFamily.InterNetwork, SocketType.Dgram, ProtocolType.Udp); + using Socket socket = CreateSocket(); + if (UsesEap) + { + await Assert.ThrowsAsync(RemoteEndPointArgumentName, () => ReceiveFromAsync(socket, new byte[1], null)); + } + else + { + await Assert.ThrowsAsync(RemoteEndPointArgumentName, () => ReceiveFromAsync(socket, new byte[1], null)); + } + } + + [Fact] + public void AddressFamilyDoesNotMatch_Throws_ArgumentException() + { + using var ipv4Socket = CreateSocket(); + EndPoint ipV6Endpoint = GetGetDummyTestEndpoint(AddressFamily.InterNetworkV6); + Assert.ThrowsAsync(RemoteEndPointArgumentName, () => ReceiveFromAsync(ipv4Socket, new byte[1], ipV6Endpoint)); + } - await Assert.ThrowsAnyAsync(() => ReceiveFromAsync(socket, new byte[1], null)); + [Fact] + public void NotBound_Throws_InvalidOperationException() + { + using Socket socket = CreateSocket(); + Assert.ThrowsAsync(() => ReceiveFromAsync(socket, new byte[1], GetGetDummyTestEndpoint())); } [Theory] @@ -198,22 +224,58 @@ public ReceiveFrom_SyncForceNonBlocking(ITestOutputHelper output) : base(output) public sealed class ReceiveFrom_Apm : ReceiveFrom { public ReceiveFrom_Apm(ITestOutputHelper output) : base(output) { } + + protected override string RemoteEndPointArgumentName => "remoteEndPoint"; + + [Fact] + public void EndReceiveFrom_NullAsyncResult_Throws_ArgumentNullException() + { + EndPoint endpoint = new IPEndPoint(IPAddress.Loopback, 1); + using Socket socket = CreateSocket(); + Assert.Throws(() => socket.EndReceiveFrom(null, ref endpoint)); + } + + [Fact] + public void EndReceiveFrom_NullEndPoint_Throws_ArgumentNullException() + { + EndPoint validEndPoint = new IPEndPoint(IPAddress.Loopback, 1); + EndPoint invalidEndPoint = null; + using Socket socket = CreateSocket(); + socket.BindToAnonymousPort(IPAddress.Loopback); + IAsyncResult iar = socket.BeginReceiveFrom(new byte[1], 0, 1, SocketFlags.None, ref validEndPoint, null, null); + Assert.Throws(RemoteEndPointArgumentName, () => socket.EndReceiveFrom(iar, ref invalidEndPoint)); + } + + [Fact] + public void EndReceiveFrom_AddressFamilyDoesNotMatch_Throws_ArgumentException() + { + EndPoint validEndPoint = new IPEndPoint(IPAddress.Loopback, 1); + EndPoint invalidEndPoint = new IPEndPoint(IPAddress.IPv6Loopback, 1); + using Socket socket = CreateSocket(); + socket.BindToAnonymousPort(IPAddress.Loopback); + IAsyncResult iar = socket.BeginReceiveFrom(new byte[1], 0, 1, SocketFlags.None, ref validEndPoint, null, null); + Assert.Throws(RemoteEndPointArgumentName, () => socket.EndReceiveFrom(iar, ref invalidEndPoint)); + } } public sealed class ReceiveFrom_Task : ReceiveFrom { public ReceiveFrom_Task(ITestOutputHelper output) : base(output) { } + + protected override string RemoteEndPointArgumentName => "remoteEndPoint"; } public sealed class ReceiveFrom_CancellableTask : ReceiveFrom { public ReceiveFrom_CancellableTask(ITestOutputHelper output) : base(output) { } + protected override string RemoteEndPointArgumentName => "remoteEndPoint"; + [Theory] [MemberData(nameof(LoopbacksAndBuffers))] public async Task WhenCanceled_Throws(IPAddress loopback, bool precanceled) { - using var socket = new Socket(loopback.AddressFamily, SocketType.Dgram, ProtocolType.Udp); + using Socket socket = new Socket(loopback.AddressFamily, SocketType.Dgram, ProtocolType.Udp); using var dummy = new Socket(loopback.AddressFamily, SocketType.Dgram, ProtocolType.Udp); socket.BindToAnonymousPort(loopback); dummy.BindToAnonymousPort(loopback); @@ -233,6 +295,15 @@ public async Task WhenCanceled_Throws(IPAddress loopback, bool precanceled) public sealed class ReceiveFrom_Eap : ReceiveFrom { public ReceiveFrom_Eap(ITestOutputHelper output) : base(output) { } + + protected override string RemoteEndPointArgumentName => "e"; + + [Fact] + public void ReceiveFromAsync_NullAsyncEventArgs_Throws_ArgumentNull() + { + using Socket socket = CreateSocket(); + Assert.Throws(() => socket.ReceiveFromAsync(null)); + } } public sealed class ReceiveFrom_SpanSync : ReceiveFrom @@ -248,10 +319,14 @@ public ReceiveFrom_SpanSyncForceNonBlocking(ITestOutputHelper output) : base(out public sealed class ReceiveFrom_MemoryArrayTask : ReceiveFrom { public ReceiveFrom_MemoryArrayTask(ITestOutputHelper output) : base(output) { } + + protected override string RemoteEndPointArgumentName => "remoteEndPoint"; } public sealed class ReceiveFrom_MemoryNativeTask : ReceiveFrom { public ReceiveFrom_MemoryNativeTask(ITestOutputHelper output) : base(output) { } + + protected override string RemoteEndPointArgumentName => "remoteEndPoint"; } } diff --git a/src/libraries/System.Net.Sockets/tests/FunctionalTests/SocketTestHelper.cs b/src/libraries/System.Net.Sockets/tests/FunctionalTests/SocketTestHelper.cs index a401f50d27f03..cedf959b50bc1 100644 --- a/src/libraries/System.Net.Sockets/tests/FunctionalTests/SocketTestHelper.cs +++ b/src/libraries/System.Net.Sockets/tests/FunctionalTests/SocketTestHelper.cs @@ -39,6 +39,8 @@ public abstract Task ReceiveMessageFromAsync( public virtual bool ValidatesArrayArguments => true; public virtual bool UsesSync => false; public virtual bool UsesApm => false; + public virtual bool UsesEap => false; + public virtual bool UsesTasks => false; public virtual bool DisposeDuringOperationResultsInDisposedException => false; public virtual bool ConnectAfterDisconnectResultsInInvalidOperationException => false; public virtual bool SupportsMultiConnect => true; @@ -209,6 +211,7 @@ public override Task SendFileAsync(Socket s, string fileName, ArraySegment public class SocketHelperTask : SocketHelperBase { + public override bool UsesTasks => true; public override Task AcceptAsync(Socket s) => s.AcceptAsync(); public override Task<(Socket socket, byte[] buffer)> AcceptAsync(Socket s, int receiveSize) @@ -240,6 +243,7 @@ public override Task SendToAsync(Socket s, ArraySegment buffer, EndPo // Same as above, but call the CancellationToken overloads where possible public class SocketHelperCancellableTask : SocketHelperBase { + public override bool UsesTasks => true; // Use a cancellable CancellationToken that we never cancel so that implementations can't just elide handling the CancellationToken. private readonly CancellationTokenSource _cts = new CancellationTokenSource(); // This variant is typically working with Memory overloads. @@ -275,6 +279,7 @@ public override Task SendToAsync(Socket s, ArraySegment buffer, EndPo public sealed class SocketHelperEap : SocketHelperBase { + public override bool UsesEap => true; public override bool ValidatesArrayArguments => false; public override bool SupportsAcceptReceive => true; @@ -423,6 +428,8 @@ public Task SendFileAsync(Socket s, string fileName, ArraySegment preBuffe public bool ValidatesArrayArguments => _socketHelper.ValidatesArrayArguments; public bool UsesSync => _socketHelper.UsesSync; public bool UsesApm => _socketHelper.UsesApm; + public bool UsesEap => _socketHelper.UsesEap; + public bool UsesTask => _socketHelper.UsesTasks; public bool DisposeDuringOperationResultsInDisposedException => _socketHelper.DisposeDuringOperationResultsInDisposedException; public bool ConnectAfterDisconnectResultsInInvalidOperationException => _socketHelper.ConnectAfterDisconnectResultsInInvalidOperationException; public bool SupportsMultiConnect => _socketHelper.SupportsMultiConnect; From 5702da333ac3d6be6878fdab41ac85152c966946 Mon Sep 17 00:00:00 2001 From: Anton Firszov Date: Mon, 1 Feb 2021 16:11:21 +0100 Subject: [PATCH 07/23] BeginReceiveFrom_RemoteEpIsReturnedWhenCompletedSynchronously --- .../tests/FunctionalTests/ReceiveFrom.cs | 25 +++++++++++++++++++ 1 file changed, 25 insertions(+) diff --git a/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveFrom.cs b/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveFrom.cs index 521abac8dc117..bb58a15f6a278 100644 --- a/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveFrom.cs +++ b/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveFrom.cs @@ -256,6 +256,31 @@ public void EndReceiveFrom_AddressFamilyDoesNotMatch_Throws_ArgumentException() IAsyncResult iar = socket.BeginReceiveFrom(new byte[1], 0, 1, SocketFlags.None, ref validEndPoint, null, null); Assert.Throws(RemoteEndPointArgumentName, () => socket.EndReceiveFrom(iar, ref invalidEndPoint)); } + + [Fact] + public void BeginReceiveFrom_RemoteEpIsReturnedWhenCompletedSynchronously() + { + EndPoint anyEp = new IPEndPoint(IPAddress.Any, 0); + EndPoint remoteEp = anyEp; + using Socket receiver = CreateSocket(); + receiver.BindToAnonymousPort(IPAddress.Loopback); + using Socket sender = CreateSocket(); + sender.BindToAnonymousPort(IPAddress.Loopback); + + sender.SendTo(new byte[1], receiver.LocalEndPoint); + + IAsyncResult iar = receiver.BeginReceiveFrom(new byte[1], 0, 1, SocketFlags.None, ref remoteEp, null, null); + if (iar.CompletedSynchronously) + { + _output.WriteLine("Completed synchronously, updated endpoint."); + Assert.Equal(sender.LocalEndPoint, remoteEp); + } + else + { + _output.WriteLine("Completed asynchronously, did not update endPoint"); + Assert.Equal(anyEp, remoteEp); + } + } } public sealed class ReceiveFrom_Task : ReceiveFrom From 0e8726f8b6a785a3f21eeb1defa1b4fc5ec5bda1 Mon Sep 17 00:00:00 2001 From: Anton Firszov Date: Mon, 1 Feb 2021 16:33:55 +0100 Subject: [PATCH 08/23] WIP: consolidate ReceiveMessageFrom argument validation tests --- .../ArgumentValidationTests.cs | 282 +++++++++--------- .../FunctionalTests/ReceiveMessageFrom.cs | 141 +++++++++ 2 files changed, 282 insertions(+), 141 deletions(-) diff --git a/src/libraries/System.Net.Sockets/tests/FunctionalTests/ArgumentValidationTests.cs b/src/libraries/System.Net.Sockets/tests/FunctionalTests/ArgumentValidationTests.cs index 9379eb8ba6eb9..7b1812e2110f8 100644 --- a/src/libraries/System.Net.Sockets/tests/FunctionalTests/ArgumentValidationTests.cs +++ b/src/libraries/System.Net.Sockets/tests/FunctionalTests/ArgumentValidationTests.cs @@ -375,68 +375,68 @@ public void Receive_Buffers_EmptyBuffers_Throws_Argument() // Assert.Throws(() => GetSocket().ReceiveFrom(s_buffer, 0, 0, SocketFlags.None, ref endpoint)); //} - [Fact] - public void ReceiveMessageFrom_NullBuffer_Throws_ArgumentNull() - { - SocketFlags flags = SocketFlags.None; - EndPoint remote = new IPEndPoint(IPAddress.Loopback, 1); - IPPacketInformation packetInfo; + //[Fact] + //public void ReceiveMessageFrom_NullBuffer_Throws_ArgumentNull() + //{ + // SocketFlags flags = SocketFlags.None; + // EndPoint remote = new IPEndPoint(IPAddress.Loopback, 1); + // IPPacketInformation packetInfo; - Assert.Throws(() => GetSocket().ReceiveMessageFrom(null, 0, 0, ref flags, ref remote, out packetInfo)); - } + // Assert.Throws(() => GetSocket().ReceiveMessageFrom(null, 0, 0, ref flags, ref remote, out packetInfo)); + //} - [Fact] - public void ReceiveMessageFrom_NullEndPoint_Throws_ArgumentNull() - { - SocketFlags flags = SocketFlags.None; - EndPoint remote = null; - IPPacketInformation packetInfo; + //[Fact] + //public void ReceiveMessageFrom_NullEndPoint_Throws_ArgumentNull() + //{ + // SocketFlags flags = SocketFlags.None; + // EndPoint remote = null; + // IPPacketInformation packetInfo; - Assert.Throws(() => GetSocket().ReceiveMessageFrom(s_buffer, 0, 0, ref flags, ref remote, out packetInfo)); - } + // Assert.Throws(() => GetSocket().ReceiveMessageFrom(s_buffer, 0, 0, ref flags, ref remote, out packetInfo)); + //} - [Fact] - public void ReceiveMessageFrom_AddressFamily_Throws_Argument() - { - SocketFlags flags = SocketFlags.None; - EndPoint remote = new IPEndPoint(IPAddress.IPv6Loopback, 1); - IPPacketInformation packetInfo; + //[Fact] + //public void ReceiveMessageFrom_AddressFamily_Throws_Argument() + //{ + // SocketFlags flags = SocketFlags.None; + // EndPoint remote = new IPEndPoint(IPAddress.IPv6Loopback, 1); + // IPPacketInformation packetInfo; - AssertExtensions.Throws("remoteEP", () => GetSocket(AddressFamily.InterNetwork).ReceiveMessageFrom(s_buffer, 0, 0, ref flags, ref remote, out packetInfo)); - } + // AssertExtensions.Throws("remoteEP", () => GetSocket(AddressFamily.InterNetwork).ReceiveMessageFrom(s_buffer, 0, 0, ref flags, ref remote, out packetInfo)); + //} - [Fact] - public void ReceiveMessageFrom_InvalidOffset_Throws_ArgumentOutOfRange() - { - SocketFlags flags = SocketFlags.None; - EndPoint remote = new IPEndPoint(IPAddress.Loopback, 1); - IPPacketInformation packetInfo; + //[Fact] + //public void ReceiveMessageFrom_InvalidOffset_Throws_ArgumentOutOfRange() + //{ + // SocketFlags flags = SocketFlags.None; + // EndPoint remote = new IPEndPoint(IPAddress.Loopback, 1); + // IPPacketInformation packetInfo; - Assert.Throws(() => GetSocket().ReceiveMessageFrom(s_buffer, -1, s_buffer.Length, ref flags, ref remote, out packetInfo)); - Assert.Throws(() => GetSocket().ReceiveMessageFrom(s_buffer, s_buffer.Length + 1, s_buffer.Length, ref flags, ref remote, out packetInfo)); - } + // Assert.Throws(() => GetSocket().ReceiveMessageFrom(s_buffer, -1, s_buffer.Length, ref flags, ref remote, out packetInfo)); + // Assert.Throws(() => GetSocket().ReceiveMessageFrom(s_buffer, s_buffer.Length + 1, s_buffer.Length, ref flags, ref remote, out packetInfo)); + //} - [Fact] - public void ReceiveMessageFrom_InvalidSize_Throws_ArgumentOutOfRange() - { - SocketFlags flags = SocketFlags.None; - EndPoint remote = new IPEndPoint(IPAddress.Loopback, 1); - IPPacketInformation packetInfo; + //[Fact] + //public void ReceiveMessageFrom_InvalidSize_Throws_ArgumentOutOfRange() + //{ + // SocketFlags flags = SocketFlags.None; + // EndPoint remote = new IPEndPoint(IPAddress.Loopback, 1); + // IPPacketInformation packetInfo; - Assert.Throws(() => GetSocket().ReceiveMessageFrom(s_buffer, 0, -1, ref flags, ref remote, out packetInfo)); - Assert.Throws(() => GetSocket().ReceiveMessageFrom(s_buffer, 0, s_buffer.Length + 1, ref flags, ref remote, out packetInfo)); - Assert.Throws(() => GetSocket().ReceiveMessageFrom(s_buffer, s_buffer.Length, 1, ref flags, ref remote, out packetInfo)); - } + // Assert.Throws(() => GetSocket().ReceiveMessageFrom(s_buffer, 0, -1, ref flags, ref remote, out packetInfo)); + // Assert.Throws(() => GetSocket().ReceiveMessageFrom(s_buffer, 0, s_buffer.Length + 1, ref flags, ref remote, out packetInfo)); + // Assert.Throws(() => GetSocket().ReceiveMessageFrom(s_buffer, s_buffer.Length, 1, ref flags, ref remote, out packetInfo)); + //} - [Fact] - public void ReceiveMessageFrom_NotBound_Throws_InvalidOperation() - { - SocketFlags flags = SocketFlags.None; - EndPoint remote = new IPEndPoint(IPAddress.Loopback, 1); - IPPacketInformation packetInfo; + //[Fact] + //public void ReceiveMessageFrom_NotBound_Throws_InvalidOperation() + //{ + // SocketFlags flags = SocketFlags.None; + // EndPoint remote = new IPEndPoint(IPAddress.Loopback, 1); + // IPPacketInformation packetInfo; - Assert.Throws(() => GetSocket().ReceiveMessageFrom(s_buffer, 0, 0, ref flags, ref remote, out packetInfo)); - } + // Assert.Throws(() => GetSocket().ReceiveMessageFrom(s_buffer, 0, 0, ref flags, ref remote, out packetInfo)); + //} [Fact] public void SetSocketOption_Object_ObjectNull_Throws_ArgumentNull() @@ -634,27 +634,27 @@ public void ReceiveAsync_NullAsyncEventArgs_Throws_ArgumentNull() // AssertExtensions.Throws("e", () => GetSocket(AddressFamily.InterNetwork).ReceiveFromAsync(eventArgs)); //} - [Fact] - public void ReceiveMessageFromAsync_NullAsyncEventArgs_Throws_ArgumentNull() - { - Assert.Throws(() => GetSocket().ReceiveMessageFromAsync(null)); - } + //[Fact] + //public void ReceiveMessageFromAsync_NullAsyncEventArgs_Throws_ArgumentNull() + //{ + // Assert.Throws(() => GetSocket().ReceiveMessageFromAsync(null)); + //} - [Fact] - public void ReceiveMessageFromAsync_NullRemoteEndPoint_Throws_ArgumentException() - { - Assert.Throws("e", () => GetSocket().ReceiveMessageFromAsync(s_eventArgs)); - } + //[Fact] + //public void ReceiveMessageFromAsync_NullRemoteEndPoint_Throws_ArgumentException() + //{ + // Assert.Throws("e", () => GetSocket().ReceiveMessageFromAsync(s_eventArgs)); + //} - [Fact] - public void ReceiveMessageFromAsync_AddressFamily_Throws_Argument() - { - var eventArgs = new SocketAsyncEventArgs { - RemoteEndPoint = new IPEndPoint(IPAddress.IPv6Loopback, 1) - }; + //[Fact] + //public void ReceiveMessageFromAsync_AddressFamily_Throws_Argument() + //{ + // var eventArgs = new SocketAsyncEventArgs { + // RemoteEndPoint = new IPEndPoint(IPAddress.IPv6Loopback, 1) + // }; - AssertExtensions.Throws("e", () => GetSocket(AddressFamily.InterNetwork).ReceiveMessageFromAsync(eventArgs)); - } + // AssertExtensions.Throws("e", () => GetSocket(AddressFamily.InterNetwork).ReceiveMessageFromAsync(eventArgs)); + //} [Fact] public void SendAsync_NullAsyncEventArgs_Throws_ArgumentNull() @@ -1378,97 +1378,97 @@ public void EndReceive_NullAsyncResult_Throws_ArgumentNull() // Assert.Throws(() => GetSocket().EndReceiveFrom(null, ref endpoint)); //} - [Fact] - public void BeginReceiveMessageFrom_NullBuffer_Throws_ArgumentNull() - { - EndPoint remote = new IPEndPoint(IPAddress.Loopback, 1); + //[Fact] + //public void BeginReceiveMessageFrom_NullBuffer_Throws_ArgumentNull() + //{ + // EndPoint remote = new IPEndPoint(IPAddress.Loopback, 1); - Assert.Throws(() => GetSocket().BeginReceiveMessageFrom(null, 0, 0, SocketFlags.None, ref remote, TheAsyncCallback, null)); - Assert.Throws(() => { GetSocket().ReceiveMessageFromAsync(new ArraySegment(null, 0, 0), SocketFlags.None, remote); }); - } + // Assert.Throws(() => GetSocket().BeginReceiveMessageFrom(null, 0, 0, SocketFlags.None, ref remote, TheAsyncCallback, null)); + // Assert.Throws(() => { GetSocket().ReceiveMessageFromAsync(new ArraySegment(null, 0, 0), SocketFlags.None, remote); }); + //} - [Fact] - public void BeginReceiveMessageFrom_NullEndPoint_Throws_ArgumentNull() - { - EndPoint remote = null; + //[Fact] + //public void BeginReceiveMessageFrom_NullEndPoint_Throws_ArgumentNull() + //{ + // EndPoint remote = null; - Assert.Throws(() => GetSocket().BeginReceiveMessageFrom(s_buffer, 0, 0, SocketFlags.None, ref remote, TheAsyncCallback, null)); - Assert.Throws(() => { GetSocket().ReceiveMessageFromAsync(new ArraySegment(s_buffer, 0, 0), SocketFlags.None, remote); }); - } + // Assert.Throws(() => GetSocket().BeginReceiveMessageFrom(s_buffer, 0, 0, SocketFlags.None, ref remote, TheAsyncCallback, null)); + // Assert.Throws(() => { GetSocket().ReceiveMessageFromAsync(new ArraySegment(s_buffer, 0, 0), SocketFlags.None, remote); }); + //} - [Fact] - public void BeginReceiveMessageFrom_AddressFamily_Throws_Argument() - { - EndPoint remote = new IPEndPoint(IPAddress.IPv6Loopback, 1); + //[Fact] + //public void BeginReceiveMessageFrom_AddressFamily_Throws_Argument() + //{ + // EndPoint remote = new IPEndPoint(IPAddress.IPv6Loopback, 1); - AssertExtensions.Throws("remoteEP", () => GetSocket(AddressFamily.InterNetwork).BeginReceiveMessageFrom(s_buffer, 0, 0, SocketFlags.None, ref remote, TheAsyncCallback, null)); - AssertExtensions.Throws("remoteEndPoint", () => { GetSocket(AddressFamily.InterNetwork).ReceiveMessageFromAsync(new ArraySegment(s_buffer, 0, 0), SocketFlags.None, remote); }); - } + // AssertExtensions.Throws("remoteEP", () => GetSocket(AddressFamily.InterNetwork).BeginReceiveMessageFrom(s_buffer, 0, 0, SocketFlags.None, ref remote, TheAsyncCallback, null)); + // AssertExtensions.Throws("remoteEndPoint", () => { GetSocket(AddressFamily.InterNetwork).ReceiveMessageFromAsync(new ArraySegment(s_buffer, 0, 0), SocketFlags.None, remote); }); + //} - [Fact] - public void BeginReceiveMessageFrom_InvalidOffset_Throws_ArgumentOutOfRange() - { - EndPoint remote = new IPEndPoint(IPAddress.Loopback, 1); + //[Fact] + //public void BeginReceiveMessageFrom_InvalidOffset_Throws_ArgumentOutOfRange() + //{ + // EndPoint remote = new IPEndPoint(IPAddress.Loopback, 1); - Assert.Throws(() => GetSocket().BeginReceiveMessageFrom(s_buffer, -1, s_buffer.Length, SocketFlags.None, ref remote, TheAsyncCallback, null)); - Assert.Throws(() => GetSocket().BeginReceiveMessageFrom(s_buffer, s_buffer.Length + 1, s_buffer.Length, SocketFlags.None, ref remote, TheAsyncCallback, null)); + // Assert.Throws(() => GetSocket().BeginReceiveMessageFrom(s_buffer, -1, s_buffer.Length, SocketFlags.None, ref remote, TheAsyncCallback, null)); + // Assert.Throws(() => GetSocket().BeginReceiveMessageFrom(s_buffer, s_buffer.Length + 1, s_buffer.Length, SocketFlags.None, ref remote, TheAsyncCallback, null)); - Assert.Throws(() => { GetSocket().ReceiveMessageFromAsync(new ArraySegment(s_buffer, -1, s_buffer.Length), SocketFlags.None, remote); }); - Assert.ThrowsAny(() => { GetSocket().ReceiveMessageFromAsync(new ArraySegment(s_buffer, s_buffer.Length + 1, s_buffer.Length), SocketFlags.None, remote); }); - } + // Assert.Throws(() => { GetSocket().ReceiveMessageFromAsync(new ArraySegment(s_buffer, -1, s_buffer.Length), SocketFlags.None, remote); }); + // Assert.ThrowsAny(() => { GetSocket().ReceiveMessageFromAsync(new ArraySegment(s_buffer, s_buffer.Length + 1, s_buffer.Length), SocketFlags.None, remote); }); + //} - [Fact] - public void BeginReceiveMessageFrom_InvalidSize_Throws_ArgumentOutOfRange() - { - EndPoint remote = new IPEndPoint(IPAddress.Loopback, 1); + //[Fact] + //public void BeginReceiveMessageFrom_InvalidSize_Throws_ArgumentOutOfRange() + //{ + // EndPoint remote = new IPEndPoint(IPAddress.Loopback, 1); - Assert.Throws(() => GetSocket().BeginReceiveMessageFrom(s_buffer, 0, -1, SocketFlags.None, ref remote, TheAsyncCallback, null)); - Assert.Throws(() => GetSocket().BeginReceiveMessageFrom(s_buffer, 0, s_buffer.Length + 1, SocketFlags.None, ref remote, TheAsyncCallback, null)); - Assert.Throws(() => GetSocket().BeginReceiveMessageFrom(s_buffer, s_buffer.Length, 1, SocketFlags.None, ref remote, TheAsyncCallback, null)); + // Assert.Throws(() => GetSocket().BeginReceiveMessageFrom(s_buffer, 0, -1, SocketFlags.None, ref remote, TheAsyncCallback, null)); + // Assert.Throws(() => GetSocket().BeginReceiveMessageFrom(s_buffer, 0, s_buffer.Length + 1, SocketFlags.None, ref remote, TheAsyncCallback, null)); + // Assert.Throws(() => GetSocket().BeginReceiveMessageFrom(s_buffer, s_buffer.Length, 1, SocketFlags.None, ref remote, TheAsyncCallback, null)); - Assert.Throws(() => { GetSocket().ReceiveMessageFromAsync(new ArraySegment(s_buffer, 0, -1), SocketFlags.None, remote); }); - Assert.ThrowsAny(() => { GetSocket().ReceiveMessageFromAsync(new ArraySegment(s_buffer, 0, s_buffer.Length + 1), SocketFlags.None, remote); }); - Assert.ThrowsAny(() => { GetSocket().ReceiveMessageFromAsync(new ArraySegment(s_buffer, s_buffer.Length, 1), SocketFlags.None, remote); }); - } + // Assert.Throws(() => { GetSocket().ReceiveMessageFromAsync(new ArraySegment(s_buffer, 0, -1), SocketFlags.None, remote); }); + // Assert.ThrowsAny(() => { GetSocket().ReceiveMessageFromAsync(new ArraySegment(s_buffer, 0, s_buffer.Length + 1), SocketFlags.None, remote); }); + // Assert.ThrowsAny(() => { GetSocket().ReceiveMessageFromAsync(new ArraySegment(s_buffer, s_buffer.Length, 1), SocketFlags.None, remote); }); + //} - [Fact] - public void BeginReceiveMessageFrom_NotBound_Throws_InvalidOperation() - { - EndPoint remote = new IPEndPoint(IPAddress.Loopback, 1); + //[Fact] + //public void BeginReceiveMessageFrom_NotBound_Throws_InvalidOperation() + //{ + // EndPoint remote = new IPEndPoint(IPAddress.Loopback, 1); - Assert.Throws(() => GetSocket().BeginReceiveMessageFrom(s_buffer, 0, 0, SocketFlags.None, ref remote, TheAsyncCallback, null)); - Assert.Throws(() => { GetSocket().ReceiveMessageFromAsync(new ArraySegment(s_buffer, 0, 0), SocketFlags.None, remote); }); - } + // Assert.Throws(() => GetSocket().BeginReceiveMessageFrom(s_buffer, 0, 0, SocketFlags.None, ref remote, TheAsyncCallback, null)); + // Assert.Throws(() => { GetSocket().ReceiveMessageFromAsync(new ArraySegment(s_buffer, 0, 0), SocketFlags.None, remote); }); + //} - [Fact] - public void EndReceiveMessageFrom_NullEndPoint_Throws_ArgumentNull() - { - SocketFlags flags = SocketFlags.None; - EndPoint remote = null; - IPPacketInformation packetInfo; + //[Fact] + //public void EndReceiveMessageFrom_NullEndPoint_Throws_ArgumentNull() + //{ + // SocketFlags flags = SocketFlags.None; + // EndPoint remote = null; + // IPPacketInformation packetInfo; - Assert.Throws(() => GetSocket().EndReceiveMessageFrom(null, ref flags, ref remote, out packetInfo)); - } + // Assert.Throws(() => GetSocket().EndReceiveMessageFrom(null, ref flags, ref remote, out packetInfo)); + //} - [Fact] - public void EndReceiveMessageFrom_AddressFamily_Throws_Argument() - { - SocketFlags flags = SocketFlags.None; - EndPoint remote = new IPEndPoint(IPAddress.IPv6Loopback, 1); - IPPacketInformation packetInfo; + //[Fact] + //public void EndReceiveMessageFrom_AddressFamily_Throws_Argument() + //{ + // SocketFlags flags = SocketFlags.None; + // EndPoint remote = new IPEndPoint(IPAddress.IPv6Loopback, 1); + // IPPacketInformation packetInfo; - AssertExtensions.Throws("endPoint", () => GetSocket(AddressFamily.InterNetwork).EndReceiveMessageFrom(null, ref flags, ref remote, out packetInfo)); - } + // AssertExtensions.Throws("endPoint", () => GetSocket(AddressFamily.InterNetwork).EndReceiveMessageFrom(null, ref flags, ref remote, out packetInfo)); + //} - [Fact] - public void EndReceiveMessageFrom_NullAsyncResult_Throws_ArgumentNull() - { - SocketFlags flags = SocketFlags.None; - EndPoint remote = new IPEndPoint(IPAddress.Loopback, 1); - IPPacketInformation packetInfo; + //[Fact] + //public void EndReceiveMessageFrom_NullAsyncResult_Throws_ArgumentNull() + //{ + // SocketFlags flags = SocketFlags.None; + // EndPoint remote = new IPEndPoint(IPAddress.Loopback, 1); + // IPPacketInformation packetInfo; - Assert.Throws(() => GetSocket().EndReceiveMessageFrom(null, ref flags, ref remote, out packetInfo)); - } + // Assert.Throws(() => GetSocket().EndReceiveMessageFrom(null, ref flags, ref remote, out packetInfo)); + //} [Fact] public void CancelConnectAsync_NullEventArgs_Throws_ArgumentNull() diff --git a/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveMessageFrom.cs b/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveMessageFrom.cs index e9be72af9041c..5fcc7291073a5 100644 --- a/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveMessageFrom.cs +++ b/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveMessageFrom.cs @@ -13,13 +13,74 @@ namespace System.Net.Sockets.Tests { public abstract class ReceiveMessageFrom : SocketTestHelperBase where T : SocketHelperBase, new() { + protected static Socket CreateSocket(AddressFamily addressFamily = AddressFamily.InterNetwork) => new Socket(addressFamily, SocketType.Dgram, ProtocolType.Udp); + protected static IPEndPoint GetGetDummyTestEndpoint(AddressFamily addressFamily = AddressFamily.InterNetwork) => addressFamily == AddressFamily.InterNetwork ? new IPEndPoint(IPAddress.Parse("1.2.3.4"), 1234) : new IPEndPoint(IPAddress.Parse("1:2:3::4"), 1234); protected static readonly TimeSpan CancellationTestTimeout = TimeSpan.FromSeconds(30); + protected virtual string RemoteEndPointArgumentName => "remoteEP"; + protected ReceiveMessageFrom(ITestOutputHelper output) : base(output) { } + [Theory] + [InlineData(1, -1, 0)] // offset low + [InlineData(1, 2, 0)] // offset high + [InlineData(1, 0, -1)] // count low + [InlineData(1, 0, 2)] // count high + [InlineData(1, 1, 1)] // count high + public async Task OutOfRange_Throws_ArgumentOutOfRangeException(int length, int offset, int count) + { + using Socket socket = CreateSocket(); + + ArraySegment buffer = new FakeArraySegment + { + Array = new byte[length], + Count = count, + Offset = offset + }.ToActual(); + + await Assert.ThrowsAnyAsync(() => ReceiveMessageFromAsync(socket, buffer, GetGetDummyTestEndpoint())); + } + + [Fact] + public async Task NullBuffer_Throws_ArgumentNullException() + { + if (!ValidatesArrayArguments) return; + using Socket socket = CreateSocket(); + await Assert.ThrowsAsync(() => ReceiveMessageFromAsync(socket, null, GetGetDummyTestEndpoint())); + } + + [Fact] + public async Task NullEndpoint_Throws_ArgumentException() + { + using Socket socket = CreateSocket(); + if (UsesEap) + { + await Assert.ThrowsAsync(RemoteEndPointArgumentName, () => ReceiveMessageFromAsync(socket, new byte[1], null)); + } + else + { + await Assert.ThrowsAsync(RemoteEndPointArgumentName, () => ReceiveMessageFromAsync(socket, new byte[1], null)); + } + } + + [Fact] + public void AddressFamilyDoesNotMatch_Throws_ArgumentException() + { + using var ipv4Socket = CreateSocket(); + EndPoint ipV6Endpoint = GetGetDummyTestEndpoint(AddressFamily.InterNetworkV6); + Assert.ThrowsAsync(RemoteEndPointArgumentName, () => ReceiveMessageFromAsync(ipv4Socket, new byte[1], ipV6Endpoint)); + } + + [Fact] + public void NotBound_Throws_InvalidOperationException() + { + using Socket socket = CreateSocket(); + Assert.ThrowsAsync(() => ReceiveMessageFromAsync(socket, new byte[1], GetGetDummyTestEndpoint())); + } + [PlatformSpecific(TestPlatforms.AnyUnix)] [Theory] [InlineData(false)] @@ -204,17 +265,84 @@ public ReceiveMessageFrom_SyncForceNonBlocking(ITestOutputHelper output) : base( public sealed class ReceiveMessageFrom_Apm : ReceiveMessageFrom { public ReceiveMessageFrom_Apm(ITestOutputHelper output) : base(output) { } + + protected override string RemoteEndPointArgumentName => "remoteEndPoint"; + + [Fact] + public void EndReceiveMessageFrom_NullAsyncResult_Throws_ArgumentNullException() + { + SocketFlags socketFlags = SocketFlags.None; + EndPoint endpoint = new IPEndPoint(IPAddress.Loopback, 1); + using Socket socket = CreateSocket(); + + Assert.Throws(() => socket.EndReceiveMessageFrom(null, ref socketFlags, ref endpoint, out _)); + } + + [Fact] + public void EndReceiveMessageFrom_NullEndPoint_Throws_ArgumentNullException() + { + SocketFlags socketFlags = SocketFlags.None; + EndPoint validEndPoint = new IPEndPoint(IPAddress.Loopback, 1); + EndPoint invalidEndPoint = null; + using Socket socket = CreateSocket(); + socket.BindToAnonymousPort(IPAddress.Loopback); + IAsyncResult iar = socket.BeginReceiveMessageFrom(new byte[1], 0, 1, SocketFlags.None, ref validEndPoint, null, null); + + Assert.Throws(RemoteEndPointArgumentName, () => socket.EndReceiveMessageFrom(iar, ref socketFlags, ref invalidEndPoint, out _)); + } + + [Fact] + public void EndReceiveMessageFrom_AddressFamilyDoesNotMatch_Throws_ArgumentException() + { + SocketFlags socketFlags = SocketFlags.None; + EndPoint validEndPoint = new IPEndPoint(IPAddress.Loopback, 1); + EndPoint invalidEndPoint = new IPEndPoint(IPAddress.IPv6Loopback, 1); + using Socket socket = CreateSocket(); + socket.BindToAnonymousPort(IPAddress.Loopback); + IAsyncResult iar = socket.BeginReceiveMessageFrom(new byte[1], 0, 1, SocketFlags.None, ref validEndPoint, null, null); + + Assert.Throws(RemoteEndPointArgumentName, () => socket.EndReceiveMessageFrom(iar, ref socketFlags, ref invalidEndPoint, out _)); + } + + [Fact] + public void BeginReceiveMessageFrom_RemoteEpIsReturnedWhenCompletedSynchronously() + { + EndPoint anyEp = new IPEndPoint(IPAddress.Any, 0); + EndPoint remoteEp = anyEp; + using Socket receiver = CreateSocket(); + receiver.BindToAnonymousPort(IPAddress.Loopback); + using Socket sender = CreateSocket(); + sender.BindToAnonymousPort(IPAddress.Loopback); + + sender.SendTo(new byte[1], receiver.LocalEndPoint); + + IAsyncResult iar = receiver.BeginReceiveMessageFrom(new byte[1], 0, 1, SocketFlags.None, ref remoteEp, null, null); + if (iar.CompletedSynchronously) + { + _output.WriteLine("Completed synchronously, updated endpoint."); + Assert.Equal(sender.LocalEndPoint, remoteEp); + } + else + { + _output.WriteLine("Completed asynchronously, did not update endPoint"); + Assert.Equal(anyEp, remoteEp); + } + } } public sealed class ReceiveMessageFrom_Task : ReceiveMessageFrom { public ReceiveMessageFrom_Task(ITestOutputHelper output) : base(output) { } + + protected override string RemoteEndPointArgumentName => "remoteEndPoint"; } public sealed class ReceiveMessageFrom_CancellableTask : ReceiveMessageFrom { public ReceiveMessageFrom_CancellableTask(ITestOutputHelper output) : base(output) { } + protected override string RemoteEndPointArgumentName => "remoteEndPoint"; + [Theory] [MemberData(nameof(LoopbacksAndBuffers))] public async Task WhenCanceled_Throws(IPAddress loopback, bool precanceled) @@ -240,6 +368,15 @@ public sealed class ReceiveMessageFrom_Eap : ReceiveMessageFrom { public ReceiveMessageFrom_Eap(ITestOutputHelper output) : base(output) { } + protected override string RemoteEndPointArgumentName => "e"; + + [Fact] + public void ReceiveFromAsync_NullAsyncEventArgs_Throws_ArgumentNull() + { + using Socket socket = CreateSocket(); + Assert.Throws(() => socket.ReceiveFromAsync(null)); + } + [Theory] [InlineData(false, 0)] [InlineData(false, 1)] @@ -334,10 +471,14 @@ public ReceiveMessageFrom_SpanSyncForceNonBlocking(ITestOutputHelper output) : b public sealed class ReceiveMessageFrom_MemoryArrayTask : ReceiveMessageFrom { public ReceiveMessageFrom_MemoryArrayTask(ITestOutputHelper output) : base(output) { } + + protected override string RemoteEndPointArgumentName => "remoteEndPoint"; } public sealed class ReceiveMessageFrom_MemoryNativeTask : ReceiveMessageFrom { public ReceiveMessageFrom_MemoryNativeTask(ITestOutputHelper output) : base(output) { } + + protected override string RemoteEndPointArgumentName => "remoteEndPoint"; } } From d6fdd9b55b58de760e7a62836f047ae18945a520 Mon Sep 17 00:00:00 2001 From: Anton Firszov Date: Mon, 1 Feb 2021 18:58:07 +0100 Subject: [PATCH 09/23] consolidate ArgumentException-s --- .../src/System/Net/Sockets/Socket.Tasks.cs | 26 +--------- .../src/System/Net/Sockets/Socket.cs | 47 +++++++++---------- .../tests/FunctionalTests/ReceiveFrom.cs | 14 +++--- .../FunctionalTests/ReceiveMessageFrom.cs | 14 +++--- 4 files changed, 38 insertions(+), 63 deletions(-) diff --git a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/Socket.Tasks.cs b/src/libraries/System.Net.Sockets/src/System/Net/Sockets/Socket.Tasks.cs index f5432d56e0009..461122cfd09a6 100644 --- a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/Socket.Tasks.cs +++ b/src/libraries/System.Net.Sockets/src/System/Net/Sockets/Socket.Tasks.cs @@ -350,18 +350,7 @@ public Task ReceiveFromAsync(ArraySegment buffer, /// An asynchronous task that completes with a containing the number of bytes received and the endpoint of the sending host. public ValueTask ReceiveFromAsync(Memory buffer, SocketFlags socketFlags, EndPoint remoteEndPoint, CancellationToken cancellationToken = default) { - if (remoteEndPoint is null) - { - throw new ArgumentNullException(nameof(remoteEndPoint)); - } - if (!CanTryAddressFamily(remoteEndPoint.AddressFamily)) - { - throw new ArgumentException(SR.Format(SR.net_InvalidEndPointAddressFamily, remoteEndPoint.AddressFamily, _addressFamily), nameof(remoteEndPoint)); - } - if (_rightEndPoint == null) - { - throw new InvalidOperationException(SR.net_sockets_mustbind); - } + ValidateReceiveFromEndpointAndState(remoteEndPoint, nameof(remoteEndPoint)); if (cancellationToken.IsCancellationRequested) { @@ -403,18 +392,7 @@ public Task ReceiveMessageFromAsync(ArraySegment /// An asynchronous task that completes with a containing the number of bytes received and additional information about the sending host. public ValueTask ReceiveMessageFromAsync(Memory buffer, SocketFlags socketFlags, EndPoint remoteEndPoint, CancellationToken cancellationToken = default) { - if (remoteEndPoint is null) - { - throw new ArgumentNullException(nameof(remoteEndPoint)); - } - if (!CanTryAddressFamily(remoteEndPoint.AddressFamily)) - { - throw new ArgumentException(SR.Format(SR.net_InvalidEndPointAddressFamily, remoteEndPoint.AddressFamily, _addressFamily), nameof(remoteEndPoint)); - } - if (_rightEndPoint == null) - { - throw new InvalidOperationException(SR.net_sockets_mustbind); - } + ValidateReceiveFromEndpointAndState(remoteEndPoint, nameof(remoteEndPoint)); if (cancellationToken.IsCancellationRequested) { return ValueTask.FromCanceled(cancellationToken); diff --git a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/Socket.cs b/src/libraries/System.Net.Sockets/src/System/Net/Sockets/Socket.cs index 2568475360478..625253d772a7a 100644 --- a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/Socket.cs +++ b/src/libraries/System.Net.Sockets/src/System/Net/Sockets/Socket.cs @@ -1540,18 +1540,7 @@ public int ReceiveMessageFrom(byte[] buffer, int offset, int size, ref SocketFla { ThrowIfDisposed(); ValidateBufferArguments(buffer, offset, size); - if (remoteEP == null) - { - throw new ArgumentNullException(nameof(remoteEP)); - } - if (!CanTryAddressFamily(remoteEP.AddressFamily)) - { - throw new ArgumentException(SR.Format(SR.net_InvalidEndPointAddressFamily, remoteEP.AddressFamily, _addressFamily), nameof(remoteEP)); - } - if (_rightEndPoint == null) - { - throw new InvalidOperationException(SR.net_sockets_mustbind); - } + ValidateReceiveFromEndpointAndState(remoteEP, nameof(remoteEP)); SocketPal.CheckDualModeReceiveSupport(this); ValidateBlockingMode(); @@ -1609,19 +1598,7 @@ public int ReceiveFrom(byte[] buffer, int offset, int size, SocketFlags socketFl { ThrowIfDisposed(); ValidateBufferArguments(buffer, offset, size); - if (remoteEP == null) - { - throw new ArgumentNullException(nameof(remoteEP)); - } - if (!CanTryAddressFamily(remoteEP.AddressFamily)) - { - throw new ArgumentException(SR.Format(SR.net_InvalidEndPointAddressFamily, - remoteEP.AddressFamily, _addressFamily), nameof(remoteEP)); - } - if (_rightEndPoint == null) - { - throw new InvalidOperationException(SR.net_sockets_mustbind); - } + ValidateReceiveFromEndpointAndState(remoteEP, nameof(remoteEP)); SocketPal.CheckDualModeReceiveSupport(this); @@ -2333,6 +2310,7 @@ public IAsyncResult BeginReceiveMessageFrom(byte[] buffer, int offset, int size, ThrowIfDisposed(); ValidateBufferArguments(buffer, offset, size); + ValidateReceiveFromEndpointAndState(remoteEP, nameof(remoteEP)); Task t = ReceiveMessageFromAsync(new Memory(buffer, offset, size), socketFlags, remoteEP).AsTask(); if (t.IsCompletedSuccessfully) @@ -2371,6 +2349,7 @@ public IAsyncResult BeginReceiveFrom(byte[] buffer, int offset, int size, Socket { ThrowIfDisposed(); ValidateBufferArguments(buffer, offset, size); + ValidateReceiveFromEndpointAndState(remoteEP, nameof(remoteEP)); Task t = ReceiveFromAsync(new Memory(buffer, offset, size), socketFlags, remoteEP).AsTask(); if (t.IsCompletedSuccessfully) @@ -3689,6 +3668,24 @@ private bool CheckErrorAndUpdateStatus(SocketError errorCode) return false; } + // Called in Receive(Message)From variants to validate 'remoteEndPoint', + // and check whether the socket is bound. + private void ValidateReceiveFromEndpointAndState(EndPoint remoteEndPoint, string remoteEndPointArgumentName) + { + if (remoteEndPoint == null) + { + throw new ArgumentNullException(remoteEndPointArgumentName); + } + if (!CanTryAddressFamily(remoteEndPoint.AddressFamily)) + { + throw new ArgumentException(SR.Format(SR.net_InvalidEndPointAddressFamily, remoteEndPoint.AddressFamily, _addressFamily), remoteEndPointArgumentName); + } + if (_rightEndPoint == null) + { + throw new InvalidOperationException(SR.net_sockets_mustbind); + } + } + // ValidateBlockingMode - called before synchronous calls to validate // the fact that we are in blocking mode (not in non-blocking mode) so the // call will actually be synchronous. diff --git a/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveFrom.cs b/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveFrom.cs index bb58a15f6a278..16723640e2885 100644 --- a/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveFrom.cs +++ b/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveFrom.cs @@ -67,18 +67,18 @@ public async Task NullEndpoint_Throws_ArgumentException() } [Fact] - public void AddressFamilyDoesNotMatch_Throws_ArgumentException() + public async Task AddressFamilyDoesNotMatch_Throws_ArgumentException() { using var ipv4Socket = CreateSocket(); EndPoint ipV6Endpoint = GetGetDummyTestEndpoint(AddressFamily.InterNetworkV6); - Assert.ThrowsAsync(RemoteEndPointArgumentName, () => ReceiveFromAsync(ipv4Socket, new byte[1], ipV6Endpoint)); + await Assert.ThrowsAsync(RemoteEndPointArgumentName, () => ReceiveFromAsync(ipv4Socket, new byte[1], ipV6Endpoint)); } [Fact] - public void NotBound_Throws_InvalidOperationException() + public async Task NotBound_Throws_InvalidOperationException() { using Socket socket = CreateSocket(); - Assert.ThrowsAsync(() => ReceiveFromAsync(socket, new byte[1], GetGetDummyTestEndpoint())); + await Assert.ThrowsAsync(() => ReceiveFromAsync(socket, new byte[1], GetGetDummyTestEndpoint())); } [Theory] @@ -225,7 +225,7 @@ public sealed class ReceiveFrom_Apm : ReceiveFrom { public ReceiveFrom_Apm(ITestOutputHelper output) : base(output) { } - protected override string RemoteEndPointArgumentName => "remoteEndPoint"; + protected override string RemoteEndPointArgumentName => "remoteEP"; [Fact] public void EndReceiveFrom_NullAsyncResult_Throws_ArgumentNullException() @@ -243,7 +243,7 @@ public void EndReceiveFrom_NullEndPoint_Throws_ArgumentNullException() using Socket socket = CreateSocket(); socket.BindToAnonymousPort(IPAddress.Loopback); IAsyncResult iar = socket.BeginReceiveFrom(new byte[1], 0, 1, SocketFlags.None, ref validEndPoint, null, null); - Assert.Throws(RemoteEndPointArgumentName, () => socket.EndReceiveFrom(iar, ref invalidEndPoint)); + Assert.Throws("endPoint", () => socket.EndReceiveFrom(iar, ref invalidEndPoint)); } [Fact] @@ -254,7 +254,7 @@ public void EndReceiveFrom_AddressFamilyDoesNotMatch_Throws_ArgumentException() using Socket socket = CreateSocket(); socket.BindToAnonymousPort(IPAddress.Loopback); IAsyncResult iar = socket.BeginReceiveFrom(new byte[1], 0, 1, SocketFlags.None, ref validEndPoint, null, null); - Assert.Throws(RemoteEndPointArgumentName, () => socket.EndReceiveFrom(iar, ref invalidEndPoint)); + Assert.Throws("endPoint", () => socket.EndReceiveFrom(iar, ref invalidEndPoint)); } [Fact] diff --git a/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveMessageFrom.cs b/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveMessageFrom.cs index 5fcc7291073a5..b96360d14d31f 100644 --- a/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveMessageFrom.cs +++ b/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveMessageFrom.cs @@ -67,18 +67,18 @@ public async Task NullEndpoint_Throws_ArgumentException() } [Fact] - public void AddressFamilyDoesNotMatch_Throws_ArgumentException() + public async Task AddressFamilyDoesNotMatch_Throws_ArgumentException() { using var ipv4Socket = CreateSocket(); EndPoint ipV6Endpoint = GetGetDummyTestEndpoint(AddressFamily.InterNetworkV6); - Assert.ThrowsAsync(RemoteEndPointArgumentName, () => ReceiveMessageFromAsync(ipv4Socket, new byte[1], ipV6Endpoint)); + await Assert.ThrowsAsync(RemoteEndPointArgumentName, () => ReceiveMessageFromAsync(ipv4Socket, new byte[1], ipV6Endpoint)); } [Fact] - public void NotBound_Throws_InvalidOperationException() + public async Task NotBound_Throws_InvalidOperationException() { using Socket socket = CreateSocket(); - Assert.ThrowsAsync(() => ReceiveMessageFromAsync(socket, new byte[1], GetGetDummyTestEndpoint())); + await Assert.ThrowsAsync(() => ReceiveMessageFromAsync(socket, new byte[1], GetGetDummyTestEndpoint())); } [PlatformSpecific(TestPlatforms.AnyUnix)] @@ -266,7 +266,7 @@ public sealed class ReceiveMessageFrom_Apm : ReceiveMessageFrom { public ReceiveMessageFrom_Apm(ITestOutputHelper output) : base(output) { } - protected override string RemoteEndPointArgumentName => "remoteEndPoint"; + protected override string RemoteEndPointArgumentName => "remoteEP"; [Fact] public void EndReceiveMessageFrom_NullAsyncResult_Throws_ArgumentNullException() @@ -288,7 +288,7 @@ public void EndReceiveMessageFrom_NullEndPoint_Throws_ArgumentNullException() socket.BindToAnonymousPort(IPAddress.Loopback); IAsyncResult iar = socket.BeginReceiveMessageFrom(new byte[1], 0, 1, SocketFlags.None, ref validEndPoint, null, null); - Assert.Throws(RemoteEndPointArgumentName, () => socket.EndReceiveMessageFrom(iar, ref socketFlags, ref invalidEndPoint, out _)); + Assert.Throws("endPoint", () => socket.EndReceiveMessageFrom(iar, ref socketFlags, ref invalidEndPoint, out _)); } [Fact] @@ -301,7 +301,7 @@ public void EndReceiveMessageFrom_AddressFamilyDoesNotMatch_Throws_ArgumentExcep socket.BindToAnonymousPort(IPAddress.Loopback); IAsyncResult iar = socket.BeginReceiveMessageFrom(new byte[1], 0, 1, SocketFlags.None, ref validEndPoint, null, null); - Assert.Throws(RemoteEndPointArgumentName, () => socket.EndReceiveMessageFrom(iar, ref socketFlags, ref invalidEndPoint, out _)); + Assert.Throws("endPoint", () => socket.EndReceiveMessageFrom(iar, ref socketFlags, ref invalidEndPoint, out _)); } [Fact] From 5a5fbbabc43cbbfcf112892c2207c2eb40f4602b Mon Sep 17 00:00:00 2001 From: Anton Firszov Date: Mon, 1 Feb 2021 19:02:20 +0100 Subject: [PATCH 10/23] Workaround for #47714 --- .../tests/FunctionalTests/ReceiveFrom.cs | 13 ++++++++++++- .../tests/FunctionalTests/ReceiveMessageFrom.cs | 4 ++++ 2 files changed, 16 insertions(+), 1 deletion(-) diff --git a/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveFrom.cs b/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveFrom.cs index 16723640e2885..d64f67a9f9831 100644 --- a/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveFrom.cs +++ b/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveFrom.cs @@ -78,7 +78,18 @@ public async Task AddressFamilyDoesNotMatch_Throws_ArgumentException() public async Task NotBound_Throws_InvalidOperationException() { using Socket socket = CreateSocket(); - await Assert.ThrowsAsync(() => ReceiveFromAsync(socket, new byte[1], GetGetDummyTestEndpoint())); + + // ReceiveFromAsync(saea) throws SocketException: + // [ActiveIssue("https://github.com/dotnet/runtime/issues/47714")] + if (UsesEap) + { + await Assert.ThrowsAsync(() => ReceiveFromAsync(socket, new byte[1], GetGetDummyTestEndpoint())); + } + else + { + await Assert.ThrowsAsync(() => ReceiveFromAsync(socket, new byte[1], GetGetDummyTestEndpoint())); + } + } [Theory] diff --git a/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveMessageFrom.cs b/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveMessageFrom.cs index b96360d14d31f..a1b07e5f1f555 100644 --- a/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveMessageFrom.cs +++ b/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveMessageFrom.cs @@ -77,6 +77,10 @@ public async Task AddressFamilyDoesNotMatch_Throws_ArgumentException() [Fact] public async Task NotBound_Throws_InvalidOperationException() { + // ReceiveFromAsync(saea) throws SocketException / fails with Debug.Assert(): + // [ActiveIssue("https://github.com/dotnet/runtime/issues/47714")] + if (UsesEap) return; + using Socket socket = CreateSocket(); await Assert.ThrowsAsync(() => ReceiveMessageFromAsync(socket, new byte[1], GetGetDummyTestEndpoint())); } From 0743b73d7a0da3cddb7541565c0317cf0ed638c0 Mon Sep 17 00:00:00 2001 From: Anton Firszov Date: Tue, 2 Feb 2021 17:59:31 +0100 Subject: [PATCH 11/23] WIP: Harmonize SendTo validation tests --- .../ArgumentValidationTests.cs | 154 +++++++++--------- .../tests/FunctionalTests/ReceiveFrom.cs | 12 +- .../FunctionalTests/ReceiveMessageFrom.cs | 14 +- .../tests/FunctionalTests/SendTo.cs | 66 ++++++-- 4 files changed, 150 insertions(+), 96 deletions(-) diff --git a/src/libraries/System.Net.Sockets/tests/FunctionalTests/ArgumentValidationTests.cs b/src/libraries/System.Net.Sockets/tests/FunctionalTests/ArgumentValidationTests.cs index 7b1812e2110f8..8a3f07e54ca8d 100644 --- a/src/libraries/System.Net.Sockets/tests/FunctionalTests/ArgumentValidationTests.cs +++ b/src/libraries/System.Net.Sockets/tests/FunctionalTests/ArgumentValidationTests.cs @@ -263,34 +263,34 @@ public void Send_Buffers_EmptyBuffers_Throws_Argument() AssertExtensions.Throws("buffers", () => GetSocket().Send(new List>(), SocketFlags.None, out errorCode)); } - [Fact] - public void SendTo_NullBuffer_Throws_ArgumentNull() - { - Assert.Throws(() => GetSocket().SendTo(null, 0, 0, SocketFlags.None, new IPEndPoint(IPAddress.Loopback, 1))); - } + //[Fact] + //public void SendTo_NullBuffer_Throws_ArgumentNull() + //{ + // Assert.Throws(() => GetSocket().SendTo(null, 0, 0, SocketFlags.None, new IPEndPoint(IPAddress.Loopback, 1))); + //} - [Fact] - public void SendTo_NullEndPoint_Throws_ArgumentNull() - { - Assert.Throws(() => GetSocket().SendTo(s_buffer, 0, 0, SocketFlags.None, null)); - } + //[Fact] + //public void SendTo_NullEndPoint_Throws_ArgumentNull() + //{ + // Assert.Throws(() => GetSocket().SendTo(s_buffer, 0, 0, SocketFlags.None, null)); + //} - [Fact] - public void SendTo_InvalidOffset_Throws_ArgumentOutOfRange() - { - EndPoint endpoint = new IPEndPoint(IPAddress.Loopback, 1); - Assert.Throws(() => GetSocket().SendTo(s_buffer, -1, s_buffer.Length, SocketFlags.None, endpoint)); - Assert.Throws(() => GetSocket().SendTo(s_buffer, s_buffer.Length + 1, s_buffer.Length, SocketFlags.None, endpoint)); - } + //[Fact] + //public void SendTo_InvalidOffset_Throws_ArgumentOutOfRange() + //{ + // EndPoint endpoint = new IPEndPoint(IPAddress.Loopback, 1); + // Assert.Throws(() => GetSocket().SendTo(s_buffer, -1, s_buffer.Length, SocketFlags.None, endpoint)); + // Assert.Throws(() => GetSocket().SendTo(s_buffer, s_buffer.Length + 1, s_buffer.Length, SocketFlags.None, endpoint)); + //} - [Fact] - public void SendTo_InvalidSize_Throws_ArgumentOutOfRange() - { - EndPoint endpoint = new IPEndPoint(IPAddress.Loopback, 1); - Assert.Throws(() => GetSocket().SendTo(s_buffer, 0, -1, SocketFlags.None, endpoint)); - Assert.Throws(() => GetSocket().SendTo(s_buffer, 0, s_buffer.Length + 1, SocketFlags.None, endpoint)); - Assert.Throws(() => GetSocket().SendTo(s_buffer, s_buffer.Length, 1, SocketFlags.None, endpoint)); - } + //[Fact] + //public void SendTo_InvalidSize_Throws_ArgumentOutOfRange() + //{ + // EndPoint endpoint = new IPEndPoint(IPAddress.Loopback, 1); + // Assert.Throws(() => GetSocket().SendTo(s_buffer, 0, -1, SocketFlags.None, endpoint)); + // Assert.Throws(() => GetSocket().SendTo(s_buffer, 0, s_buffer.Length + 1, SocketFlags.None, endpoint)); + // Assert.Throws(() => GetSocket().SendTo(s_buffer, s_buffer.Length, 1, SocketFlags.None, endpoint)); + //} [Fact] public void Receive_Buffer_NullBuffer_Throws_ArgumentNull() @@ -684,17 +684,17 @@ public void SendPacketsAsync_NotConnected_Throws_NotSupported() Assert.Throws(() => GetSocket().SendPacketsAsync(eventArgs)); } - [Fact] - public void SendToAsync_NullAsyncEventArgs_Throws_ArgumentNull() - { - Assert.Throws(() => GetSocket().SendToAsync(null)); - } + //[Fact] + //public void SendToAsync_NullAsyncEventArgs_Throws_ArgumentNull() + //{ + // Assert.Throws(() => GetSocket().SendToAsync(null)); + //} - [Fact] - public void SendToAsync_NullRemoteEndPoint_Throws_ArgumentNull() - { - Assert.Throws(() => GetSocket().SendToAsync(s_eventArgs)); - } + //[Fact] + //public void SendToAsync_NullRemoteEndPoint_Throws_ArgumentNull() + //{ + // Assert.Throws(() => GetSocket().SendToAsync(s_eventArgs)); + //} [Theory] [InlineData(true)] @@ -1212,57 +1212,57 @@ public void EndSend_UnrelatedAsyncResult_Throws_Argument() AssertExtensions.Throws("asyncResult", () => GetSocket().EndSend(Task.CompletedTask)); } - [Fact] - public void BeginSendTo_NullBuffer_Throws_ArgumentNull() - { - Assert.Throws(() => GetSocket().BeginSendTo(null, 0, 0, SocketFlags.None, new IPEndPoint(IPAddress.Loopback, 1), TheAsyncCallback, null)); - Assert.Throws(() => { GetSocket().SendToAsync(new ArraySegment(null, 0, 0), SocketFlags.None, new IPEndPoint(IPAddress.Loopback, 1)); }); - } + //[Fact] + //public void BeginSendTo_NullBuffer_Throws_ArgumentNull() + //{ + // Assert.Throws(() => GetSocket().BeginSendTo(null, 0, 0, SocketFlags.None, new IPEndPoint(IPAddress.Loopback, 1), TheAsyncCallback, null)); + // Assert.Throws(() => { GetSocket().SendToAsync(new ArraySegment(null, 0, 0), SocketFlags.None, new IPEndPoint(IPAddress.Loopback, 1)); }); + //} - [Fact] - public void BeginSendTo_NullEndPoint_Throws_ArgumentNull() - { - Assert.Throws(() => GetSocket().BeginSendTo(s_buffer, 0, 0, SocketFlags.None, null, TheAsyncCallback, null)); - Assert.Throws(() => { GetSocket().SendToAsync(new ArraySegment(s_buffer, 0, 0), SocketFlags.None, null); }); - } + //[Fact] + //public void BeginSendTo_NullEndPoint_Throws_ArgumentNull() + //{ + // Assert.Throws(() => GetSocket().BeginSendTo(s_buffer, 0, 0, SocketFlags.None, null, TheAsyncCallback, null)); + // Assert.Throws(() => { GetSocket().SendToAsync(new ArraySegment(s_buffer, 0, 0), SocketFlags.None, null); }); + //} - [Fact] - public void BeginSendTo_InvalidOffset_Throws_ArgumentOutOfRange() - { - EndPoint endpoint = new IPEndPoint(IPAddress.Loopback, 1); + //[Fact] + //public void BeginSendTo_InvalidOffset_Throws_ArgumentOutOfRange() + //{ + // EndPoint endpoint = new IPEndPoint(IPAddress.Loopback, 1); - Assert.Throws(() => GetSocket().BeginSendTo(s_buffer, -1, s_buffer.Length, SocketFlags.None, endpoint, TheAsyncCallback, null)); - Assert.Throws(() => GetSocket().BeginSendTo(s_buffer, s_buffer.Length + 1, s_buffer.Length, SocketFlags.None, endpoint, TheAsyncCallback, null)); + // Assert.Throws(() => GetSocket().BeginSendTo(s_buffer, -1, s_buffer.Length, SocketFlags.None, endpoint, TheAsyncCallback, null)); + // Assert.Throws(() => GetSocket().BeginSendTo(s_buffer, s_buffer.Length + 1, s_buffer.Length, SocketFlags.None, endpoint, TheAsyncCallback, null)); - Assert.Throws(() => { GetSocket().SendToAsync(new ArraySegment(s_buffer, -1, s_buffer.Length), SocketFlags.None, endpoint); }); - Assert.ThrowsAny(() => { GetSocket().SendToAsync(new ArraySegment(s_buffer, s_buffer.Length + 1, s_buffer.Length), SocketFlags.None, endpoint); }); - } + // Assert.Throws(() => { GetSocket().SendToAsync(new ArraySegment(s_buffer, -1, s_buffer.Length), SocketFlags.None, endpoint); }); + // Assert.ThrowsAny(() => { GetSocket().SendToAsync(new ArraySegment(s_buffer, s_buffer.Length + 1, s_buffer.Length), SocketFlags.None, endpoint); }); + //} - [Fact] - public void BeginSendTo_InvalidSize_Throws_ArgumentOutOfRange() - { - EndPoint endpoint = new IPEndPoint(IPAddress.Loopback, 1); + //[Fact] + //public void BeginSendTo_InvalidSize_Throws_ArgumentOutOfRange() + //{ + // EndPoint endpoint = new IPEndPoint(IPAddress.Loopback, 1); - Assert.Throws(() => GetSocket().BeginSendTo(s_buffer, 0, -1, SocketFlags.None, endpoint, TheAsyncCallback, null)); - Assert.Throws(() => GetSocket().BeginSendTo(s_buffer, 0, s_buffer.Length + 1, SocketFlags.None, endpoint, TheAsyncCallback, null)); - Assert.Throws(() => GetSocket().BeginSendTo(s_buffer, s_buffer.Length, 1, SocketFlags.None, endpoint, TheAsyncCallback, null)); + // Assert.Throws(() => GetSocket().BeginSendTo(s_buffer, 0, -1, SocketFlags.None, endpoint, TheAsyncCallback, null)); + // Assert.Throws(() => GetSocket().BeginSendTo(s_buffer, 0, s_buffer.Length + 1, SocketFlags.None, endpoint, TheAsyncCallback, null)); + // Assert.Throws(() => GetSocket().BeginSendTo(s_buffer, s_buffer.Length, 1, SocketFlags.None, endpoint, TheAsyncCallback, null)); - Assert.Throws(() => { GetSocket().SendToAsync(new ArraySegment(s_buffer, 0, -1), SocketFlags.None, endpoint); }); - Assert.ThrowsAny(() => { GetSocket().SendToAsync(new ArraySegment(s_buffer, 0, s_buffer.Length + 1), SocketFlags.None, endpoint); }); - Assert.ThrowsAny(() => { GetSocket().SendToAsync(new ArraySegment(s_buffer, s_buffer.Length, 1), SocketFlags.None, endpoint); }); - } + // Assert.Throws(() => { GetSocket().SendToAsync(new ArraySegment(s_buffer, 0, -1), SocketFlags.None, endpoint); }); + // Assert.ThrowsAny(() => { GetSocket().SendToAsync(new ArraySegment(s_buffer, 0, s_buffer.Length + 1), SocketFlags.None, endpoint); }); + // Assert.ThrowsAny(() => { GetSocket().SendToAsync(new ArraySegment(s_buffer, s_buffer.Length, 1), SocketFlags.None, endpoint); }); + //} - [Fact] - public void EndSendTo_NullAsyncResult_Throws_ArgumentNull() - { - Assert.Throws(() => GetSocket().EndSendTo(null)); - } + //[Fact] + //public void EndSendTo_NullAsyncResult_Throws_ArgumentNull() + //{ + // Assert.Throws(() => GetSocket().EndSendTo(null)); + //} - [Fact] - public void EndSendto_UnrelatedAsyncResult_Throws_Argument() - { - AssertExtensions.Throws("asyncResult", () => GetSocket().EndSendTo(Task.CompletedTask)); - } + //[Fact] + //public void EndSendto_UnrelatedAsyncResult_Throws_Argument() + //{ + // AssertExtensions.Throws("asyncResult", () => GetSocket().EndSendTo(Task.CompletedTask)); + //} [Fact] public void BeginReceive_Buffer_NullBuffer_Throws_ArgumentNull() diff --git a/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveFrom.cs b/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveFrom.cs index 61dcb772b440b..f4f6fb34b0d39 100644 --- a/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveFrom.cs +++ b/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveFrom.cs @@ -89,7 +89,6 @@ public async Task NotBound_Throws_InvalidOperationException() { await Assert.ThrowsAsync(() => ReceiveFromAsync(socket, new byte[1], GetGetDummyTestEndpoint())); } - } [Theory] @@ -288,6 +287,15 @@ public void EndReceiveFrom_NullAsyncResult_Throws_ArgumentNullException() Assert.Throws(() => socket.EndReceiveFrom(null, ref endpoint)); } + [Fact] + public void EndReceiveFrom_UnrelatedAsyncResult_Throws_ArgumentException() + { + EndPoint endpoint = new IPEndPoint(IPAddress.Loopback, 1); + using Socket socket = CreateSocket(); + + Assert.Throws(() => socket.EndReceiveFrom(Task.CompletedTask, ref endpoint)); + } + [Fact] public void EndReceiveFrom_NullEndPoint_Throws_ArgumentNullException() { @@ -377,7 +385,7 @@ public ReceiveFrom_Eap(ITestOutputHelper output) : base(output) { } protected override string RemoteEndPointArgumentName => "e"; [Fact] - public void ReceiveFromAsync_NullAsyncEventArgs_Throws_ArgumentNull() + public void ReceiveFromAsync_NullAsyncEventArgs_Throws_ArgumentNullException() { using Socket socket = CreateSocket(); Assert.Throws(() => socket.ReceiveFromAsync(null)); diff --git a/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveMessageFrom.cs b/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveMessageFrom.cs index 38896a1610ec7..2730432093d9e 100644 --- a/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveMessageFrom.cs +++ b/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveMessageFrom.cs @@ -287,6 +287,16 @@ public void EndReceiveMessageFrom_NullAsyncResult_Throws_ArgumentNullException() Assert.Throws(() => socket.EndReceiveMessageFrom(null, ref socketFlags, ref endpoint, out _)); } + [Fact] + public void EndReceiveMessageFrom_UnrelatedAsyncResult_Throws_ArgumentException() + { + SocketFlags socketFlags = SocketFlags.None; + EndPoint endpoint = new IPEndPoint(IPAddress.Loopback, 1); + using Socket socket = CreateSocket(); + + Assert.Throws(() => socket.EndReceiveMessageFrom(Task.CompletedTask, ref socketFlags, ref endpoint, out _)); + } + [Fact] public void EndReceiveMessageFrom_NullEndPoint_Throws_ArgumentNullException() { @@ -380,10 +390,10 @@ public ReceiveMessageFrom_Eap(ITestOutputHelper output) : base(output) { } protected override string RemoteEndPointArgumentName => "e"; [Fact] - public void ReceiveFromAsync_NullAsyncEventArgs_Throws_ArgumentNull() + public void ReceiveFromAsync_NullAsyncEventArgs_Throws_ArgumentNullException() { using Socket socket = CreateSocket(); - Assert.Throws(() => socket.ReceiveFromAsync(null)); + Assert.Throws(() => socket.ReceiveMessageFromAsync(null)); } [Theory] diff --git a/src/libraries/System.Net.Sockets/tests/FunctionalTests/SendTo.cs b/src/libraries/System.Net.Sockets/tests/FunctionalTests/SendTo.cs index 1159d40f2e4a3..39a34403ab791 100644 --- a/src/libraries/System.Net.Sockets/tests/FunctionalTests/SendTo.cs +++ b/src/libraries/System.Net.Sockets/tests/FunctionalTests/SendTo.cs @@ -13,7 +13,12 @@ namespace System.Net.Sockets.Tests { public abstract class SendTo : SocketTestHelperBase where T : SocketHelperBase, new() { - protected static readonly IPEndPoint ValidUdpRemoteEndpoint = new IPEndPoint(IPAddress.Parse("10.20.30.40"), 1234); + protected static Socket CreateSocket(AddressFamily addressFamily = AddressFamily.InterNetwork) => new Socket(addressFamily, SocketType.Dgram, ProtocolType.Udp); + + protected static IPEndPoint GetGetDummyTestEndpoint(AddressFamily addressFamily = AddressFamily.InterNetwork) => + addressFamily == AddressFamily.InterNetwork ? new IPEndPoint(IPAddress.Parse("1.2.3.4"), 1234) : new IPEndPoint(IPAddress.Parse("1:2:3::4"), 1234); + + protected const string RemoteEndPointArgumentName = "remoteEP"; protected SendTo(ITestOutputHelper output) : base(output) { @@ -23,34 +28,41 @@ protected SendTo(ITestOutputHelper output) : base(output) [InlineData(1, -1, 0)] // offset low [InlineData(1, 2, 0)] // offset high [InlineData(1, 0, -1)] // count low - [InlineData(1, 1, 2)] // count high - public async Task OutOfRange_Throws(int length, int offset, int count) + [InlineData(1, 0, 2)] // count high + [InlineData(1, 1, 1)] // count high + public async Task OutOfRange_Throws_ArgumentOutOfRangeException(int length, int offset, int count) { - using var socket = new Socket(AddressFamily.InterNetwork, SocketType.Dgram, ProtocolType.Udp); + using var socket = CreateSocket(); ArraySegment buffer = new FakeArraySegment { Array = new byte[length], Count = count, Offset = offset }.ToActual(); - await Assert.ThrowsAnyAsync(() => SendToAsync(socket, buffer, ValidUdpRemoteEndpoint)); + await Assert.ThrowsAnyAsync(() => SendToAsync(socket, buffer, GetGetDummyTestEndpoint())); } [Fact] - public async Task NullBuffer_Throws() + public async Task NullBuffer_Throws_ArgumentNullException() { if (!ValidatesArrayArguments) return; - using var socket = new Socket(AddressFamily.InterNetwork, SocketType.Dgram, ProtocolType.Udp); + using var socket = CreateSocket(); - await Assert.ThrowsAsync(() => SendToAsync(socket, null, ValidUdpRemoteEndpoint)); + await Assert.ThrowsAsync(() => SendToAsync(socket, null, GetGetDummyTestEndpoint())); } [Fact] - public async Task NullEndpoint_Throws() + public async Task NullEndpoint_Throws_ArgumentException() { - using var socket = new Socket(AddressFamily.InterNetwork, SocketType.Dgram, ProtocolType.Udp); - - await Assert.ThrowsAnyAsync(() => SendToAsync(socket, new byte[1], null)); + using Socket socket = CreateSocket(); + if (UsesEap) + { + await Assert.ThrowsAsync(() => SendToAsync(socket, new byte[1], null)); + } + else + { + await Assert.ThrowsAsync(RemoteEndPointArgumentName, () => SendToAsync(socket, new byte[1], null)); + } } [Fact] @@ -59,7 +71,7 @@ public async Task Datagram_UDP_ShouldImplicitlyBindLocalEndpoint() using var socket = new Socket(AddressFamily.InterNetwork, SocketType.Dgram, ProtocolType.Udp); byte[] buffer = new byte[32]; - Task sendTask = SendToAsync(socket, new ArraySegment(buffer), ValidUdpRemoteEndpoint); + Task sendTask = SendToAsync(socket, new ArraySegment(buffer), GetGetDummyTestEndpoint()); // Asynchronous calls shall alter the property immediately: if (!UsesSync) @@ -91,7 +103,7 @@ public async Task Disposed_Throws() using var socket = new Socket(AddressFamily.InterNetwork, SocketType.Dgram, ProtocolType.Udp); socket.Dispose(); - await Assert.ThrowsAsync(() => SendToAsync(socket, new byte[1], ValidUdpRemoteEndpoint)); + await Assert.ThrowsAsync(() => SendToAsync(socket, new byte[1], GetGetDummyTestEndpoint())); } } @@ -118,11 +130,35 @@ public SendTo_SyncForceNonBlocking(ITestOutputHelper output) : base(output) {} public sealed class SendTo_Apm : SendTo { public SendTo_Apm(ITestOutputHelper output) : base(output) {} + + [Fact] + public void EndSendTo_NullAsyncResult_Throws_ArgumentNullException() + { + EndPoint endpoint = new IPEndPoint(IPAddress.Loopback, 1); + using Socket socket = CreateSocket(); + Assert.Throws(() => socket.EndSendTo(null)); + } + + [Fact] + public void EndSendTo_UnrelatedAsyncResult_Throws_ArgumentException() + { + EndPoint endpoint = new IPEndPoint(IPAddress.Loopback, 1); + using Socket socket = CreateSocket(); + + Assert.Throws(() => socket.EndSendTo(Task.CompletedTask)); + } } public sealed class SendTo_Eap : SendTo { public SendTo_Eap(ITestOutputHelper output) : base(output) {} + + [Fact] + public void SendToAsync_NullAsyncEventArgs_Throws_ArgumentNullException() + { + using Socket socket = CreateSocket(); + Assert.Throws(() => socket.SendToAsync(null)); + } } public sealed class SendTo_Task : SendTo @@ -142,7 +178,7 @@ public async Task PreCanceled_Throws() cts.Cancel(); OperationCanceledException ex = await Assert.ThrowsAnyAsync( - () => sender.SendToAsync(new byte[1], SocketFlags.None, ValidUdpRemoteEndpoint, cts.Token).AsTask()); + () => sender.SendToAsync(new byte[1], SocketFlags.None, GetGetDummyTestEndpoint(), cts.Token).AsTask()); Assert.Equal(cts.Token, ex.CancellationToken); } From 6e78c33cf5874b959c8c537fb71eb7ad639c52f8 Mon Sep 17 00:00:00 2001 From: Anton Firszov Date: Tue, 2 Feb 2021 18:02:27 +0100 Subject: [PATCH 12/23] delete duplicate tests from ArgumentValidationTests.cs --- .../ArgumentValidationTests.cs | 402 ------------------ 1 file changed, 402 deletions(-) diff --git a/src/libraries/System.Net.Sockets/tests/FunctionalTests/ArgumentValidationTests.cs b/src/libraries/System.Net.Sockets/tests/FunctionalTests/ArgumentValidationTests.cs index 8a3f07e54ca8d..7cbb830e2f528 100644 --- a/src/libraries/System.Net.Sockets/tests/FunctionalTests/ArgumentValidationTests.cs +++ b/src/libraries/System.Net.Sockets/tests/FunctionalTests/ArgumentValidationTests.cs @@ -263,35 +263,6 @@ public void Send_Buffers_EmptyBuffers_Throws_Argument() AssertExtensions.Throws("buffers", () => GetSocket().Send(new List>(), SocketFlags.None, out errorCode)); } - //[Fact] - //public void SendTo_NullBuffer_Throws_ArgumentNull() - //{ - // Assert.Throws(() => GetSocket().SendTo(null, 0, 0, SocketFlags.None, new IPEndPoint(IPAddress.Loopback, 1))); - //} - - //[Fact] - //public void SendTo_NullEndPoint_Throws_ArgumentNull() - //{ - // Assert.Throws(() => GetSocket().SendTo(s_buffer, 0, 0, SocketFlags.None, null)); - //} - - //[Fact] - //public void SendTo_InvalidOffset_Throws_ArgumentOutOfRange() - //{ - // EndPoint endpoint = new IPEndPoint(IPAddress.Loopback, 1); - // Assert.Throws(() => GetSocket().SendTo(s_buffer, -1, s_buffer.Length, SocketFlags.None, endpoint)); - // Assert.Throws(() => GetSocket().SendTo(s_buffer, s_buffer.Length + 1, s_buffer.Length, SocketFlags.None, endpoint)); - //} - - //[Fact] - //public void SendTo_InvalidSize_Throws_ArgumentOutOfRange() - //{ - // EndPoint endpoint = new IPEndPoint(IPAddress.Loopback, 1); - // Assert.Throws(() => GetSocket().SendTo(s_buffer, 0, -1, SocketFlags.None, endpoint)); - // Assert.Throws(() => GetSocket().SendTo(s_buffer, 0, s_buffer.Length + 1, SocketFlags.None, endpoint)); - // Assert.Throws(() => GetSocket().SendTo(s_buffer, s_buffer.Length, 1, SocketFlags.None, endpoint)); - //} - [Fact] public void Receive_Buffer_NullBuffer_Throws_ArgumentNull() { @@ -330,114 +301,6 @@ public void Receive_Buffers_EmptyBuffers_Throws_Argument() AssertExtensions.Throws("buffers", () => GetSocket().Receive(new List>(), SocketFlags.None, out errorCode)); } - //[Fact] - //public void ReceiveFrom_NullBuffer_Throws_ArgumentNull() - //{ - // EndPoint endpoint = new IPEndPoint(IPAddress.Loopback, 1); - // Assert.Throws(() => GetSocket().ReceiveFrom(null, 0, 0, SocketFlags.None, ref endpoint)); - //} - - //[Fact] - //public void ReceiveFrom_NullEndPoint_Throws_ArgumentNull() - //{ - // EndPoint endpoint = null; - // Assert.Throws(() => GetSocket().ReceiveFrom(s_buffer, 0, 0, SocketFlags.None, ref endpoint)); - //} - - //[Fact] - //public void ReceiveFrom_AddressFamily_Throws_Argument() - //{ - // EndPoint endpoint = new IPEndPoint(IPAddress.IPv6Loopback, 1); - // AssertExtensions.Throws("remoteEP", () => GetSocket(AddressFamily.InterNetwork).ReceiveFrom(s_buffer, 0, 0, SocketFlags.None, ref endpoint)); - //} - - //[Fact] - //public void ReceiveFrom_InvalidOffset_Throws_ArgumentOutOfRange() - //{ - // EndPoint endpoint = new IPEndPoint(IPAddress.Loopback, 1); - // Assert.Throws(() => GetSocket().ReceiveFrom(s_buffer, -1, s_buffer.Length, SocketFlags.None, ref endpoint)); - // Assert.Throws(() => GetSocket().ReceiveFrom(s_buffer, s_buffer.Length + 1, s_buffer.Length, SocketFlags.None, ref endpoint)); - //} - - //[Fact] - //public void ReceiveFrom_InvalidSize_Throws_ArgumentOutOfRange() - //{ - // EndPoint endpoint = new IPEndPoint(IPAddress.Loopback, 1); - // Assert.Throws(() => GetSocket().ReceiveFrom(s_buffer, 0, -1, SocketFlags.None, ref endpoint)); - // Assert.Throws(() => GetSocket().ReceiveFrom(s_buffer, 0, s_buffer.Length + 1, SocketFlags.None, ref endpoint)); - // Assert.Throws(() => GetSocket().ReceiveFrom(s_buffer, s_buffer.Length, 1, SocketFlags.None, ref endpoint)); - //} - - //[Fact] - //public void ReceiveFrom_NotBound_Throws_InvalidOperation() - //{ - // EndPoint endpoint = new IPEndPoint(IPAddress.Loopback, 1); - // Assert.Throws(() => GetSocket().ReceiveFrom(s_buffer, 0, 0, SocketFlags.None, ref endpoint)); - //} - - //[Fact] - //public void ReceiveMessageFrom_NullBuffer_Throws_ArgumentNull() - //{ - // SocketFlags flags = SocketFlags.None; - // EndPoint remote = new IPEndPoint(IPAddress.Loopback, 1); - // IPPacketInformation packetInfo; - - // Assert.Throws(() => GetSocket().ReceiveMessageFrom(null, 0, 0, ref flags, ref remote, out packetInfo)); - //} - - //[Fact] - //public void ReceiveMessageFrom_NullEndPoint_Throws_ArgumentNull() - //{ - // SocketFlags flags = SocketFlags.None; - // EndPoint remote = null; - // IPPacketInformation packetInfo; - - // Assert.Throws(() => GetSocket().ReceiveMessageFrom(s_buffer, 0, 0, ref flags, ref remote, out packetInfo)); - //} - - //[Fact] - //public void ReceiveMessageFrom_AddressFamily_Throws_Argument() - //{ - // SocketFlags flags = SocketFlags.None; - // EndPoint remote = new IPEndPoint(IPAddress.IPv6Loopback, 1); - // IPPacketInformation packetInfo; - - // AssertExtensions.Throws("remoteEP", () => GetSocket(AddressFamily.InterNetwork).ReceiveMessageFrom(s_buffer, 0, 0, ref flags, ref remote, out packetInfo)); - //} - - //[Fact] - //public void ReceiveMessageFrom_InvalidOffset_Throws_ArgumentOutOfRange() - //{ - // SocketFlags flags = SocketFlags.None; - // EndPoint remote = new IPEndPoint(IPAddress.Loopback, 1); - // IPPacketInformation packetInfo; - - // Assert.Throws(() => GetSocket().ReceiveMessageFrom(s_buffer, -1, s_buffer.Length, ref flags, ref remote, out packetInfo)); - // Assert.Throws(() => GetSocket().ReceiveMessageFrom(s_buffer, s_buffer.Length + 1, s_buffer.Length, ref flags, ref remote, out packetInfo)); - //} - - //[Fact] - //public void ReceiveMessageFrom_InvalidSize_Throws_ArgumentOutOfRange() - //{ - // SocketFlags flags = SocketFlags.None; - // EndPoint remote = new IPEndPoint(IPAddress.Loopback, 1); - // IPPacketInformation packetInfo; - - // Assert.Throws(() => GetSocket().ReceiveMessageFrom(s_buffer, 0, -1, ref flags, ref remote, out packetInfo)); - // Assert.Throws(() => GetSocket().ReceiveMessageFrom(s_buffer, 0, s_buffer.Length + 1, ref flags, ref remote, out packetInfo)); - // Assert.Throws(() => GetSocket().ReceiveMessageFrom(s_buffer, s_buffer.Length, 1, ref flags, ref remote, out packetInfo)); - //} - - //[Fact] - //public void ReceiveMessageFrom_NotBound_Throws_InvalidOperation() - //{ - // SocketFlags flags = SocketFlags.None; - // EndPoint remote = new IPEndPoint(IPAddress.Loopback, 1); - // IPPacketInformation packetInfo; - - // Assert.Throws(() => GetSocket().ReceiveMessageFrom(s_buffer, 0, 0, ref flags, ref remote, out packetInfo)); - //} - [Fact] public void SetSocketOption_Object_ObjectNull_Throws_ArgumentNull() { @@ -612,50 +475,6 @@ public void ReceiveAsync_NullAsyncEventArgs_Throws_ArgumentNull() Assert.Throws(() => GetSocket().ReceiveAsync(null)); } - //[Fact] - //public void ReceiveFromAsync_NullAsyncEventArgs_Throws_ArgumentNull() - //{ - // Assert.Throws(() => GetSocket().ReceiveFromAsync(null)); - //} - - //[Fact] - //public void ReceiveFromAsync_NullRemoteEndPoint_Throws_ArgumentException() - //{ - // Assert.Throws("e", () => GetSocket().ReceiveFromAsync(s_eventArgs)); - //} - - //[Fact] - //public void ReceiveFromAsync_AddressFamily_Throws_Argument() - //{ - // var eventArgs = new SocketAsyncEventArgs { - // RemoteEndPoint = new IPEndPoint(IPAddress.IPv6Loopback, 1) - // }; - - // AssertExtensions.Throws("e", () => GetSocket(AddressFamily.InterNetwork).ReceiveFromAsync(eventArgs)); - //} - - //[Fact] - //public void ReceiveMessageFromAsync_NullAsyncEventArgs_Throws_ArgumentNull() - //{ - // Assert.Throws(() => GetSocket().ReceiveMessageFromAsync(null)); - //} - - //[Fact] - //public void ReceiveMessageFromAsync_NullRemoteEndPoint_Throws_ArgumentException() - //{ - // Assert.Throws("e", () => GetSocket().ReceiveMessageFromAsync(s_eventArgs)); - //} - - //[Fact] - //public void ReceiveMessageFromAsync_AddressFamily_Throws_Argument() - //{ - // var eventArgs = new SocketAsyncEventArgs { - // RemoteEndPoint = new IPEndPoint(IPAddress.IPv6Loopback, 1) - // }; - - // AssertExtensions.Throws("e", () => GetSocket(AddressFamily.InterNetwork).ReceiveMessageFromAsync(eventArgs)); - //} - [Fact] public void SendAsync_NullAsyncEventArgs_Throws_ArgumentNull() { @@ -684,18 +503,6 @@ public void SendPacketsAsync_NotConnected_Throws_NotSupported() Assert.Throws(() => GetSocket().SendPacketsAsync(eventArgs)); } - //[Fact] - //public void SendToAsync_NullAsyncEventArgs_Throws_ArgumentNull() - //{ - // Assert.Throws(() => GetSocket().SendToAsync(null)); - //} - - //[Fact] - //public void SendToAsync_NullRemoteEndPoint_Throws_ArgumentNull() - //{ - // Assert.Throws(() => GetSocket().SendToAsync(s_eventArgs)); - //} - [Theory] [InlineData(true)] [InlineData(false)] @@ -1212,58 +1019,6 @@ public void EndSend_UnrelatedAsyncResult_Throws_Argument() AssertExtensions.Throws("asyncResult", () => GetSocket().EndSend(Task.CompletedTask)); } - //[Fact] - //public void BeginSendTo_NullBuffer_Throws_ArgumentNull() - //{ - // Assert.Throws(() => GetSocket().BeginSendTo(null, 0, 0, SocketFlags.None, new IPEndPoint(IPAddress.Loopback, 1), TheAsyncCallback, null)); - // Assert.Throws(() => { GetSocket().SendToAsync(new ArraySegment(null, 0, 0), SocketFlags.None, new IPEndPoint(IPAddress.Loopback, 1)); }); - //} - - //[Fact] - //public void BeginSendTo_NullEndPoint_Throws_ArgumentNull() - //{ - // Assert.Throws(() => GetSocket().BeginSendTo(s_buffer, 0, 0, SocketFlags.None, null, TheAsyncCallback, null)); - // Assert.Throws(() => { GetSocket().SendToAsync(new ArraySegment(s_buffer, 0, 0), SocketFlags.None, null); }); - //} - - //[Fact] - //public void BeginSendTo_InvalidOffset_Throws_ArgumentOutOfRange() - //{ - // EndPoint endpoint = new IPEndPoint(IPAddress.Loopback, 1); - - // Assert.Throws(() => GetSocket().BeginSendTo(s_buffer, -1, s_buffer.Length, SocketFlags.None, endpoint, TheAsyncCallback, null)); - // Assert.Throws(() => GetSocket().BeginSendTo(s_buffer, s_buffer.Length + 1, s_buffer.Length, SocketFlags.None, endpoint, TheAsyncCallback, null)); - - // Assert.Throws(() => { GetSocket().SendToAsync(new ArraySegment(s_buffer, -1, s_buffer.Length), SocketFlags.None, endpoint); }); - // Assert.ThrowsAny(() => { GetSocket().SendToAsync(new ArraySegment(s_buffer, s_buffer.Length + 1, s_buffer.Length), SocketFlags.None, endpoint); }); - //} - - //[Fact] - //public void BeginSendTo_InvalidSize_Throws_ArgumentOutOfRange() - //{ - // EndPoint endpoint = new IPEndPoint(IPAddress.Loopback, 1); - - // Assert.Throws(() => GetSocket().BeginSendTo(s_buffer, 0, -1, SocketFlags.None, endpoint, TheAsyncCallback, null)); - // Assert.Throws(() => GetSocket().BeginSendTo(s_buffer, 0, s_buffer.Length + 1, SocketFlags.None, endpoint, TheAsyncCallback, null)); - // Assert.Throws(() => GetSocket().BeginSendTo(s_buffer, s_buffer.Length, 1, SocketFlags.None, endpoint, TheAsyncCallback, null)); - - // Assert.Throws(() => { GetSocket().SendToAsync(new ArraySegment(s_buffer, 0, -1), SocketFlags.None, endpoint); }); - // Assert.ThrowsAny(() => { GetSocket().SendToAsync(new ArraySegment(s_buffer, 0, s_buffer.Length + 1), SocketFlags.None, endpoint); }); - // Assert.ThrowsAny(() => { GetSocket().SendToAsync(new ArraySegment(s_buffer, s_buffer.Length, 1), SocketFlags.None, endpoint); }); - //} - - //[Fact] - //public void EndSendTo_NullAsyncResult_Throws_ArgumentNull() - //{ - // Assert.Throws(() => GetSocket().EndSendTo(null)); - //} - - //[Fact] - //public void EndSendto_UnrelatedAsyncResult_Throws_Argument() - //{ - // AssertExtensions.Throws("asyncResult", () => GetSocket().EndSendTo(Task.CompletedTask)); - //} - [Fact] public void BeginReceive_Buffer_NullBuffer_Throws_ArgumentNull() { @@ -1313,163 +1068,6 @@ public void EndReceive_NullAsyncResult_Throws_ArgumentNull() Assert.Throws(() => GetSocket().EndReceive(null)); } - //[Fact] - //public void BeginReceiveFrom_NullBuffer_Throws_ArgumentNull() - //{ - // EndPoint endpoint = new IPEndPoint(IPAddress.Loopback, 1); - // Assert.Throws(() => GetSocket().BeginReceiveFrom(null, 0, 0, SocketFlags.None, ref endpoint, TheAsyncCallback, null)); - // Assert.Throws(() => { GetSocket().ReceiveFromAsync(new ArraySegment(null, 0, 0), SocketFlags.None, endpoint); }); - //} - - //[Fact] - //public void BeginReceiveFrom_NullEndPoint_Throws_ArgumentNull() - //{ - // EndPoint endpoint = null; - // Assert.Throws(() => GetSocket().BeginReceiveFrom(s_buffer, 0, 0, SocketFlags.None, ref endpoint, TheAsyncCallback, null)); - // Assert.Throws(() => { GetSocket().ReceiveFromAsync(new ArraySegment(s_buffer, 0, 0), SocketFlags.None, endpoint); }); - //} - - //[Fact] - //public void BeginReceiveFrom_AddressFamily_Throws_Argument() - //{ - // EndPoint endpoint = new IPEndPoint(IPAddress.IPv6Loopback, 1); - // AssertExtensions.Throws("remoteEP", () => GetSocket(AddressFamily.InterNetwork).BeginReceiveFrom(s_buffer, 0, 0, SocketFlags.None, ref endpoint, TheAsyncCallback, null)); - // AssertExtensions.Throws("remoteEndPoint", () => { GetSocket(AddressFamily.InterNetwork).ReceiveFromAsync(new ArraySegment(s_buffer, 0, 0), SocketFlags.None, endpoint); }); - //} - - //[Fact] - //public void BeginReceiveFrom_InvalidOffset_Throws_ArgumentOutOfRange() - //{ - // EndPoint endpoint = new IPEndPoint(IPAddress.Loopback, 1); - - // Assert.Throws(() => GetSocket().BeginReceiveFrom(s_buffer, -1, s_buffer.Length, SocketFlags.None, ref endpoint, TheAsyncCallback, null)); - // Assert.Throws(() => GetSocket().BeginReceiveFrom(s_buffer, s_buffer.Length + 1, s_buffer.Length, SocketFlags.None, ref endpoint, TheAsyncCallback, null)); - - // Assert.Throws(() => { GetSocket().ReceiveFromAsync(new ArraySegment(s_buffer, -1, s_buffer.Length), SocketFlags.None, endpoint); }); - // Assert.ThrowsAny(() => { GetSocket().ReceiveFromAsync(new ArraySegment(s_buffer, s_buffer.Length + 1, s_buffer.Length), SocketFlags.None, endpoint); }); - //} - - //[Fact] - //public void BeginReceiveFrom_InvalidSize_Throws_ArgumentOutOfRange() - //{ - // EndPoint endpoint = new IPEndPoint(IPAddress.Loopback, 1); - - // Assert.Throws(() => GetSocket().BeginReceiveFrom(s_buffer, 0, -1, SocketFlags.None, ref endpoint, TheAsyncCallback, null)); - // Assert.Throws(() => GetSocket().BeginReceiveFrom(s_buffer, 0, s_buffer.Length + 1, SocketFlags.None, ref endpoint, TheAsyncCallback, null)); - // Assert.Throws(() => GetSocket().BeginReceiveFrom(s_buffer, s_buffer.Length, 1, SocketFlags.None, ref endpoint, TheAsyncCallback, null)); - - // Assert.Throws(() => { GetSocket().ReceiveFromAsync(new ArraySegment(s_buffer, 0, -1), SocketFlags.None, endpoint); }); - // Assert.ThrowsAny(() => { GetSocket().ReceiveFromAsync(new ArraySegment(s_buffer, 0, s_buffer.Length + 1), SocketFlags.None, endpoint); }); - // Assert.ThrowsAny(() => { GetSocket().ReceiveFromAsync(new ArraySegment(s_buffer, s_buffer.Length, 1), SocketFlags.None, endpoint); }); - //} - - //[Fact] - //public void BeginReceiveFrom_NotBound_Throws_InvalidOperation() - //{ - // EndPoint endpoint = new IPEndPoint(IPAddress.Loopback, 1); - // Assert.Throws(() => GetSocket().BeginReceiveFrom(s_buffer, 0, 0, SocketFlags.None, ref endpoint, TheAsyncCallback, null)); - // Assert.Throws(() => { GetSocket().ReceiveFromAsync(new ArraySegment(s_buffer, 0, 0), SocketFlags.None, endpoint); }); - //} - - //[Fact] - //public void EndReceiveFrom_NullAsyncResult_Throws_ArgumentNull() - //{ - // EndPoint endpoint = new IPEndPoint(IPAddress.Loopback, 1); - // Assert.Throws(() => GetSocket().EndReceiveFrom(null, ref endpoint)); - //} - - //[Fact] - //public void BeginReceiveMessageFrom_NullBuffer_Throws_ArgumentNull() - //{ - // EndPoint remote = new IPEndPoint(IPAddress.Loopback, 1); - - // Assert.Throws(() => GetSocket().BeginReceiveMessageFrom(null, 0, 0, SocketFlags.None, ref remote, TheAsyncCallback, null)); - // Assert.Throws(() => { GetSocket().ReceiveMessageFromAsync(new ArraySegment(null, 0, 0), SocketFlags.None, remote); }); - //} - - //[Fact] - //public void BeginReceiveMessageFrom_NullEndPoint_Throws_ArgumentNull() - //{ - // EndPoint remote = null; - - // Assert.Throws(() => GetSocket().BeginReceiveMessageFrom(s_buffer, 0, 0, SocketFlags.None, ref remote, TheAsyncCallback, null)); - // Assert.Throws(() => { GetSocket().ReceiveMessageFromAsync(new ArraySegment(s_buffer, 0, 0), SocketFlags.None, remote); }); - //} - - //[Fact] - //public void BeginReceiveMessageFrom_AddressFamily_Throws_Argument() - //{ - // EndPoint remote = new IPEndPoint(IPAddress.IPv6Loopback, 1); - - // AssertExtensions.Throws("remoteEP", () => GetSocket(AddressFamily.InterNetwork).BeginReceiveMessageFrom(s_buffer, 0, 0, SocketFlags.None, ref remote, TheAsyncCallback, null)); - // AssertExtensions.Throws("remoteEndPoint", () => { GetSocket(AddressFamily.InterNetwork).ReceiveMessageFromAsync(new ArraySegment(s_buffer, 0, 0), SocketFlags.None, remote); }); - //} - - //[Fact] - //public void BeginReceiveMessageFrom_InvalidOffset_Throws_ArgumentOutOfRange() - //{ - // EndPoint remote = new IPEndPoint(IPAddress.Loopback, 1); - - // Assert.Throws(() => GetSocket().BeginReceiveMessageFrom(s_buffer, -1, s_buffer.Length, SocketFlags.None, ref remote, TheAsyncCallback, null)); - // Assert.Throws(() => GetSocket().BeginReceiveMessageFrom(s_buffer, s_buffer.Length + 1, s_buffer.Length, SocketFlags.None, ref remote, TheAsyncCallback, null)); - - // Assert.Throws(() => { GetSocket().ReceiveMessageFromAsync(new ArraySegment(s_buffer, -1, s_buffer.Length), SocketFlags.None, remote); }); - // Assert.ThrowsAny(() => { GetSocket().ReceiveMessageFromAsync(new ArraySegment(s_buffer, s_buffer.Length + 1, s_buffer.Length), SocketFlags.None, remote); }); - //} - - //[Fact] - //public void BeginReceiveMessageFrom_InvalidSize_Throws_ArgumentOutOfRange() - //{ - // EndPoint remote = new IPEndPoint(IPAddress.Loopback, 1); - - // Assert.Throws(() => GetSocket().BeginReceiveMessageFrom(s_buffer, 0, -1, SocketFlags.None, ref remote, TheAsyncCallback, null)); - // Assert.Throws(() => GetSocket().BeginReceiveMessageFrom(s_buffer, 0, s_buffer.Length + 1, SocketFlags.None, ref remote, TheAsyncCallback, null)); - // Assert.Throws(() => GetSocket().BeginReceiveMessageFrom(s_buffer, s_buffer.Length, 1, SocketFlags.None, ref remote, TheAsyncCallback, null)); - - // Assert.Throws(() => { GetSocket().ReceiveMessageFromAsync(new ArraySegment(s_buffer, 0, -1), SocketFlags.None, remote); }); - // Assert.ThrowsAny(() => { GetSocket().ReceiveMessageFromAsync(new ArraySegment(s_buffer, 0, s_buffer.Length + 1), SocketFlags.None, remote); }); - // Assert.ThrowsAny(() => { GetSocket().ReceiveMessageFromAsync(new ArraySegment(s_buffer, s_buffer.Length, 1), SocketFlags.None, remote); }); - //} - - //[Fact] - //public void BeginReceiveMessageFrom_NotBound_Throws_InvalidOperation() - //{ - // EndPoint remote = new IPEndPoint(IPAddress.Loopback, 1); - - // Assert.Throws(() => GetSocket().BeginReceiveMessageFrom(s_buffer, 0, 0, SocketFlags.None, ref remote, TheAsyncCallback, null)); - // Assert.Throws(() => { GetSocket().ReceiveMessageFromAsync(new ArraySegment(s_buffer, 0, 0), SocketFlags.None, remote); }); - //} - - //[Fact] - //public void EndReceiveMessageFrom_NullEndPoint_Throws_ArgumentNull() - //{ - // SocketFlags flags = SocketFlags.None; - // EndPoint remote = null; - // IPPacketInformation packetInfo; - - // Assert.Throws(() => GetSocket().EndReceiveMessageFrom(null, ref flags, ref remote, out packetInfo)); - //} - - //[Fact] - //public void EndReceiveMessageFrom_AddressFamily_Throws_Argument() - //{ - // SocketFlags flags = SocketFlags.None; - // EndPoint remote = new IPEndPoint(IPAddress.IPv6Loopback, 1); - // IPPacketInformation packetInfo; - - // AssertExtensions.Throws("endPoint", () => GetSocket(AddressFamily.InterNetwork).EndReceiveMessageFrom(null, ref flags, ref remote, out packetInfo)); - //} - - //[Fact] - //public void EndReceiveMessageFrom_NullAsyncResult_Throws_ArgumentNull() - //{ - // SocketFlags flags = SocketFlags.None; - // EndPoint remote = new IPEndPoint(IPAddress.Loopback, 1); - // IPPacketInformation packetInfo; - - // Assert.Throws(() => GetSocket().EndReceiveMessageFrom(null, ref flags, ref remote, out packetInfo)); - //} - [Fact] public void CancelConnectAsync_NullEventArgs_Throws_ArgumentNull() { From ae70cbcf4d27b7c8ac03a1929c7fab97d64516ef Mon Sep 17 00:00:00 2001 From: Anton Firszov Date: Tue, 2 Feb 2021 19:02:06 +0100 Subject: [PATCH 13/23] delete some unused code --- .../src/System.Net.Sockets.csproj | 5 +- .../Net/Sockets/BaseOverlappedAsyncResult.cs | 8 -- .../Net/Sockets/OverlappedAsyncResult.Unix.cs | 32 ----- .../Sockets/OverlappedAsyncResult.Windows.cs | 136 ------------------ .../Net/Sockets/OverlappedAsyncResult.cs | 22 --- .../System/Net/Sockets/SocketPal.Windows.cs | 25 ---- 6 files changed, 1 insertion(+), 227 deletions(-) delete mode 100644 src/libraries/System.Net.Sockets/src/System/Net/Sockets/OverlappedAsyncResult.Unix.cs delete mode 100644 src/libraries/System.Net.Sockets/src/System/Net/Sockets/OverlappedAsyncResult.Windows.cs delete mode 100644 src/libraries/System.Net.Sockets/src/System/Net/Sockets/OverlappedAsyncResult.cs diff --git a/src/libraries/System.Net.Sockets/src/System.Net.Sockets.csproj b/src/libraries/System.Net.Sockets/src/System.Net.Sockets.csproj index 1757202c4a178..c2c5357a34c49 100644 --- a/src/libraries/System.Net.Sockets/src/System.Net.Sockets.csproj +++ b/src/libraries/System.Net.Sockets/src/System.Net.Sockets.csproj @@ -1,4 +1,4 @@ - + true $(NetCoreAppCurrent)-windows;$(NetCoreAppCurrent)-Unix;$(NetCoreAppCurrent) @@ -46,7 +46,6 @@ - @@ -94,7 +93,6 @@ - @@ -192,7 +190,6 @@ - diff --git a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/BaseOverlappedAsyncResult.cs b/src/libraries/System.Net.Sockets/src/System/Net/Sockets/BaseOverlappedAsyncResult.cs index 0d3a9ffcc7acf..a60cbb975dafe 100644 --- a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/BaseOverlappedAsyncResult.cs +++ b/src/libraries/System.Net.Sockets/src/System/Net/Sockets/BaseOverlappedAsyncResult.cs @@ -21,13 +21,5 @@ internal partial class BaseOverlappedAsyncResult : ContextAwareResult _numBytes = numBytes; return s_resultObjectSentinel; // return sentinel rather than boxing numBytes } - - // DELETEME - // Used instead of the base InternalWaitForCompletion when storing an Int32 result - internal int InternalWaitForCompletionInt32Result() - { - base.InternalWaitForCompletion(); - return _numBytes; - } } } diff --git a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/OverlappedAsyncResult.Unix.cs b/src/libraries/System.Net.Sockets/src/System/Net/Sockets/OverlappedAsyncResult.Unix.cs deleted file mode 100644 index 49cb1262b3d1b..0000000000000 --- a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/OverlappedAsyncResult.Unix.cs +++ /dev/null @@ -1,32 +0,0 @@ -// Licensed to the .NET Foundation under one or more agreements. -// The .NET Foundation licenses this file to you under the MIT license. - -using System.Diagnostics; - -namespace System.Net.Sockets -{ - // OverlappedAsyncResult - // - // This class is used to take care of storage for async Socket operation - // from the BeginSend, BeginSendTo, BeginReceive, BeginReceiveFrom calls. - internal partial class OverlappedAsyncResult : BaseOverlappedAsyncResult - { - private int _socketAddressSize; - - internal int GetSocketAddressSize() - { - return _socketAddressSize; - } - - public void CompletionCallback(int numBytes, byte[]? socketAddress, int socketAddressSize, SocketFlags receivedFlags, SocketError errorCode) - { - if (_socketAddress != null) - { - Debug.Assert(socketAddress == null || _socketAddress.Buffer == socketAddress, $"Unexpected socket address: {socketAddress}"); - _socketAddressSize = socketAddressSize; - } - - base.CompletionCallback(numBytes, errorCode); - } - } -} diff --git a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/OverlappedAsyncResult.Windows.cs b/src/libraries/System.Net.Sockets/src/System/Net/Sockets/OverlappedAsyncResult.Windows.cs deleted file mode 100644 index dced861318f9f..0000000000000 --- a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/OverlappedAsyncResult.Windows.cs +++ /dev/null @@ -1,136 +0,0 @@ -// Licensed to the .NET Foundation under one or more agreements. -// The .NET Foundation licenses this file to you under the MIT license. - -using System.Collections.Generic; -using System.Diagnostics; -using System.Runtime.InteropServices; - -namespace System.Net.Sockets -{ - // OverlappedAsyncResult - // - // This class is used to take care of storage for async Socket operation - // from the BeginSend, BeginSendTo, BeginReceive, BeginReceiveFrom calls. - internal partial class OverlappedAsyncResult : BaseOverlappedAsyncResult - { - internal WSABuffer _singleBuffer; - internal WSABuffer[]? _wsaBuffers; - - internal IntPtr GetSocketAddressPtr() - { - return Marshal.UnsafeAddrOfPinnedArrayElement(_socketAddress!.Buffer, 0); - } - - internal IntPtr GetSocketAddressSizePtr() - { - return Marshal.UnsafeAddrOfPinnedArrayElement(_socketAddress!.Buffer, _socketAddress.GetAddressSizeOffset()); - } - - internal unsafe int GetSocketAddressSize() - { - return *(int*)GetSocketAddressSizePtr(); - } - - // SetUnmanagedStructures - // - // Fills in overlapped structures used in an async overlapped Winsock call. - // These calls are outside the runtime and are unmanaged code, so we need - // to prepare specific structures and ints that lie in unmanaged memory - // since the overlapped calls may complete asynchronously. - internal void SetUnmanagedStructures(byte[] buffer, int offset, int size, Internals.SocketAddress? socketAddress) - { - // Fill in Buffer Array structure that will be used for our send/recv Buffer - _socketAddress = socketAddress; - if (_socketAddress != null) - { - object[] objectsToPin = new object[2]; - objectsToPin[0] = buffer; - - _socketAddress.CopyAddressSizeIntoBuffer(); - objectsToPin[1] = _socketAddress.Buffer; - - base.SetUnmanagedStructures(objectsToPin); - } - else - { - base.SetUnmanagedStructures(buffer); - } - - _singleBuffer.Length = size; - _singleBuffer.Pointer = Marshal.UnsafeAddrOfPinnedArrayElement(buffer, offset); - } - - internal void SetUnmanagedStructures(IList> buffers) - { - // Fill in Buffer Array structure that will be used for our send/recv Buffer. - // Make sure we don't let the app mess up the buffer array enough to cause - // corruption. - int count = buffers.Count; - ArraySegment[] buffersCopy = new ArraySegment[count]; - - for (int i = 0; i < count; i++) - { - buffersCopy[i] = buffers[i]; - RangeValidationHelpers.ValidateSegment(buffersCopy[i]); - } - - _wsaBuffers = new WSABuffer[count]; - - object[] objectsToPin = new object[count]; - for (int i = 0; i < count; i++) - { - objectsToPin[i] = buffersCopy[i].Array!; - } - - base.SetUnmanagedStructures(objectsToPin); - - for (int i = 0; i < count; i++) - { - _wsaBuffers[i].Length = buffersCopy[i].Count; - _wsaBuffers[i].Pointer = Marshal.UnsafeAddrOfPinnedArrayElement(buffersCopy[i].Array!, buffersCopy[i].Offset); - } - } - - // This method is called after an asynchronous call is made for the user. - // It checks and acts accordingly if the IO: - // 1) completed synchronously. - // 2) was pended. - // 3) failed. - internal override object? PostCompletion(int numBytes) - { - if (ErrorCode == 0 && NetEventSource.Log.IsEnabled()) - { - LogBuffer(numBytes); - } - - return base.PostCompletion(numBytes); - } - - private void LogBuffer(int size) - { - // This should only be called if tracing is enabled. However, there is the potential for a race - // condition where tracing is disabled between a calling check and here, in which case the assert - // may fire erroneously. - Debug.Assert(NetEventSource.Log.IsEnabled()); - - if (size > -1) - { - if (_wsaBuffers != null) - { - foreach (WSABuffer wsaBuffer in _wsaBuffers) - { - NetEventSource.DumpBuffer(this, wsaBuffer.Pointer, Math.Min(wsaBuffer.Length, size)); - if ((size -= wsaBuffer.Length) <= 0) - { - break; - } - } - } - else - { - NetEventSource.DumpBuffer(this, _singleBuffer.Pointer, Math.Min(_singleBuffer.Length, size)); - } - } - } - } -} diff --git a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/OverlappedAsyncResult.cs b/src/libraries/System.Net.Sockets/src/System/Net/Sockets/OverlappedAsyncResult.cs deleted file mode 100644 index 784d5ed499b48..0000000000000 --- a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/OverlappedAsyncResult.cs +++ /dev/null @@ -1,22 +0,0 @@ -// Licensed to the .NET Foundation under one or more agreements. -// The .NET Foundation licenses this file to you under the MIT license. - -namespace System.Net.Sockets -{ - // !!! DELETEME!!! - internal partial class OverlappedAsyncResult : BaseOverlappedAsyncResult - { - private Internals.SocketAddress? _socketAddress; - - internal OverlappedAsyncResult(Socket socket, object? asyncState, AsyncCallback? asyncCallback) : - base(socket, asyncState, asyncCallback) - { - } - - internal Internals.SocketAddress? SocketAddress - { - get { return _socketAddress; } - set { _socketAddress = value; } - } - } -} diff --git a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/SocketPal.Windows.cs b/src/libraries/System.Net.Sockets/src/System/Net/Sockets/SocketPal.Windows.cs index ecebabca34d10..0530afd53dbd1 100644 --- a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/SocketPal.Windows.cs +++ b/src/libraries/System.Net.Sockets/src/System/Net/Sockets/SocketPal.Windows.cs @@ -1099,31 +1099,6 @@ public static unsafe SocketError SendFileAsync(SafeSocketHandle handle, FileStre } } - public static unsafe SocketError ReceiveAsync(SafeSocketHandle handle, IList> buffers, SocketFlags socketFlags, OverlappedAsyncResult asyncResult) - { - // Set up asyncResult for overlapped WSASend. - asyncResult.SetUnmanagedStructures(buffers); - try - { - int bytesTransferred; - SocketError errorCode = Interop.Winsock.WSARecv( - handle, - asyncResult._wsaBuffers, - asyncResult._wsaBuffers!.Length, - out bytesTransferred, - ref socketFlags, - asyncResult.DangerousOverlappedPointer, // SafeHandle was just created in SetUnmanagedStructures - IntPtr.Zero); - - return asyncResult.ProcessOverlappedResult(errorCode == SocketError.Success, bytesTransferred); - } - catch - { - asyncResult.ReleaseUnmanagedStructures(); - throw; - } - } - public static unsafe SocketError ReceiveMessageFromAsync(Socket socket, SafeSocketHandle handle, byte[] buffer, int offset, int count, SocketFlags socketFlags, Internals.SocketAddress socketAddress, ReceiveMessageOverlappedAsyncResult asyncResult) { asyncResult.SetUnmanagedStructures(buffer, offset, count, socketAddress, socketFlags); From a692597c107e90b691baeff484232a2aa8e6da78 Mon Sep 17 00:00:00 2001 From: Anton Firszov Date: Tue, 2 Feb 2021 19:13:38 +0100 Subject: [PATCH 14/23] delete more unused stuff --- .../src/System.Net.Sockets.csproj | 3 - ...eceiveMessageOverlappedAsyncResult.Unix.cs | 29 ---- ...iveMessageOverlappedAsyncResult.Windows.cs | 138 ------------------ .../ReceiveMessageOverlappedAsyncResult.cs | 59 -------- .../src/System/Net/Sockets/SocketPal.Unix.cs | 19 --- .../System/Net/Sockets/SocketPal.Windows.cs | 22 --- 6 files changed, 270 deletions(-) delete mode 100644 src/libraries/System.Net.Sockets/src/System/Net/Sockets/ReceiveMessageOverlappedAsyncResult.Unix.cs delete mode 100644 src/libraries/System.Net.Sockets/src/System/Net/Sockets/ReceiveMessageOverlappedAsyncResult.Windows.cs delete mode 100644 src/libraries/System.Net.Sockets/src/System/Net/Sockets/ReceiveMessageOverlappedAsyncResult.cs diff --git a/src/libraries/System.Net.Sockets/src/System.Net.Sockets.csproj b/src/libraries/System.Net.Sockets/src/System.Net.Sockets.csproj index c2c5357a34c49..c6421ec4e1986 100644 --- a/src/libraries/System.Net.Sockets/src/System.Net.Sockets.csproj +++ b/src/libraries/System.Net.Sockets/src/System.Net.Sockets.csproj @@ -46,7 +46,6 @@ - - @@ -190,7 +188,6 @@ - diff --git a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/ReceiveMessageOverlappedAsyncResult.Unix.cs b/src/libraries/System.Net.Sockets/src/System/Net/Sockets/ReceiveMessageOverlappedAsyncResult.Unix.cs deleted file mode 100644 index aa596b291b015..0000000000000 --- a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/ReceiveMessageOverlappedAsyncResult.Unix.cs +++ /dev/null @@ -1,29 +0,0 @@ -// Licensed to the .NET Foundation under one or more agreements. -// The .NET Foundation licenses this file to you under the MIT license. - -using System.Diagnostics; - -namespace System.Net.Sockets -{ - internal unsafe sealed partial class ReceiveMessageOverlappedAsyncResult : BaseOverlappedAsyncResult - { - private int _socketAddressSize; - - internal int GetSocketAddressSize() - { - return _socketAddressSize; - } - - public void CompletionCallback(int numBytes, byte[] socketAddress, int socketAddressSize, SocketFlags receivedFlags, IPPacketInformation ipPacketInformation, SocketError errorCode) - { - Debug.Assert(_socketAddress != null, "_socketAddress was null"); - Debug.Assert(socketAddress == null || _socketAddress.Buffer == socketAddress, $"Unexpected socketAddress: {socketAddress}"); - - _socketAddressSize = socketAddressSize; - _socketFlags = receivedFlags; - _ipPacketInformation = ipPacketInformation; - - base.CompletionCallback(numBytes, errorCode); - } - } -} diff --git a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/ReceiveMessageOverlappedAsyncResult.Windows.cs b/src/libraries/System.Net.Sockets/src/System/Net/Sockets/ReceiveMessageOverlappedAsyncResult.Windows.cs deleted file mode 100644 index 5aa6bf3289876..0000000000000 --- a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/ReceiveMessageOverlappedAsyncResult.Windows.cs +++ /dev/null @@ -1,138 +0,0 @@ -// Licensed to the .NET Foundation under one or more agreements. -// The .NET Foundation licenses this file to you under the MIT license. - -using System.Diagnostics; -using System.Runtime.InteropServices; - -namespace System.Net.Sockets -{ - internal unsafe sealed partial class ReceiveMessageOverlappedAsyncResult : BaseOverlappedAsyncResult - { - private Interop.Winsock.WSAMsg* _message; - private WSABuffer* _wsaBuffer; - private byte[]? _wsaBufferArray; - private byte[]? _controlBuffer; - internal byte[]? _messageBuffer; - - private IntPtr GetSocketAddressSizePtr() - { - return Marshal.UnsafeAddrOfPinnedArrayElement(_socketAddress!.Buffer, _socketAddress.GetAddressSizeOffset()); - } - - internal unsafe int GetSocketAddressSize() - { - return *(int*)GetSocketAddressSizePtr(); - } - - // SetUnmanagedStructures - // - // Fills in overlapped Structures used in an async overlapped Winsock call. - // These calls are outside the runtime and are unmanaged code, so we need - // to prepare specific structures and ints that lie in unmanaged memory - // since the overlapped calls may complete asynchronously. - internal unsafe void SetUnmanagedStructures(byte[] buffer, int offset, int size, Internals.SocketAddress socketAddress, SocketFlags socketFlags) - { - _messageBuffer = new byte[sizeof(Interop.Winsock.WSAMsg)]; - _wsaBufferArray = new byte[sizeof(WSABuffer)]; - - bool ipv4, ipv6; - Socket.GetIPProtocolInformation(((Socket)AsyncObject!).AddressFamily, socketAddress, out ipv4, out ipv6); - - // Prepare control buffer. - if (ipv4) - { - _controlBuffer = new byte[sizeof(Interop.Winsock.ControlData)]; - } - else if (ipv6) - { - _controlBuffer = new byte[sizeof(Interop.Winsock.ControlDataIPv6)]; - } - - // Pin buffers. - object[] objectsToPin = new object[(_controlBuffer != null) ? 5 : 4]; - objectsToPin[0] = buffer; - objectsToPin[1] = _messageBuffer; - objectsToPin[2] = _wsaBufferArray; - - // Prepare socketaddress buffer. - _socketAddress = socketAddress; - _socketAddress.CopyAddressSizeIntoBuffer(); - objectsToPin[3] = _socketAddress.Buffer; - - if (_controlBuffer != null) - { - objectsToPin[4] = _controlBuffer; - } - - base.SetUnmanagedStructures(objectsToPin); - - // Prepare data buffer. - _wsaBuffer = (WSABuffer*)Marshal.UnsafeAddrOfPinnedArrayElement(_wsaBufferArray, 0); - _wsaBuffer->Length = size; - _wsaBuffer->Pointer = Marshal.UnsafeAddrOfPinnedArrayElement(buffer, offset); - - - // Setup structure. - _message = (Interop.Winsock.WSAMsg*)Marshal.UnsafeAddrOfPinnedArrayElement(_messageBuffer, 0); - _message->socketAddress = Marshal.UnsafeAddrOfPinnedArrayElement(_socketAddress.Buffer, 0); - _message->addressLength = (uint)_socketAddress.Size; - _message->buffers = Marshal.UnsafeAddrOfPinnedArrayElement(_wsaBufferArray, 0); - _message->count = 1; - - if (_controlBuffer != null) - { - _message->controlBuffer.Pointer = Marshal.UnsafeAddrOfPinnedArrayElement(_controlBuffer, 0); - _message->controlBuffer.Length = _controlBuffer.Length; - } - - _message->flags = socketFlags; - } - - private unsafe void InitIPPacketInformation() - { - int? controlBufferLength = _controlBuffer?.Length; - if (controlBufferLength == sizeof(Interop.Winsock.ControlData)) - { - // IPv4 - _ipPacketInformation = SocketPal.GetIPPacketInformation((Interop.Winsock.ControlData*)_message->controlBuffer.Pointer); - } - else if (controlBufferLength == sizeof(Interop.Winsock.ControlDataIPv6)) - { - // IPv6 - _ipPacketInformation = SocketPal.GetIPPacketInformation((Interop.Winsock.ControlDataIPv6*)_message->controlBuffer.Pointer); - } - else - { - // Other - _ipPacketInformation = default; - } - } - - protected override void ForceReleaseUnmanagedStructures() - { - _socketFlags = _message->flags; - base.ForceReleaseUnmanagedStructures(); - } - - internal override object? PostCompletion(int numBytes) - { - InitIPPacketInformation(); - if (ErrorCode == 0 && NetEventSource.Log.IsEnabled()) - { - LogBuffer(numBytes); - } - - return base.PostCompletion(numBytes); - } - - private void LogBuffer(int size) - { - // This should only be called if tracing is enabled. However, there is the potential for a race - // condition where tracing is disabled between a calling check and here, in which case the assert - // may fire erroneously. - Debug.Assert(NetEventSource.Log.IsEnabled()); - - NetEventSource.DumpBuffer(this, _wsaBuffer->Pointer, Math.Min(_wsaBuffer->Length, size)); - } - } -} diff --git a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/ReceiveMessageOverlappedAsyncResult.cs b/src/libraries/System.Net.Sockets/src/System/Net/Sockets/ReceiveMessageOverlappedAsyncResult.cs deleted file mode 100644 index 25ef89d4d0cee..0000000000000 --- a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/ReceiveMessageOverlappedAsyncResult.cs +++ /dev/null @@ -1,59 +0,0 @@ -// Licensed to the .NET Foundation under one or more agreements. -// The .NET Foundation licenses this file to you under the MIT license. - -namespace System.Net.Sockets -{ - // !!! DELETEME !!! - internal unsafe sealed partial class ReceiveMessageOverlappedAsyncResult : BaseOverlappedAsyncResult - { - private Internals.SocketAddress? _socketAddressOriginal; - private Internals.SocketAddress? _socketAddress; - - private SocketFlags _socketFlags; - private IPPacketInformation _ipPacketInformation; - - internal ReceiveMessageOverlappedAsyncResult(Socket socket, object? asyncState, AsyncCallback? asyncCallback) : - base(socket, asyncState, asyncCallback) - { } - - internal Internals.SocketAddress? SocketAddress - { - get - { - return _socketAddress; - } - set - { - _socketAddress = value; - } - } - - internal Internals.SocketAddress? SocketAddressOriginal - { - get - { - return _socketAddressOriginal; - } - set - { - _socketAddressOriginal = value; - } - } - - internal SocketFlags SocketFlags - { - get - { - return _socketFlags; - } - } - - internal IPPacketInformation IPPacketInformation - { - get - { - return _ipPacketInformation; - } - } - } -} diff --git a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/SocketPal.Unix.cs b/src/libraries/System.Net.Sockets/src/System/Net/Sockets/SocketPal.Unix.cs index b85a57d51e03d..6f800064abad7 100644 --- a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/SocketPal.Unix.cs +++ b/src/libraries/System.Net.Sockets/src/System/Net/Sockets/SocketPal.Unix.cs @@ -1884,25 +1884,6 @@ public static async void SendPacketsAsync( } } - public static SocketError ReceiveMessageFromAsync(Socket socket, SafeSocketHandle handle, byte[] buffer, int offset, int count, SocketFlags socketFlags, Internals.SocketAddress socketAddress, ReceiveMessageOverlappedAsyncResult asyncResult) - { - asyncResult.SocketAddress = socketAddress; - - bool isIPv4, isIPv6; - Socket.GetIPProtocolInformation(((Socket)asyncResult.AsyncObject!).AddressFamily, socketAddress, out isIPv4, out isIPv6); - - int socketAddressSize = socketAddress.InternalSize; - int bytesReceived; - SocketFlags receivedFlags; - IPPacketInformation ipPacketInformation; - SocketError socketError = handle.AsyncContext.ReceiveMessageFromAsync(new Memory(buffer, offset, count), null, socketFlags, socketAddress.Buffer, ref socketAddressSize, isIPv4, isIPv6, out bytesReceived, out receivedFlags, out ipPacketInformation, asyncResult.CompletionCallback); - if (socketError == SocketError.Success) - { - asyncResult.CompletionCallback(bytesReceived, socketAddress.Buffer, socketAddressSize, receivedFlags, ipPacketInformation, SocketError.Success); - } - return socketError; - } - public static SocketError AcceptAsync(Socket socket, SafeSocketHandle handle, SafeSocketHandle? acceptHandle, int receiveSize, int socketAddressSize, AcceptOverlappedAsyncResult asyncResult) { Debug.Assert(acceptHandle == null, $"Unexpected acceptHandle: {acceptHandle}"); diff --git a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/SocketPal.Windows.cs b/src/libraries/System.Net.Sockets/src/System/Net/Sockets/SocketPal.Windows.cs index 0530afd53dbd1..cf6e12e66dbba 100644 --- a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/SocketPal.Windows.cs +++ b/src/libraries/System.Net.Sockets/src/System/Net/Sockets/SocketPal.Windows.cs @@ -1099,28 +1099,6 @@ public static unsafe SocketError SendFileAsync(SafeSocketHandle handle, FileStre } } - public static unsafe SocketError ReceiveMessageFromAsync(Socket socket, SafeSocketHandle handle, byte[] buffer, int offset, int count, SocketFlags socketFlags, Internals.SocketAddress socketAddress, ReceiveMessageOverlappedAsyncResult asyncResult) - { - asyncResult.SetUnmanagedStructures(buffer, offset, count, socketAddress, socketFlags); - try - { - int bytesTransfered; - SocketError errorCode = (SocketError)socket.WSARecvMsg( - handle, - Marshal.UnsafeAddrOfPinnedArrayElement(asyncResult._messageBuffer!, 0), - out bytesTransfered, - asyncResult.DangerousOverlappedPointer, // SafeHandle was just created in SetUnmanagedStructures - IntPtr.Zero); - - return asyncResult.ProcessOverlappedResult(errorCode == SocketError.Success, bytesTransfered); - } - catch - { - asyncResult.ReleaseUnmanagedStructures(); - throw; - } - } - public static unsafe SocketError AcceptAsync(Socket socket, SafeSocketHandle handle, SafeSocketHandle acceptHandle, int receiveSize, int socketAddressSize, AcceptOverlappedAsyncResult asyncResult) { // The buffer needs to contain the requested data plus room for two sockaddrs and 16 bytes From 47604132f841f6dfe6668a4773292ea6df6361ea Mon Sep 17 00:00:00 2001 From: Anton Firszov Date: Tue, 2 Feb 2021 19:43:52 +0100 Subject: [PATCH 15/23] Revert "cherry pick testfix" This reverts commit 56cd081fdb176cbd5ceab03a0c62ca1f9402f824. --- .../tests/FunctionalTests/ReceiveFrom.cs | 49 ++++++------------- .../FunctionalTests/ReceiveMessageFrom.cs | 49 ++++++------------- 2 files changed, 32 insertions(+), 66 deletions(-) diff --git a/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveFrom.cs b/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveFrom.cs index f4f6fb34b0d39..de8f67b2fd541 100644 --- a/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveFrom.cs +++ b/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveFrom.cs @@ -7,7 +7,6 @@ using System.Threading.Tasks; using Xunit; using Xunit.Abstractions; -using Xunit.Sdk; namespace System.Net.Sockets.Tests { @@ -178,6 +177,7 @@ public async Task ClosedBeforeOperation_Throws_ObjectDisposedException(bool clos [Theory] [InlineData(true)] [InlineData(false)] + [ActiveIssue("https://github.com/dotnet/runtime/issues/47561")] public async Task ClosedDuringOperation_Throws_ObjectDisposedExceptionOrSocketException(bool closeOrDispose) { if (UsesSync && PlatformDetection.IsOSX) @@ -187,42 +187,25 @@ public async Task ClosedDuringOperation_Throws_ObjectDisposedExceptionOrSocketEx return; } - int msDelay = 100; - if (UsesSync) + using var socket = new Socket(AddressFamily.InterNetwork, SocketType.Dgram, ProtocolType.Udp); + socket.BindToAnonymousPort(IPAddress.Any); + + Task receiveTask = ReceiveFromAsync(socket, new byte[1], GetGetDummyTestEndpoint()); + await Task.Delay(100); + if (closeOrDispose) socket.Close(); + else socket.Dispose(); + + if (UsesApm) { - // In sync case Dispose may happen before the operation is started, - // in that case we would see an ObjectDisposedException instead of a SocketException. - // We may need to try the run a couple of times to deal with the timing race. - await RetryHelper.ExecuteAsync(() => RunTestAsync(), maxAttempts: 10, retryWhen: e => e is XunitException); + await Assert.ThrowsAsync(() => receiveTask) + .TimeoutAfter(CancellationTestTimeout); } else { - await RunTestAsync(); - } - - async Task RunTestAsync() - { - using var socket = new Socket(AddressFamily.InterNetwork, SocketType.Dgram, ProtocolType.Udp); - socket.BindToAnonymousPort(IPAddress.Any); - - Task receiveTask = ReceiveFromAsync(socket, new byte[1], GetGetDummyTestEndpoint()); - await Task.Delay(msDelay); - msDelay *= 2; - if (closeOrDispose) socket.Close(); - else socket.Dispose(); - - if (DisposeDuringOperationResultsInDisposedException) - { - await Assert.ThrowsAsync(() => receiveTask) - .TimeoutAfter(CancellationTestTimeout); - } - else - { - SocketException ex = await Assert.ThrowsAsync(() => receiveTask) - .TimeoutAfter(CancellationTestTimeout); - SocketError expectedError = UsesSync ? SocketError.Interrupted : SocketError.OperationAborted; - Assert.Equal(expectedError, ex.SocketErrorCode); - } + SocketException ex = await Assert.ThrowsAsync(() => receiveTask) + .TimeoutAfter(CancellationTestTimeout); + SocketError expectedError = UsesSync ? SocketError.Interrupted : SocketError.OperationAborted; + Assert.Equal(expectedError, ex.SocketErrorCode); } } diff --git a/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveMessageFrom.cs b/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveMessageFrom.cs index 2730432093d9e..df5775a619ece 100644 --- a/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveMessageFrom.cs +++ b/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveMessageFrom.cs @@ -7,7 +7,6 @@ using System.Threading.Tasks; using Xunit; using Xunit.Abstractions; -using Xunit.Sdk; namespace System.Net.Sockets.Tests { @@ -176,6 +175,7 @@ public async Task ClosedBeforeOperation_Throws_ObjectDisposedException(bool clos [Theory] [InlineData(true)] [InlineData(false)] + [ActiveIssue("https://github.com/dotnet/runtime/issues/47561")] public async Task ClosedDuringOperation_Throws_ObjectDisposedExceptionOrSocketException(bool closeOrDispose) { if (UsesSync && PlatformDetection.IsOSX) @@ -185,42 +185,25 @@ public async Task ClosedDuringOperation_Throws_ObjectDisposedExceptionOrSocketEx return; } - int msDelay = 100; - if (UsesSync) + using var socket = new Socket(AddressFamily.InterNetwork, SocketType.Dgram, ProtocolType.Udp); + socket.BindToAnonymousPort(IPAddress.Any); + + Task receiveTask = ReceiveMessageFromAsync(socket, new byte[1], GetGetDummyTestEndpoint()); + await Task.Delay(100); + if (closeOrDispose) socket.Close(); + else socket.Dispose(); + + if (UsesApm) { - // In sync case Dispose may happen before the operation is started, - // in that case we would see an ObjectDisposedException instead of a SocketException. - // We may need to try the run a couple of times to deal with the timing race. - await RetryHelper.ExecuteAsync(() => RunTestAsync(), maxAttempts: 10, retryWhen: e => e is XunitException); + await Assert.ThrowsAsync(() => receiveTask) + .TimeoutAfter(CancellationTestTimeout); } else { - await RunTestAsync(); - } - - async Task RunTestAsync() - { - using var socket = new Socket(AddressFamily.InterNetwork, SocketType.Dgram, ProtocolType.Udp); - socket.BindToAnonymousPort(IPAddress.Any); - - Task receiveTask = ReceiveMessageFromAsync(socket, new byte[1], GetGetDummyTestEndpoint()); - await Task.Delay(msDelay); - msDelay *= 2; - if (closeOrDispose) socket.Close(); - else socket.Dispose(); - - if (DisposeDuringOperationResultsInDisposedException) - { - await Assert.ThrowsAsync(() => receiveTask) - .TimeoutAfter(CancellationTestTimeout); - } - else - { - SocketException ex = await Assert.ThrowsAsync(() => receiveTask) - .TimeoutAfter(CancellationTestTimeout); - SocketError expectedError = UsesSync ? SocketError.Interrupted : SocketError.OperationAborted; - Assert.Equal(expectedError, ex.SocketErrorCode); - } + SocketException ex = await Assert.ThrowsAsync(() => receiveTask) + .TimeoutAfter(CancellationTestTimeout); + SocketError expectedError = UsesSync ? SocketError.Interrupted : SocketError.OperationAborted; + Assert.Equal(expectedError, ex.SocketErrorCode); } } From dacfd6d6d4658b6bcb645a455225133958d306af Mon Sep 17 00:00:00 2001 From: Anton Firszov Date: Tue, 2 Feb 2021 19:49:19 +0100 Subject: [PATCH 16/23] undo adding unused SocketTestHelper property --- .../tests/FunctionalTests/SocketTestHelper.cs | 4 ---- 1 file changed, 4 deletions(-) diff --git a/src/libraries/System.Net.Sockets/tests/FunctionalTests/SocketTestHelper.cs b/src/libraries/System.Net.Sockets/tests/FunctionalTests/SocketTestHelper.cs index 7eead221037bc..832fb5ea60f28 100644 --- a/src/libraries/System.Net.Sockets/tests/FunctionalTests/SocketTestHelper.cs +++ b/src/libraries/System.Net.Sockets/tests/FunctionalTests/SocketTestHelper.cs @@ -40,7 +40,6 @@ public abstract Task ReceiveMessageFromAsync( public virtual bool UsesSync => false; public virtual bool UsesApm => false; public virtual bool UsesEap => false; - public virtual bool UsesTasks => false; public virtual bool DisposeDuringOperationResultsInDisposedException => false; public virtual bool ConnectAfterDisconnectResultsInInvalidOperationException => false; public virtual bool SupportsMultiConnect => true; @@ -211,7 +210,6 @@ public override Task SendFileAsync(Socket s, string fileName, ArraySegment public class SocketHelperTask : SocketHelperBase { - public override bool UsesTasks => true; public override Task AcceptAsync(Socket s) => s.AcceptAsync(); public override Task<(Socket socket, byte[] buffer)> AcceptAsync(Socket s, int receiveSize) @@ -243,7 +241,6 @@ public override Task SendToAsync(Socket s, ArraySegment buffer, EndPo // Same as above, but call the CancellationToken overloads where possible public class SocketHelperCancellableTask : SocketHelperBase { - public override bool UsesTasks => true; // Use a cancellable CancellationToken that we never cancel so that implementations can't just elide handling the CancellationToken. private readonly CancellationTokenSource _cts = new CancellationTokenSource(); // This variant is typically working with Memory overloads. @@ -429,7 +426,6 @@ public Task SendFileAsync(Socket s, string fileName, ArraySegment preBuffe public bool UsesSync => _socketHelper.UsesSync; public bool UsesApm => _socketHelper.UsesApm; public bool UsesEap => _socketHelper.UsesEap; - public bool UsesTask => _socketHelper.UsesTasks; public bool DisposeDuringOperationResultsInDisposedException => _socketHelper.DisposeDuringOperationResultsInDisposedException; public bool ConnectAfterDisconnectResultsInInvalidOperationException => _socketHelper.ConnectAfterDisconnectResultsInInvalidOperationException; public bool SupportsMultiConnect => _socketHelper.SupportsMultiConnect; From e138a719cca08550325872f9e9f10704204be9eb Mon Sep 17 00:00:00 2001 From: Anton Firszov Date: Tue, 2 Feb 2021 20:05:57 +0100 Subject: [PATCH 17/23] do not validate remoteEP argument name --- .../tests/FunctionalTests/ReceiveFrom.cs | 20 +++---------------- .../FunctionalTests/ReceiveMessageFrom.cs | 20 +++---------------- 2 files changed, 6 insertions(+), 34 deletions(-) diff --git a/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveFrom.cs b/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveFrom.cs index de8f67b2fd541..06abfd6f52f30 100644 --- a/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveFrom.cs +++ b/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveFrom.cs @@ -19,8 +19,6 @@ protected static IPEndPoint GetGetDummyTestEndpoint(AddressFamily addressFamily protected static readonly TimeSpan CancellationTestTimeout = TimeSpan.FromSeconds(30); - protected virtual string RemoteEndPointArgumentName => "remoteEP"; - protected ReceiveFrom(ITestOutputHelper output) : base(output) { } [Theory] @@ -57,11 +55,11 @@ public async Task NullEndpoint_Throws_ArgumentException() using Socket socket = CreateSocket(); if (UsesEap) { - await Assert.ThrowsAsync(RemoteEndPointArgumentName, () => ReceiveFromAsync(socket, new byte[1], null)); + await Assert.ThrowsAsync(() => ReceiveFromAsync(socket, new byte[1], null)); } else { - await Assert.ThrowsAsync(RemoteEndPointArgumentName, () => ReceiveFromAsync(socket, new byte[1], null)); + await Assert.ThrowsAsync(() => ReceiveFromAsync(socket, new byte[1], null)); } } @@ -70,7 +68,7 @@ public async Task AddressFamilyDoesNotMatch_Throws_ArgumentException() { using var ipv4Socket = CreateSocket(); EndPoint ipV6Endpoint = GetGetDummyTestEndpoint(AddressFamily.InterNetworkV6); - await Assert.ThrowsAsync(RemoteEndPointArgumentName, () => ReceiveFromAsync(ipv4Socket, new byte[1], ipV6Endpoint)); + await Assert.ThrowsAsync(() => ReceiveFromAsync(ipv4Socket, new byte[1], ipV6Endpoint)); } [Fact] @@ -260,8 +258,6 @@ public sealed class ReceiveFrom_Apm : ReceiveFrom { public ReceiveFrom_Apm(ITestOutputHelper output) : base(output) { } - protected override string RemoteEndPointArgumentName => "remoteEP"; - [Fact] public void EndReceiveFrom_NullAsyncResult_Throws_ArgumentNullException() { @@ -330,16 +326,12 @@ public void BeginReceiveFrom_RemoteEpIsReturnedWhenCompletedSynchronously() public sealed class ReceiveFrom_Task : ReceiveFrom { public ReceiveFrom_Task(ITestOutputHelper output) : base(output) { } - - protected override string RemoteEndPointArgumentName => "remoteEndPoint"; } public sealed class ReceiveFrom_CancellableTask : ReceiveFrom { public ReceiveFrom_CancellableTask(ITestOutputHelper output) : base(output) { } - protected override string RemoteEndPointArgumentName => "remoteEndPoint"; - [Theory] [MemberData(nameof(LoopbacksAndBuffers))] public async Task WhenCanceled_Throws(IPAddress loopback, bool precanceled) @@ -365,8 +357,6 @@ public sealed class ReceiveFrom_Eap : ReceiveFrom { public ReceiveFrom_Eap(ITestOutputHelper output) : base(output) { } - protected override string RemoteEndPointArgumentName => "e"; - [Fact] public void ReceiveFromAsync_NullAsyncEventArgs_Throws_ArgumentNullException() { @@ -388,14 +378,10 @@ public ReceiveFrom_SpanSyncForceNonBlocking(ITestOutputHelper output) : base(out public sealed class ReceiveFrom_MemoryArrayTask : ReceiveFrom { public ReceiveFrom_MemoryArrayTask(ITestOutputHelper output) : base(output) { } - - protected override string RemoteEndPointArgumentName => "remoteEndPoint"; } public sealed class ReceiveFrom_MemoryNativeTask : ReceiveFrom { public ReceiveFrom_MemoryNativeTask(ITestOutputHelper output) : base(output) { } - - protected override string RemoteEndPointArgumentName => "remoteEndPoint"; } } diff --git a/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveMessageFrom.cs b/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveMessageFrom.cs index df5775a619ece..e81787b8b83d5 100644 --- a/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveMessageFrom.cs +++ b/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveMessageFrom.cs @@ -19,8 +19,6 @@ protected static IPEndPoint GetGetDummyTestEndpoint(AddressFamily addressFamily protected static readonly TimeSpan CancellationTestTimeout = TimeSpan.FromSeconds(30); - protected virtual string RemoteEndPointArgumentName => "remoteEP"; - protected ReceiveMessageFrom(ITestOutputHelper output) : base(output) { } [Theory] @@ -57,11 +55,11 @@ public async Task NullEndpoint_Throws_ArgumentException() using Socket socket = CreateSocket(); if (UsesEap) { - await Assert.ThrowsAsync(RemoteEndPointArgumentName, () => ReceiveMessageFromAsync(socket, new byte[1], null)); + await Assert.ThrowsAsync(() => ReceiveMessageFromAsync(socket, new byte[1], null)); } else { - await Assert.ThrowsAsync(RemoteEndPointArgumentName, () => ReceiveMessageFromAsync(socket, new byte[1], null)); + await Assert.ThrowsAsync(() => ReceiveMessageFromAsync(socket, new byte[1], null)); } } @@ -70,7 +68,7 @@ public async Task AddressFamilyDoesNotMatch_Throws_ArgumentException() { using var ipv4Socket = CreateSocket(); EndPoint ipV6Endpoint = GetGetDummyTestEndpoint(AddressFamily.InterNetworkV6); - await Assert.ThrowsAsync(RemoteEndPointArgumentName, () => ReceiveMessageFromAsync(ipv4Socket, new byte[1], ipV6Endpoint)); + await Assert.ThrowsAsync(() => ReceiveMessageFromAsync(ipv4Socket, new byte[1], ipV6Endpoint)); } [Fact] @@ -258,8 +256,6 @@ public sealed class ReceiveMessageFrom_Apm : ReceiveMessageFrom { public ReceiveMessageFrom_Apm(ITestOutputHelper output) : base(output) { } - protected override string RemoteEndPointArgumentName => "remoteEP"; - [Fact] public void EndReceiveMessageFrom_NullAsyncResult_Throws_ArgumentNullException() { @@ -335,16 +331,12 @@ public void BeginReceiveMessageFrom_RemoteEpIsReturnedWhenCompletedSynchronously public sealed class ReceiveMessageFrom_Task : ReceiveMessageFrom { public ReceiveMessageFrom_Task(ITestOutputHelper output) : base(output) { } - - protected override string RemoteEndPointArgumentName => "remoteEndPoint"; } public sealed class ReceiveMessageFrom_CancellableTask : ReceiveMessageFrom { public ReceiveMessageFrom_CancellableTask(ITestOutputHelper output) : base(output) { } - protected override string RemoteEndPointArgumentName => "remoteEndPoint"; - [Theory] [MemberData(nameof(LoopbacksAndBuffers))] public async Task WhenCanceled_Throws(IPAddress loopback, bool precanceled) @@ -370,8 +362,6 @@ public sealed class ReceiveMessageFrom_Eap : ReceiveMessageFrom { public ReceiveMessageFrom_Eap(ITestOutputHelper output) : base(output) { } - protected override string RemoteEndPointArgumentName => "e"; - [Fact] public void ReceiveFromAsync_NullAsyncEventArgs_Throws_ArgumentNullException() { @@ -473,14 +463,10 @@ public ReceiveMessageFrom_SpanSyncForceNonBlocking(ITestOutputHelper output) : b public sealed class ReceiveMessageFrom_MemoryArrayTask : ReceiveMessageFrom { public ReceiveMessageFrom_MemoryArrayTask(ITestOutputHelper output) : base(output) { } - - protected override string RemoteEndPointArgumentName => "remoteEndPoint"; } public sealed class ReceiveMessageFrom_MemoryNativeTask : ReceiveMessageFrom { public ReceiveMessageFrom_MemoryNativeTask(ITestOutputHelper output) : base(output) { } - - protected override string RemoteEndPointArgumentName => "remoteEndPoint"; } } From 96bc809ea6d5c527567ba7ae9679eeea9b96165a Mon Sep 17 00:00:00 2001 From: Anton Firszov Date: Tue, 2 Feb 2021 20:44:12 +0100 Subject: [PATCH 18/23] exceptions should be thrown on synchronous path --- .../tests/FunctionalTests/ReceiveFrom.cs | 12 ++++++------ .../tests/FunctionalTests/ReceiveMessageFrom.cs | 14 +++++++------- .../tests/FunctionalTests/SendTo.cs | 10 ++++------ .../tests/FunctionalTests/SocketTestHelper.cs | 16 ++++++++++++++++ 4 files changed, 33 insertions(+), 19 deletions(-) diff --git a/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveFrom.cs b/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveFrom.cs index 06abfd6f52f30..d288f0ec3c291 100644 --- a/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveFrom.cs +++ b/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveFrom.cs @@ -38,7 +38,7 @@ public async Task OutOfRange_Throws_ArgumentOutOfRangeException(int length, int Offset = offset }.ToActual(); - await Assert.ThrowsAnyAsync(() => ReceiveFromAsync(socket, buffer, GetGetDummyTestEndpoint())); + await AssertThrowsSynchronously(() => ReceiveFromAsync(socket, buffer, GetGetDummyTestEndpoint())); } [Fact] @@ -46,7 +46,7 @@ public async Task NullBuffer_Throws_ArgumentNullException() { if (!ValidatesArrayArguments) return; using Socket socket = CreateSocket(); - await Assert.ThrowsAsync(() => ReceiveFromAsync(socket, null, GetGetDummyTestEndpoint())); + await AssertThrowsSynchronously(() => ReceiveFromAsync(socket, null, GetGetDummyTestEndpoint())); } [Fact] @@ -55,11 +55,11 @@ public async Task NullEndpoint_Throws_ArgumentException() using Socket socket = CreateSocket(); if (UsesEap) { - await Assert.ThrowsAsync(() => ReceiveFromAsync(socket, new byte[1], null)); + await AssertThrowsSynchronously(() => ReceiveFromAsync(socket, new byte[1], null)); } else { - await Assert.ThrowsAsync(() => ReceiveFromAsync(socket, new byte[1], null)); + await AssertThrowsSynchronously(() => ReceiveFromAsync(socket, new byte[1], null)); } } @@ -68,7 +68,7 @@ public async Task AddressFamilyDoesNotMatch_Throws_ArgumentException() { using var ipv4Socket = CreateSocket(); EndPoint ipV6Endpoint = GetGetDummyTestEndpoint(AddressFamily.InterNetworkV6); - await Assert.ThrowsAsync(() => ReceiveFromAsync(ipv4Socket, new byte[1], ipV6Endpoint)); + await AssertThrowsSynchronously(() => ReceiveFromAsync(ipv4Socket, new byte[1], ipV6Endpoint)); } [Fact] @@ -84,7 +84,7 @@ public async Task NotBound_Throws_InvalidOperationException() } else { - await Assert.ThrowsAsync(() => ReceiveFromAsync(socket, new byte[1], GetGetDummyTestEndpoint())); + await AssertThrowsSynchronously(() => ReceiveFromAsync(socket, new byte[1], GetGetDummyTestEndpoint())); } } diff --git a/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveMessageFrom.cs b/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveMessageFrom.cs index e81787b8b83d5..0384715f16e75 100644 --- a/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveMessageFrom.cs +++ b/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveMessageFrom.cs @@ -38,7 +38,7 @@ public async Task OutOfRange_Throws_ArgumentOutOfRangeException(int length, int Offset = offset }.ToActual(); - await Assert.ThrowsAnyAsync(() => ReceiveMessageFromAsync(socket, buffer, GetGetDummyTestEndpoint())); + await AssertThrowsSynchronously(() => ReceiveMessageFromAsync(socket, buffer, GetGetDummyTestEndpoint())); } [Fact] @@ -46,7 +46,7 @@ public async Task NullBuffer_Throws_ArgumentNullException() { if (!ValidatesArrayArguments) return; using Socket socket = CreateSocket(); - await Assert.ThrowsAsync(() => ReceiveMessageFromAsync(socket, null, GetGetDummyTestEndpoint())); + await AssertThrowsSynchronously(() => ReceiveMessageFromAsync(socket, null, GetGetDummyTestEndpoint())); } [Fact] @@ -55,11 +55,11 @@ public async Task NullEndpoint_Throws_ArgumentException() using Socket socket = CreateSocket(); if (UsesEap) { - await Assert.ThrowsAsync(() => ReceiveMessageFromAsync(socket, new byte[1], null)); + await AssertThrowsSynchronously(() => ReceiveMessageFromAsync(socket, new byte[1], null)); } else { - await Assert.ThrowsAsync(() => ReceiveMessageFromAsync(socket, new byte[1], null)); + await AssertThrowsSynchronously(() => ReceiveMessageFromAsync(socket, new byte[1], null)); } } @@ -68,18 +68,18 @@ public async Task AddressFamilyDoesNotMatch_Throws_ArgumentException() { using var ipv4Socket = CreateSocket(); EndPoint ipV6Endpoint = GetGetDummyTestEndpoint(AddressFamily.InterNetworkV6); - await Assert.ThrowsAsync(() => ReceiveMessageFromAsync(ipv4Socket, new byte[1], ipV6Endpoint)); + await AssertThrowsSynchronously(() => ReceiveMessageFromAsync(ipv4Socket, new byte[1], ipV6Endpoint)); } [Fact] public async Task NotBound_Throws_InvalidOperationException() { - // ReceiveFromAsync(saea) throws SocketException / fails with Debug.Assert(): + // ReceiveFromAsync(saea) fails on a Debug.Assert(): // [ActiveIssue("https://github.com/dotnet/runtime/issues/47714")] if (UsesEap) return; using Socket socket = CreateSocket(); - await Assert.ThrowsAsync(() => ReceiveMessageFromAsync(socket, new byte[1], GetGetDummyTestEndpoint())); + await AssertThrowsSynchronously(() => ReceiveMessageFromAsync(socket, new byte[1], GetGetDummyTestEndpoint())); } [PlatformSpecific(TestPlatforms.AnyUnix)] diff --git a/src/libraries/System.Net.Sockets/tests/FunctionalTests/SendTo.cs b/src/libraries/System.Net.Sockets/tests/FunctionalTests/SendTo.cs index 39a34403ab791..70205f8033cc4 100644 --- a/src/libraries/System.Net.Sockets/tests/FunctionalTests/SendTo.cs +++ b/src/libraries/System.Net.Sockets/tests/FunctionalTests/SendTo.cs @@ -18,8 +18,6 @@ namespace System.Net.Sockets.Tests protected static IPEndPoint GetGetDummyTestEndpoint(AddressFamily addressFamily = AddressFamily.InterNetwork) => addressFamily == AddressFamily.InterNetwork ? new IPEndPoint(IPAddress.Parse("1.2.3.4"), 1234) : new IPEndPoint(IPAddress.Parse("1:2:3::4"), 1234); - protected const string RemoteEndPointArgumentName = "remoteEP"; - protected SendTo(ITestOutputHelper output) : base(output) { } @@ -39,7 +37,7 @@ public async Task OutOfRange_Throws_ArgumentOutOfRangeException(int length, int Array = new byte[length], Count = count, Offset = offset }.ToActual(); - await Assert.ThrowsAnyAsync(() => SendToAsync(socket, buffer, GetGetDummyTestEndpoint())); + await AssertThrowsSynchronously(() => SendToAsync(socket, buffer, GetGetDummyTestEndpoint())); } [Fact] @@ -48,7 +46,7 @@ public async Task NullBuffer_Throws_ArgumentNullException() if (!ValidatesArrayArguments) return; using var socket = CreateSocket(); - await Assert.ThrowsAsync(() => SendToAsync(socket, null, GetGetDummyTestEndpoint())); + await AssertThrowsSynchronously(() => SendToAsync(socket, null, GetGetDummyTestEndpoint())); } [Fact] @@ -57,11 +55,11 @@ public async Task NullEndpoint_Throws_ArgumentException() using Socket socket = CreateSocket(); if (UsesEap) { - await Assert.ThrowsAsync(() => SendToAsync(socket, new byte[1], null)); + await AssertThrowsSynchronously(() => SendToAsync(socket, new byte[1], null)); } else { - await Assert.ThrowsAsync(RemoteEndPointArgumentName, () => SendToAsync(socket, new byte[1], null)); + await AssertThrowsSynchronously(() => SendToAsync(socket, new byte[1], null)); } } diff --git a/src/libraries/System.Net.Sockets/tests/FunctionalTests/SocketTestHelper.cs b/src/libraries/System.Net.Sockets/tests/FunctionalTests/SocketTestHelper.cs index 832fb5ea60f28..bdaf68ffb497e 100644 --- a/src/libraries/System.Net.Sockets/tests/FunctionalTests/SocketTestHelper.cs +++ b/src/libraries/System.Net.Sockets/tests/FunctionalTests/SocketTestHelper.cs @@ -434,6 +434,22 @@ public Task SendFileAsync(Socket s, string fileName, ArraySegment preBuffe public bool SupportsSendFileSlicing => _socketHelper.SupportsSendFileSlicing; public void Listen(Socket s, int backlog) => _socketHelper.Listen(s, backlog); public void ConfigureNonBlocking(Socket s) => _socketHelper.ConfigureNonBlocking(s); + + // A helper method to observe exceptions on sync paths of async variants. + // In that case, exceptions should be seen without awaiting completion. + // Synchronous variants are started on a separate thread using Task.Run(), therefore we should await the task. + protected async Task AssertThrowsSynchronously(Func testCode) + where TException : Exception + { + if (UsesSync) + { + return await Assert.ThrowsAsync(testCode); + } + else + { + return Assert.Throws(() => { _ = testCode(); }); + } + } } public class SocketHelperSpanSync : SocketHelperArraySync From 4804b524a22ef5367b2f45f54dc36843f77b4bd8 Mon Sep 17 00:00:00 2001 From: Anton Firszov Date: Tue, 2 Feb 2021 20:49:04 +0100 Subject: [PATCH 19/23] NotBound_Throws_InvalidOperationException does not fail on Unix --- .../tests/FunctionalTests/ReceiveFrom.cs | 16 +++++----------- 1 file changed, 5 insertions(+), 11 deletions(-) diff --git a/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveFrom.cs b/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveFrom.cs index d288f0ec3c291..524b81f67d2d5 100644 --- a/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveFrom.cs +++ b/src/libraries/System.Net.Sockets/tests/FunctionalTests/ReceiveFrom.cs @@ -74,18 +74,12 @@ public async Task AddressFamilyDoesNotMatch_Throws_ArgumentException() [Fact] public async Task NotBound_Throws_InvalidOperationException() { - using Socket socket = CreateSocket(); - - // ReceiveFromAsync(saea) throws SocketException: + // ReceiveFromAsync(saea) does not throw. // [ActiveIssue("https://github.com/dotnet/runtime/issues/47714")] - if (UsesEap) - { - await Assert.ThrowsAsync(() => ReceiveFromAsync(socket, new byte[1], GetGetDummyTestEndpoint())); - } - else - { - await AssertThrowsSynchronously(() => ReceiveFromAsync(socket, new byte[1], GetGetDummyTestEndpoint())); - } + if (UsesEap) return; + + using Socket socket = CreateSocket(); + await AssertThrowsSynchronously(() => ReceiveFromAsync(socket, new byte[1], GetGetDummyTestEndpoint())); } [Theory] From adb73327d1612ce81800f2f9418cf6be332e6192 Mon Sep 17 00:00:00 2001 From: Anton Firszov Date: Thu, 4 Feb 2021 16:32:49 +0100 Subject: [PATCH 20/23] rename 'task' to 't' for consistency --- .../System.Net.Sockets/src/System/Net/Sockets/Socket.cs | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/Socket.cs b/src/libraries/System.Net.Sockets/src/System/Net/Sockets/Socket.cs index cc6d3107f5161..fbe32bedd4ba3 100644 --- a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/Socket.cs +++ b/src/libraries/System.Net.Sockets/src/System/Net/Sockets/Socket.cs @@ -2310,8 +2310,8 @@ public IAsyncResult BeginSendTo(byte[] buffer, int offset, int size, SocketFlags throw new ArgumentNullException(nameof(remoteEP)); } - Task task = SendToAsync(buffer.AsMemory().Slice(offset, size), socketFlags, remoteEP).AsTask(); - return TaskToApm.Begin(task, callback, state); + Task t = SendToAsync(buffer.AsMemory().Slice(offset, size), socketFlags, remoteEP).AsTask(); + return TaskToApm.Begin(t, callback, state); } public int EndSendTo(IAsyncResult asyncResult) From 8dbeabcc24f1dbb454ce6b69d5e15af100e8b189 Mon Sep 17 00:00:00 2001 From: Anton Firszov Date: Thu, 4 Feb 2021 16:40:26 +0100 Subject: [PATCH 21/23] add comment about updating 'remoteEP' in Begin methods --- .../System.Net.Sockets/src/System/Net/Sockets/Socket.cs | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/Socket.cs b/src/libraries/System.Net.Sockets/src/System/Net/Sockets/Socket.cs index fbe32bedd4ba3..61f5096d9396f 100644 --- a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/Socket.cs +++ b/src/libraries/System.Net.Sockets/src/System/Net/Sockets/Socket.cs @@ -2407,6 +2407,8 @@ public IAsyncResult BeginReceiveMessageFrom(byte[] buffer, int offset, int size, ValidateReceiveFromEndpointAndState(remoteEP, nameof(remoteEP)); Task t = ReceiveMessageFromAsync(new Memory(buffer, offset, size), socketFlags, remoteEP).AsTask(); + // In case of synchronous completion, ReceiveMessageFromAsync() returns a completed task. + // When this happens, we need to update 'remoteEP' in order to conform to the historical behavior of BeginReceiveMessageFrom(). if (t.IsCompletedSuccessfully) { EndPoint resultEp = t.Result.RemoteEndPoint; @@ -2446,6 +2448,8 @@ public IAsyncResult BeginReceiveFrom(byte[] buffer, int offset, int size, Socket ValidateReceiveFromEndpointAndState(remoteEP, nameof(remoteEP)); Task t = ReceiveFromAsync(new Memory(buffer, offset, size), socketFlags, remoteEP).AsTask(); + // In case of synchronous completion, ReceiveFromAsync() returns a completed task. + // When this happens, we need to update 'remoteEP' in order to conform to the historical behavior of BeginReceiveFrom(). if (t.IsCompletedSuccessfully) { EndPoint resultEp = t.Result.RemoteEndPoint; From fa5429326ec38b93dd6fa10e0dc3363ea36153be Mon Sep 17 00:00:00 2001 From: Anton Firszov Date: Thu, 4 Feb 2021 16:43:40 +0100 Subject: [PATCH 22/23] consistent Memory slicing --- .../System.Net.Sockets/src/System/Net/Sockets/Socket.cs | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/Socket.cs b/src/libraries/System.Net.Sockets/src/System/Net/Sockets/Socket.cs index 61f5096d9396f..eb5277e8e01a2 100644 --- a/src/libraries/System.Net.Sockets/src/System/Net/Sockets/Socket.cs +++ b/src/libraries/System.Net.Sockets/src/System/Net/Sockets/Socket.cs @@ -2310,7 +2310,7 @@ public IAsyncResult BeginSendTo(byte[] buffer, int offset, int size, SocketFlags throw new ArgumentNullException(nameof(remoteEP)); } - Task t = SendToAsync(buffer.AsMemory().Slice(offset, size), socketFlags, remoteEP).AsTask(); + Task t = SendToAsync(buffer.AsMemory(offset, size), socketFlags, remoteEP).AsTask(); return TaskToApm.Begin(t, callback, state); } @@ -2406,7 +2406,7 @@ public IAsyncResult BeginReceiveMessageFrom(byte[] buffer, int offset, int size, ValidateBufferArguments(buffer, offset, size); ValidateReceiveFromEndpointAndState(remoteEP, nameof(remoteEP)); - Task t = ReceiveMessageFromAsync(new Memory(buffer, offset, size), socketFlags, remoteEP).AsTask(); + Task t = ReceiveMessageFromAsync(buffer.AsMemory(offset, size), socketFlags, remoteEP).AsTask(); // In case of synchronous completion, ReceiveMessageFromAsync() returns a completed task. // When this happens, we need to update 'remoteEP' in order to conform to the historical behavior of BeginReceiveMessageFrom(). if (t.IsCompletedSuccessfully) @@ -2447,7 +2447,7 @@ public IAsyncResult BeginReceiveFrom(byte[] buffer, int offset, int size, Socket ValidateBufferArguments(buffer, offset, size); ValidateReceiveFromEndpointAndState(remoteEP, nameof(remoteEP)); - Task t = ReceiveFromAsync(new Memory(buffer, offset, size), socketFlags, remoteEP).AsTask(); + Task t = ReceiveFromAsync(buffer.AsMemory(offset, size), socketFlags, remoteEP).AsTask(); // In case of synchronous completion, ReceiveFromAsync() returns a completed task. // When this happens, we need to update 'remoteEP' in order to conform to the historical behavior of BeginReceiveFrom(). if (t.IsCompletedSuccessfully) From b3e035e55645d15bb8af0f55dd5b255c80d12cfa Mon Sep 17 00:00:00 2001 From: Anton Firszov Date: Mon, 8 Feb 2021 15:40:29 +0100 Subject: [PATCH 23/23] workaround #47905 in tests --- .../tests/FunctionalTests/DualModeSocketTest.cs | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/src/libraries/System.Net.Sockets/tests/FunctionalTests/DualModeSocketTest.cs b/src/libraries/System.Net.Sockets/tests/FunctionalTests/DualModeSocketTest.cs index e957790e8c590..d7d037abba193 100644 --- a/src/libraries/System.Net.Sockets/tests/FunctionalTests/DualModeSocketTest.cs +++ b/src/libraries/System.Net.Sockets/tests/FunctionalTests/DualModeSocketTest.cs @@ -1121,7 +1121,11 @@ public void Socket_BeginSendToV4IPEndPointToV4Host_Throws() Assert.Throws(() => { - socket.BeginSendTo(new byte[1], 0, 1, SocketFlags.None, new IPEndPoint(IPAddress.Loopback, UnusedPort), null, null); + // [ActiveIssue("https://github.com/dotnet/runtime/issues/47905")] + // TODO: When fixing the issue above, revert this test to check that the exception is being thrown in BeginSendTo + // without the need to call EndSendTo. + IAsyncResult result = socket.BeginSendTo(new byte[1], 0, 1, SocketFlags.None, new IPEndPoint(IPAddress.Loopback, UnusedPort), null, null); + socket.EndSendTo(result); }); } }