mirror of
https://github.com/Sonarr/Sonarr.git
synced 2024-11-01 08:22:35 +01:00
07458529f6
cleaned up unit test logging
52 lines
1.3 KiB
C#
52 lines
1.3 KiB
C#
using System;
|
|
using System.Web;
|
|
using System.Web.Caching;
|
|
using NLog;
|
|
using NzbDrone.Core.Providers.Jobs;
|
|
|
|
namespace NzbDrone.Core
|
|
{
|
|
public class WebTimer
|
|
{
|
|
private readonly JobProvider _jobProvider;
|
|
|
|
private static CacheItemRemovedCallback _onCacheRemove;
|
|
private static bool _stop;
|
|
|
|
private static readonly Logger Logger = LogManager.GetCurrentClassLogger();
|
|
|
|
|
|
|
|
public WebTimer(JobProvider jobProvider)
|
|
{
|
|
_jobProvider = jobProvider;
|
|
}
|
|
|
|
//TODO: Make timer doesn't keep running during unit tests.
|
|
public void StartTimer(int secondInterval)
|
|
{
|
|
_onCacheRemove = new CacheItemRemovedCallback(DoWork);
|
|
|
|
HttpRuntime.Cache.Insert(GetType().ToString(), secondInterval, null,
|
|
DateTime.Now.AddSeconds(secondInterval), Cache.NoSlidingExpiration,
|
|
CacheItemPriority.NotRemovable, _onCacheRemove);
|
|
}
|
|
|
|
|
|
public void DoWork(string k, object v, CacheItemRemovedReason r)
|
|
{
|
|
if (!_stop)
|
|
{
|
|
_jobProvider.QueueScheduled();
|
|
StartTimer(Convert.ToInt32(v));
|
|
}
|
|
}
|
|
|
|
public static void Stop()
|
|
{
|
|
Logger.Info("Stopping Web Timer");
|
|
_stop = true;
|
|
}
|
|
}
|
|
}
|