mirror of
https://github.com/GeWuYou/GFramework.git
synced 2026-03-22 10:34:30 +08:00
- 将ILogAppender接口继承IDisposable以支持资源释放 - 添加ITimeProvider和SystemTimeProvider接口及实现类 - 创建FakeTimeProvider用于测试时间控制 - 修改SamplingFilter支持时间提供者注入和最大日志记录器数量限制 - 为SamplingFilter添加过期状态清理功能 - 修改StatisticsAppender使用时间提供者并实现IDisposable - 更新相关单元测试以使用FakeTimeProvider进行精确时间控制 - 在测试类中为模拟追加器添加Dispose方法实现
41 lines
1.0 KiB
C#
41 lines
1.0 KiB
C#
using GFramework.Core.Abstractions.time;
|
|
|
|
namespace GFramework.Core.Tests.time;
|
|
|
|
/// <summary>
|
|
/// 可控制的时间提供者,用于测试
|
|
/// </summary>
|
|
public sealed class FakeTimeProvider : ITimeProvider
|
|
{
|
|
private DateTime _currentTime;
|
|
|
|
/// <summary>
|
|
/// 创建可控制的时间提供者
|
|
/// </summary>
|
|
/// <param name="initialTime">初始时间,默认为 2024-01-01 00:00:00 UTC</param>
|
|
public FakeTimeProvider(DateTime? initialTime = null)
|
|
{
|
|
_currentTime = initialTime ?? new DateTime(2024, 1, 1, 0, 0, 0, DateTimeKind.Utc);
|
|
}
|
|
|
|
/// <summary>
|
|
/// 获取当前时间
|
|
/// </summary>
|
|
public DateTime UtcNow => _currentTime;
|
|
|
|
/// <summary>
|
|
/// 前进指定的时间
|
|
/// </summary>
|
|
public void Advance(TimeSpan duration)
|
|
{
|
|
_currentTime = _currentTime.Add(duration);
|
|
}
|
|
|
|
/// <summary>
|
|
/// 设置当前时间
|
|
/// </summary>
|
|
public void SetTime(DateTime time)
|
|
{
|
|
_currentTime = time;
|
|
}
|
|
} |