/* // makes nlog go haywire, revisit later * private static readonly CustomTimeSource timeSource = new CustomTimeSource(); * * private class CustomTimeSource : NLog.Time.TimeSource * { * private TimeZoneInfo zoneInfo = TimeZoneInfo.Utc; * * [Required] * public string Zone * { * get { return zoneInfo.DisplayName; } * set { zoneInfo = TimeZoneInfo.FindSystemTimeZoneById(value); } * } * * public override DateTime Time => IPBanService.UtcNow; * * public override DateTime FromSystemTime(DateTime systemTime) * { * return systemTime.ToUniversalTime(); * } * * public DateTime CurrentTime { get; set; } = IPBanService.UtcNow; * } */ static Logger() { try { LogFactory factory = null; try { factory = LogManager.LoadConfiguration(ConfigurationManager.OpenExeConfiguration(ConfigurationUserLevel.None).FilePath); } catch { // if no config, exception is thrown that is OK } if (factory is null || factory.Configuration.AllTargets.Count == 0) { string nlogConfigPath = Path.Combine(AppContext.BaseDirectory, "nlog.config"); if (!File.Exists(nlogConfigPath)) { string logLevel = "Warn"; Console.WriteLine("Creating default nlog.config file"); // storing this as a resource fails to use correct string in precompiled .exe with .net core, bug with Microsoft I think string defaultNLogConfig = $@"<?xml version=""1.0""?> <nlog xmlns=""http://www.nlog-project.org/schemas/NLog.xsd"" xmlns:xsi=""http://www.w3.org/2001/XMLSchema-instance"" throwExceptions=""false"" internalLogToConsole=""false"" internalLogToConsoleError=""false"" internalLogLevel=""Trace""> <targets> <target name=""logfile"" xsi:type=""File"" fileName=""${{basedir}}/logfile.txt"" archiveNumbering=""Sequence"" archiveEvery=""Day"" maxArchiveFiles=""28"" encoding=""UTF-8""/> <target name=""console"" xsi:type=""Console""/> </targets> <rules> <logger name=""*"" minlevel=""{logLevel}"" writeTo=""logfile""/> <logger name=""*"" minlevel=""{logLevel}"" writeTo=""console""/> </rules> </nlog>"; ExtensionMethods.FileWriteAllTextWithRetry(nlogConfigPath, defaultNLogConfig); } if (File.Exists(nlogConfigPath)) { factory = LogManager.LoadConfiguration(nlogConfigPath); } else { throw new IOException("Unable to create nlog configuration file, nlog.config file failed to write default config."); } } nlogInstance = factory.GetCurrentClassLogger(); instance = new NLogWrapper(nlogInstance); if (UnitTestDetector.Running) { foreach (LoggingRule rule in LogManager.Configuration.LoggingRules) { rule.EnableLoggingForLevels(NLog.LogLevel.Trace, NLog.LogLevel.Fatal); } LogManager.ReconfigExistingLoggers(); } //NLog.Time.TimeSource.Current = timeSource; } catch (Exception ex) { // log to console as no other logger is available Console.WriteLine("Failed to initialize logger: {0}", ex); } }
/// <summary> /// Create a test IPBanService /// </summary> /// <param name="directory">Root directory</param> /// <param name="configFileName">Config file name</param> /// <param name="defaultBannedIPAddressHandlerUrl">Url for banned ip handling or null to not handle banned ip</param> /// <param name="configFileModifier">Change config file (param are file text, returns new file text)</param> /// <returns>Service</returns> public static T CreateAndStartIPBanTestService <T>(string directory = null, string configFileName = null, string defaultBannedIPAddressHandlerUrl = null, Func <string, string> configFileModifier = null) where T : IPBanService { NLog.Time.TimeSource.Current = new TestTimeSource(); string defaultNLogConfig = $@"<?xml version=""1.0""?> <nlog xmlns=""http://www.nlog-project.org/schemas/NLog.xsd"" xmlns:xsi=""http://www.w3.org/2001/XMLSchema-instance"" throwExceptions=""false"" internalLogToConsole=""false"" internalLogToConsoleError=""false"" internalLogLevel=""Trace""> <targets> <target name=""logfile"" xsi:type=""File"" fileName=""${{basedir}}/logfile.txt"" encoding=""UTF-8""/> <target name=""console"" xsi:type=""Console""/> </targets> <rules> <logger name=""*"" minlevel=""Debug"" writeTo=""logfile""/> <logger name=""*"" minlevel=""Debug"" writeTo=""console""/> </rules> </nlog>"; File.WriteAllText(Path.Combine(AppContext.BaseDirectory, "nlog.config"), defaultNLogConfig); string logFilePath = Path.Combine(AppContext.BaseDirectory, "logfile.txt"); if (File.Exists(logFilePath)) { File.Delete(logFilePath); } ExtensionMethods.RemoveDatabaseFiles(); DefaultHttpRequestMaker.DisableLiveRequests = true; if (string.IsNullOrWhiteSpace(directory)) { directory = AppContext.BaseDirectory; } if (string.IsNullOrWhiteSpace(configFileName)) { configFileName = IPBanConfig.DefaultFileName; } string configFilePath = Path.Combine(directory, configFileName); string configFileText = File.ReadAllText(configFilePath); configFilePath += ".tmp"; if (configFileModifier != null) { configFileText = configFileModifier(configFileText); } ExtensionMethods.FileWriteAllTextWithRetry(configFilePath, configFileText); T service = IPBanService.CreateService <T>() as T; service.ExternalIPAddressLookup = LocalMachineExternalIPAddressLookupTest.Instance; service.ConfigFilePath = configFilePath; service.MultiThreaded = false; service.ManualCycle = true; service.DnsList = null; // too slow for tests, turn off if (defaultBannedIPAddressHandlerUrl is null) { service.BannedIPAddressHandler = NullBannedIPAddressHandler.Instance; } else { service.BannedIPAddressHandler = new DefaultBannedIPAddressHandler { BaseUrl = defaultBannedIPAddressHandlerUrl }; } service.Version = "1.1.1.1"; service.RunAsync(CancellationToken.None).Sync(); service.RunCycleAsync().Sync(); service.DB.Truncate(true); service.Firewall.Truncate(); return(service); }