blob: 6a9cf1d51e853275ef882065664eadf7f78d7369 [file] [log] [blame]
#region Apache License
//
// Licensed to the Apache Software Foundation (ASF) under one or more
// contributor license agreements. See the NOTICE file distributed with
// this work for additional information regarding copyright ownership.
// The ASF licenses this file to you under the Apache License, Version 2.0
// (the "License"); you may not use this file except in compliance with
// the License. You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
//
#endregion
using log4net.Appender;
using log4net.Config;
using log4net.Core;
using NUnit.Framework;
namespace log4net.Tests.Appender;
/// <summary>
/// Used for internal unit testing the <see cref="BufferingAppenderSkeleton"/> class.
/// </summary>
[TestFixture]
public class BufferingAppenderTest
{
private BufferingForwardingAppender _bufferingForwardingAppender = new();
private CountingAppender _countingAppender = new();
private Repository.Hierarchy.Hierarchy _hierarchy = new();
private void SetupRepository()
{
_hierarchy = new Repository.Hierarchy.Hierarchy();
_countingAppender = new CountingAppender();
_countingAppender.ActivateOptions();
_bufferingForwardingAppender = new BufferingForwardingAppender();
_bufferingForwardingAppender.AddAppender(_countingAppender);
_bufferingForwardingAppender.BufferSize = 0;
_bufferingForwardingAppender.ClearFilters();
_bufferingForwardingAppender.Evaluator = null;
_bufferingForwardingAppender.Fix = FixFlags.Partial;
_bufferingForwardingAppender.Lossy = false;
_bufferingForwardingAppender.LossyEvaluator = null;
_bufferingForwardingAppender.Threshold = Level.All;
_bufferingForwardingAppender.ActivateOptions();
BasicConfigurator.Configure(_hierarchy, _bufferingForwardingAppender);
}
[Test]
public void TestSetupAppender()
{
SetupRepository();
Assert.That(_countingAppender.Counter, Is.EqualTo(0), "Test empty appender");
ILogger logger = _hierarchy.GetLogger("test");
logger.Log(typeof(BufferingAppenderTest), Level.Warn, "Message logged", null);
Assert.That(_countingAppender.Counter, Is.EqualTo(1), "Test 1 event logged");
}
[Test]
public void TestBufferSize5()
{
SetupRepository();
_bufferingForwardingAppender.BufferSize = 5;
_bufferingForwardingAppender.ActivateOptions();
Assert.That(_countingAppender.Counter, Is.EqualTo(0));
ILogger logger = _hierarchy.GetLogger("test");
logger.Log(typeof(BufferingAppenderTest), Level.Warn, "Message 1", null);
Assert.That(_countingAppender.Counter, Is.EqualTo(0), "Test 1 event in buffer");
logger.Log(typeof(BufferingAppenderTest), Level.Warn, "Message 2", null);
Assert.That(_countingAppender.Counter, Is.EqualTo(0), "Test 2 event in buffer");
logger.Log(typeof(BufferingAppenderTest), Level.Warn, "Message 3", null);
Assert.That(_countingAppender.Counter, Is.EqualTo(0), "Test 3 event in buffer");
logger.Log(typeof(BufferingAppenderTest), Level.Warn, "Message 4", null);
Assert.That(_countingAppender.Counter, Is.EqualTo(0), "Test 4 event in buffer");
logger.Log(typeof(BufferingAppenderTest), Level.Warn, "Message 5", null);
Assert.That(_countingAppender.Counter, Is.EqualTo(0), "Test 5 event in buffer");
logger.Log(typeof(BufferingAppenderTest), Level.Warn, "Message 6", null);
Assert.That(_countingAppender.Counter, Is.EqualTo(6), "Test 0 event in buffer. 6 event sent");
logger.Log(typeof(BufferingAppenderTest), Level.Warn, "Message 7", null);
Assert.That(_countingAppender.Counter, Is.EqualTo(6), "Test 1 event in buffer. 6 event sent");
logger.Log(typeof(BufferingAppenderTest), Level.Warn, "Message 8", null);
Assert.That(_countingAppender.Counter, Is.EqualTo(6), "Test 2 event in buffer. 6 event sent");
}
}