55 instantiations of LogBufferingFilterRule
Microsoft.AspNetCore.Diagnostics.Middleware (1)
Buffering\PerIncomingRequestLoggingBuilderExtensions.cs (1)
100options.Rules.Add(new LogBufferingFilterRule(logLevel: logLevel));
Microsoft.AspNetCore.Diagnostics.Middleware.Tests (13)
Buffering\PerIncomingRequestLoggingBuilderExtensionsTests.cs (9)
57new(categoryName: "Program.MyLogger", logLevel: LogLevel.Information, eventId: 1, eventName: "number one"), 58new(logLevel: LogLevel.Information), 77new(categoryName: "Program.MyLogger", logLevel: LogLevel.Information, eventId: 1, eventName: "number one"), 78new(logLevel: LogLevel.Information), 83options.Rules.Add(new LogBufferingFilterRule(categoryName: "Program.MyLogger", 85options.Rules.Add(new LogBufferingFilterRule(logLevel: LogLevel.Information)); 99new(categoryName: "Program.MyLogger", logLevel: LogLevel.Information, eventId: 1, eventName: "number one"), 100new(logLevel : LogLevel.Information), 104new(logLevel: LogLevel.Information),
Buffering\PerRequestLogBufferingOptionsCustomValidatorTests.cs (1)
21new LogBufferingFilterRule(categoryName: "**")
Logging\AcceptanceTests.cs (3)
867options.Rules.Add(new LogBufferingFilterRule(logLevel: LogLevel.Debug)); 916options.Rules.Add(new LogBufferingFilterRule(logLevel: LogLevel.Debug)); 917options.Rules.Add(new LogBufferingFilterRule(logLevel: LogLevel.Debug, categoryName: "logatrequest"));
Microsoft.Extensions.Telemetry (1)
Buffering\GlobalBufferLoggingBuilderExtensions.cs (1)
86.Configure(options => options.Rules.Add(new LogBufferingFilterRule(logLevel: logLevel)));
Microsoft.Extensions.Telemetry.Tests (40)
Buffering\GlobalBufferLoggerBuilderExtensionsTests.cs (5)
48new ("Program.MyLogger", LogLevel.Information, 1, "number one", [new("region", "westus2"), new ("priority", 1)]), 49new (logLevel: LogLevel.Information), 78new(categoryName: "Program.MyLogger", logLevel: LogLevel.Information, eventId: 1, eventName: "number one"), 79new(logLevel : LogLevel.Information), 83new(logLevel: LogLevel.Information),
Buffering\GlobalLogBufferingOptionsCustomValidatorTests.cs (1)
20new LogBufferingFilterRule(categoryName: "**")
Buffering\LogBufferingFilterRuleTests.cs (33)
21new LogBufferingFilterRule(), 22new LogBufferingFilterRule(eventId: 1), 23new LogBufferingFilterRule(logLevel: LogLevel.Information, eventId: 1), 24new LogBufferingFilterRule(logLevel: LogLevel.Information, eventId: 1), 25new LogBufferingFilterRule(logLevel: LogLevel.Warning), 26new LogBufferingFilterRule(logLevel: LogLevel.Warning, eventId: 2), 27new LogBufferingFilterRule(logLevel: LogLevel.Warning, eventId: 1), 28new LogBufferingFilterRule("Program1.MyLogger", LogLevel.Warning, 1), 29new LogBufferingFilterRule("Program.*MyLogger1", LogLevel.Warning, 1), 30new LogBufferingFilterRule("Program.MyLogger", LogLevel.Warning, 1, attributes: [new("region2", "westus2")]), // inapplicable key 31new LogBufferingFilterRule("Program.MyLogger", LogLevel.Warning, 1, attributes:[new("region", "westus3")]), // inapplicable value 32new LogBufferingFilterRule("Program.MyLogger", LogLevel.Warning, 1, attributes:[new("region", "westus2")]), // the best rule - [11] 33new LogBufferingFilterRule("Program.MyLogger", LogLevel.Warning, 2), 34new LogBufferingFilterRule("Program.MyLogger", eventId: 1), 35new LogBufferingFilterRule(logLevel: LogLevel.Warning, eventId: 1), 36new LogBufferingFilterRule("Program", LogLevel.Warning, 1), 37new LogBufferingFilterRule("Program.MyLogger", LogLevel.Warning), 38new LogBufferingFilterRule("Program.MyLogger", LogLevel.Error, 1), 59new LogBufferingFilterRule(logLevel: LogLevel.Information, eventId: 1), 60new LogBufferingFilterRule(logLevel: LogLevel.Information, eventId: 1), 61new LogBufferingFilterRule(logLevel: LogLevel.Warning), 62new LogBufferingFilterRule(logLevel: LogLevel.Warning, eventId: 2), 63new LogBufferingFilterRule(logLevel: LogLevel.Warning, eventId: 1), 64new LogBufferingFilterRule("Program1.MyLogger", LogLevel.Warning, 1), 65new LogBufferingFilterRule("Program.*MyLogger1", LogLevel.Warning, 1), 66new LogBufferingFilterRule("Program.MyLogger", LogLevel.Warning, 1), 67new LogBufferingFilterRule("Program.MyLogger*", LogLevel.Warning, 1), 68new LogBufferingFilterRule("Program.MyLogger", LogLevel.Warning, 1, attributes:[new("region", "westus2")]), // the best rule 69new LogBufferingFilterRule("Program.MyLogger*", LogLevel.Warning, 1, attributes:[new("region", "westus2")]), // same as the best, but last and should be selected 86new LogBufferingFilterRule("Program.MyLogger", LogLevel.Warning, 1, attributes:[new("priority", 1)]), 87new LogBufferingFilterRule("Program.MyLogger", LogLevel.Warning, 1, attributes:[new("priority", 2)]), // the best rule 88new LogBufferingFilterRule("Program.MyLogger", LogLevel.Warning, 1, attributes:[new("priority", 3)]), 89new LogBufferingFilterRule("Program.MyLogger", LogLevel.Warning, 1),
Logging\ExtendedLoggerTests.cs (1)
995options.Rules.Add(new LogBufferingFilterRule(logLevel: LogLevel.Warning));
51 references to LogBufferingFilterRule
Microsoft.AspNetCore.Diagnostics.Middleware (5)
Buffering\IncomingRequestLogBuffer.cs (1)
29private readonly LogBufferingFilterRule[] _filterRules;
Buffering\PerRequestLogBufferingConfigureOptions.cs (1)
43foreach (LogBufferingFilterRule rule in parsedOptions.Rules)
Buffering\PerRequestLogBufferingOptions.cs (2)
62/// Gets or sets the collection of <see cref="LogBufferingFilterRule"/> used for filtering log messages for the purpose of further buffering. 72public IList<LogBufferingFilterRule> Rules { get; set; } = [];
Buffering\PerRequestLogBufferingOptionsCustomValidator.cs (1)
18foreach (LogBufferingFilterRule rule in options.Rules)
Microsoft.AspNetCore.Diagnostics.Middleware.Tests (5)
Buffering\PerIncomingRequestLoggingBuilderExtensionsTests.cs (4)
55List<LogBufferingFilterRule> expectedData = 75List<LogBufferingFilterRule> expectedData = 97List<LogBufferingFilterRule> initialData = 102List<LogBufferingFilterRule> updatedData =
Buffering\PerRequestLogBufferingOptionsCustomValidatorTests.cs (1)
19Rules = new List<LogBufferingFilterRule>
Microsoft.Extensions.Telemetry (28)
Buffering\GlobalBuffer.cs (1)
20internal LogBufferingFilterRule[] LastKnownGoodFilterRules;
Buffering\GlobalLogBufferingConfigureOptions.cs (1)
43foreach (LogBufferingFilterRule rule in parsedOptions.Rules)
Buffering\GlobalLogBufferingOptions.cs (2)
61/// Gets or sets the collection of <see cref="LogBufferingFilterRule"/> used for filtering log messages for the purpose of further buffering. 70public IList<LogBufferingFilterRule> Rules { get; set; } = [];
Buffering\GlobalLogBufferingOptionsCustomValidator.cs (1)
17foreach (LogBufferingFilterRule rule in options.Rules)
Buffering\LogBufferingFilterRule.cs (1)
21/// Initializes a new instance of the <see cref="LogBufferingFilterRule"/> class.
Buffering\LogBufferingFilterRuleSelector.cs (22)
24private static readonly ObjectPool<List<LogBufferingFilterRule>> _rulePool = 25PoolFactory.CreateListPool<LogBufferingFilterRule>(); 27private readonly ObjectPool<List<LogBufferingFilterRule>> _cachedRulePool = 28PoolFactory.CreateListPool<LogBufferingFilterRule>(); 29private readonly ConcurrentDictionary<(LogLevel, EventId), List<LogBufferingFilterRule>> _ruleCache = new(); 31public static LogBufferingFilterRule[] SelectByCategory(IList<LogBufferingFilterRule> rules, string category) 33List<LogBufferingFilterRule> rulesOfCategory = _rulePool.Get(); 37foreach (LogBufferingFilterRule rule in rules) 55foreach (((LogLevel, EventId) key, List<LogBufferingFilterRule> value) in _ruleCache) 63public LogBufferingFilterRule? Select( 64IList<LogBufferingFilterRule> rules, 70List<LogBufferingFilterRule> ruleCandidates = _ruleCache.GetOrAdd((logLevel, eventId), _ => 72List<LogBufferingFilterRule> candidates = _cachedRulePool.Get(); 73foreach (LogBufferingFilterRule rule in rules) 85LogBufferingFilterRule? currentBest = null; 86foreach (LogBufferingFilterRule ruleCandidate in ruleCandidates) 97private static bool IsAttributesMatch(LogBufferingFilterRule rule, IReadOnlyList<KeyValuePair<string, object?>>? attributes) 114private static bool IsBetter(LogBufferingFilterRule? currentBest, LogBufferingFilterRule ruleCandidate) 133private static bool IsMatch(LogBufferingFilterRule rule, string category) 166private static bool IsMatch(LogBufferingFilterRule rule, LogLevel logLevel, EventId eventId)
Microsoft.Extensions.Telemetry.Tests (13)
Buffering\GlobalBufferLoggerBuilderExtensionsTests.cs (3)
46List<LogBufferingFilterRule> expectedData = 76List<LogBufferingFilterRule> initialData = 81List<LogBufferingFilterRule> updatedData =
Buffering\GlobalLogBufferingOptionsCustomValidatorTests.cs (1)
18Rules = new List<LogBufferingFilterRule>
Buffering\LogBufferingFilterRuleTests.cs (9)
19var rules = new List<LogBufferingFilterRule> 42LogBufferingFilterRule[] categorySpecificRules = LogBufferingFilterRuleSelector.SelectByCategory(rules, "Program.MyLogger"); 43LogBufferingFilterRule? result = _selector.Select( 57var rules = new List<LogBufferingFilterRule> 73LogBufferingFilterRule[] categorySpecificRules = LogBufferingFilterRuleSelector.SelectByCategory(rules, "Program.MyLogger"); 74LogBufferingFilterRule? result = _selector.Select(categorySpecificRules, LogLevel.Warning, 1, [new("region", "westus2")]); 84var rules = new List<LogBufferingFilterRule> 93LogBufferingFilterRule[] categorySpecificRules = LogBufferingFilterRuleSelector.SelectByCategory(rules, "Program.MyLogger"); 94LogBufferingFilterRule? result = _selector.Select(categorySpecificRules, LogLevel.Warning, 1, [new("priority", "2")]);