mirror of
https://github.com/JKorf/CryptoExchange.Net
synced 2025-06-07 16:06:15 +00:00
commit 0571ed17a0e502f689af6e8a5dbd0f05fd229496 Author: JKorf <jankorf91@gmail.com> Date: Sun Jul 10 19:56:27 2022 +0200 Fixed tests commit 99c331b389b58f09db3960adc7293d9b45d05caa Author: JKorf <jankorf91@gmail.com> Date: Sun Jul 10 16:41:14 2022 +0200 Updated version commit 70f8bd203a00fbdef2b13526133a3b556cfc897f Author: JKorf <jankorf91@gmail.com> Date: Sun Jul 10 16:36:00 2022 +0200 Finished up websocket refactoring commit 89b517c93684dc9c1e8a99bc600caaf6f9a4459e Author: JKorf <jankorf91@gmail.com> Date: Fri Jul 8 20:24:58 2022 +0200 wip commit 91e33cc42c5725aece765b6c8f6a7f35ab87a80e Author: JKorf <jankorf91@gmail.com> Date: Thu Jul 7 22:17:55 2022 +0200 wip
165 lines
5.9 KiB
C#
165 lines
5.9 KiB
C#
using System;
|
|
using System.Threading;
|
|
using CryptoExchange.Net.Objects;
|
|
using CryptoExchange.Net.Sockets;
|
|
using CryptoExchange.Net.UnitTests.TestImplementations;
|
|
using Microsoft.Extensions.Logging;
|
|
using Newtonsoft.Json.Linq;
|
|
using NUnit.Framework;
|
|
|
|
namespace CryptoExchange.Net.UnitTests
|
|
{
|
|
[TestFixture]
|
|
public class SocketClientTests
|
|
{
|
|
[TestCase]
|
|
public void SettingOptions_Should_ResultInOptionsSet()
|
|
{
|
|
//arrange
|
|
//act
|
|
var client = new TestSocketClient(new TestOptions()
|
|
{
|
|
SubOptions = new RestApiClientOptions
|
|
{
|
|
BaseAddress = "http://test.address.com"
|
|
},
|
|
ReconnectInterval = TimeSpan.FromSeconds(6)
|
|
});
|
|
|
|
|
|
//assert
|
|
Assert.IsTrue(client.SubClient.Options.BaseAddress == "http://test.address.com");
|
|
Assert.IsTrue(client.ClientOptions.ReconnectInterval.TotalSeconds == 6);
|
|
}
|
|
|
|
[TestCase(true)]
|
|
[TestCase(false)]
|
|
public void ConnectSocket_Should_ReturnConnectionResult(bool canConnect)
|
|
{
|
|
//arrange
|
|
var client = new TestSocketClient();
|
|
var socket = client.CreateSocket();
|
|
socket.CanConnect = canConnect;
|
|
|
|
//act
|
|
var connectResult = client.ConnectSocketSub(new SocketConnection(client, null, socket, null));
|
|
|
|
//assert
|
|
Assert.IsTrue(connectResult.Success == canConnect);
|
|
}
|
|
|
|
[TestCase]
|
|
public void SocketMessages_Should_BeProcessedInDataHandlers()
|
|
{
|
|
// arrange
|
|
var client = new TestSocketClient(new TestOptions() { ReconnectInterval = TimeSpan.Zero, LogLevel = LogLevel.Debug });
|
|
var socket = client.CreateSocket();
|
|
socket.ShouldReconnect = true;
|
|
socket.CanConnect = true;
|
|
socket.DisconnectTime = DateTime.UtcNow;
|
|
var sub = new SocketConnection(client, null, socket, null);
|
|
var rstEvent = new ManualResetEvent(false);
|
|
JToken result = null;
|
|
sub.AddSubscription(SocketSubscription.CreateForIdentifier(10, "TestHandler", true, false, (messageEvent) =>
|
|
{
|
|
result = messageEvent.JsonData;
|
|
rstEvent.Set();
|
|
}));
|
|
client.ConnectSocketSub(sub);
|
|
|
|
// act
|
|
socket.InvokeMessage("{\"property\": 123}");
|
|
rstEvent.WaitOne(1000);
|
|
|
|
// assert
|
|
Assert.IsTrue((int)result["property"] == 123);
|
|
}
|
|
|
|
[TestCase(false)]
|
|
[TestCase(true)]
|
|
public void SocketMessages_Should_ContainOriginalDataIfEnabled(bool enabled)
|
|
{
|
|
// arrange
|
|
var client = new TestSocketClient(new TestOptions() { ReconnectInterval = TimeSpan.Zero, LogLevel = LogLevel.Debug, OutputOriginalData = enabled });
|
|
var socket = client.CreateSocket();
|
|
socket.ShouldReconnect = true;
|
|
socket.CanConnect = true;
|
|
socket.DisconnectTime = DateTime.UtcNow;
|
|
var sub = new SocketConnection(client, null, socket, null);
|
|
var rstEvent = new ManualResetEvent(false);
|
|
string original = null;
|
|
sub.AddSubscription(SocketSubscription.CreateForIdentifier(10, "TestHandler", true, false, (messageEvent) =>
|
|
{
|
|
original = messageEvent.OriginalData;
|
|
rstEvent.Set();
|
|
}));
|
|
client.ConnectSocketSub(sub);
|
|
|
|
// act
|
|
socket.InvokeMessage("{\"property\": 123}");
|
|
rstEvent.WaitOne(1000);
|
|
|
|
// assert
|
|
Assert.IsTrue(original == (enabled ? "{\"property\": 123}" : null));
|
|
}
|
|
|
|
[TestCase()]
|
|
public void UnsubscribingStream_Should_CloseTheSocket()
|
|
{
|
|
// arrange
|
|
var client = new TestSocketClient(new TestOptions() { ReconnectInterval = TimeSpan.Zero, LogLevel = LogLevel.Debug });
|
|
var socket = client.CreateSocket();
|
|
socket.CanConnect = true;
|
|
var sub = new SocketConnection(client, null, socket, null);
|
|
client.ConnectSocketSub(sub);
|
|
var us = SocketSubscription.CreateForIdentifier(10, "Test", true, false, (e) => { });
|
|
var ups = new UpdateSubscription(sub, us);
|
|
sub.AddSubscription(us);
|
|
|
|
// act
|
|
client.UnsubscribeAsync(ups).Wait();
|
|
|
|
// assert
|
|
Assert.IsTrue(socket.Connected == false);
|
|
}
|
|
|
|
[TestCase()]
|
|
public void UnsubscribingAll_Should_CloseAllSockets()
|
|
{
|
|
// arrange
|
|
var client = new TestSocketClient(new TestOptions() { ReconnectInterval = TimeSpan.Zero, LogLevel = LogLevel.Debug });
|
|
var socket1 = client.CreateSocket();
|
|
var socket2 = client.CreateSocket();
|
|
socket1.CanConnect = true;
|
|
socket2.CanConnect = true;
|
|
var sub1 = new SocketConnection(client, null, socket1, null);
|
|
var sub2 = new SocketConnection(client, null, socket2, null);
|
|
client.ConnectSocketSub(sub1);
|
|
client.ConnectSocketSub(sub2);
|
|
|
|
// act
|
|
client.UnsubscribeAllAsync().Wait();
|
|
|
|
// assert
|
|
Assert.IsTrue(socket1.Connected == false);
|
|
Assert.IsTrue(socket2.Connected == false);
|
|
}
|
|
|
|
[TestCase()]
|
|
public void FailingToConnectSocket_Should_ReturnError()
|
|
{
|
|
// arrange
|
|
var client = new TestSocketClient(new TestOptions() { ReconnectInterval = TimeSpan.Zero, LogLevel = LogLevel.Debug });
|
|
var socket = client.CreateSocket();
|
|
socket.CanConnect = false;
|
|
var sub = new SocketConnection(client, null, socket, null);
|
|
|
|
// act
|
|
var connectResult = client.ConnectSocketSub(sub);
|
|
|
|
// assert
|
|
Assert.IsFalse(connectResult.Success);
|
|
}
|
|
}
|
|
}
|