Test refactoring

pull/1/head
Ogoun 4 years ago
parent 3dd4d22c22
commit 7d7090b4c9

@ -1,60 +1,89 @@
using System;
using System.Collections.Concurrent;
using System.Collections.Generic;
using ZeroLevel.Services.Pools;
namespace ZeroLevel.Network
{
internal sealed class RequestBuffer
{
private ConcurrentDictionary<long, RequestInfo> _requests = new ConcurrentDictionary<long, RequestInfo>();
private static ObjectPool<RequestInfo> _ri_pool = new ObjectPool<RequestInfo>(() => new RequestInfo());
private ConcurrentDictionary<long, Action<byte[]>> _callbacks = new ConcurrentDictionary<long, Action<byte[]>>();
private ConcurrentDictionary<long, Action<string>> _fallbacks = new ConcurrentDictionary<long, Action<string>>();
private ConcurrentDictionary<long, long> _timeouts = new ConcurrentDictionary<long, long>();
public void RegisterForFrame(int identity, Action<byte[]> callback, Action<string> fail = null)
public void RegisterForFrame(int identity, Action<byte[]> callback, Action<string> fallback = null)
{
var ri = _ri_pool.Allocate();
ri.Reset(callback, fail);
_requests[identity] = ri;
if (callback != null)
{
_callbacks.TryAdd(identity, callback);
}
if (fallback != null)
{
_fallbacks.TryAdd(identity, fallback);
}
}
public void Fail(long frameId, string message)
public void Fail(long identity, string message)
{
RequestInfo ri;
if (_requests.TryRemove(frameId, out ri))
Action<string> rec;
if (_fallbacks.TryRemove(identity, out rec))
{
ri.Fail(message);
_ri_pool.Free(ri);
try
{
rec(message);
}
catch (Exception ex)
{
Log.Error(ex, $"Fail invoke fallback for request '{identity}' with message '{message ?? string.Empty}'");
}
rec = null;
}
}
public void Success(long frameId, byte[] data)
public void Success(long identity, byte[] data)
{
RequestInfo ri;
if (_requests.TryRemove(frameId, out ri))
Action<byte[]> rec;
if (_callbacks.TryRemove(identity, out rec))
{
ri.Success(data);
_ri_pool.Free(ri);
try
{
rec(data);
}
catch (Exception ex)
{
Log.Error(ex, $"Fail invoke callback for request '{identity}'. Response size '{data?.Length ?? 0}'");
}
rec = null;
}
}
public void StartSend(long frameId)
public void StartSend(long identity)
{
RequestInfo ri;
if (_requests.TryGetValue(frameId, out ri))
if (_callbacks.ContainsKey(identity)
|| _fallbacks.ContainsKey(identity))
{
ri.StartSend();
_timeouts.TryAdd(identity, DateTime.UtcNow.Ticks);
}
}
public void Timeout(List<long> frameIds)
public void Timeout(List<long> identities)
{
RequestInfo ri;
for (int i = 0; i < frameIds.Count; i++)
long t;
Action<string> rec;
foreach (var id in identities)
{
if (_requests.TryRemove(frameIds[i], out ri))
if (_fallbacks.TryRemove(id, out rec))
{
_ri_pool.Free(ri);
try
{
rec("Timeout");
}
catch (Exception ex)
{
Log.Error(ex, $"Fail invoke fallback for request '{id}' by timeout");
}
rec = null;
}
_timeouts.TryRemove(id, out t);
}
}
@ -62,10 +91,9 @@ namespace ZeroLevel.Network
{
var now_ticks = DateTime.UtcNow.Ticks;
var to_remove = new List<long>();
foreach (var pair in _requests)
foreach (var pair in _timeouts)
{
if (pair.Value.Sended == false) continue;
var diff = now_ticks - pair.Value.Timestamp;
var diff = now_ticks - pair.Value;
if (diff > BaseSocket.MAX_REQUEST_TIME_TICKS)
{
to_remove.Add(pair.Key);

Loading…
Cancel
Save

Powered by TurnKey Linux.