#region Copyright & License
//
// Copyright 2001-2005 The Apache Software Foundation
//
// Licensed 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.Core;
using log4net.Appender;
using NUnit.Framework;
namespace log4net.Tests.Appender
{
///
/// Used for internal unit testing the class.
///
///
/// Used for internal unit testing the class.
///
[TestFixture] public class BufferingAppenderTest
{
private BufferingForwardingAppender m_bufferingForwardingAppender;
private CountingAppender m_countingAppender;
private log4net.Repository.Hierarchy.Hierarchy m_hierarchy;
private void SetupRepository()
{
m_hierarchy = new Repository.Hierarchy.Hierarchy();
m_countingAppender = new CountingAppender();
m_countingAppender.ActivateOptions();
m_bufferingForwardingAppender = new BufferingForwardingAppender();
m_bufferingForwardingAppender.AddAppender(m_countingAppender);
m_bufferingForwardingAppender.BufferSize = 0;
m_bufferingForwardingAppender.ClearFilters();
m_bufferingForwardingAppender.Evaluator = null;
m_bufferingForwardingAppender.Fix = FixFlags.Partial;
m_bufferingForwardingAppender.Lossy = false;
m_bufferingForwardingAppender.LossyEvaluator = null;
m_bufferingForwardingAppender.Threshold = Level.All;
m_bufferingForwardingAppender.ActivateOptions();
log4net.Config.BasicConfigurator.Configure(m_hierarchy, m_bufferingForwardingAppender);
}
///
///
[Test] public void TestSetupAppender()
{
SetupRepository();
Assert.AreEqual(0, m_countingAppender.Counter, "Test empty appender");
ILogger logger = m_hierarchy.GetLogger("test");
logger.Log(typeof(BufferingAppenderTest), Level.Warn, "Message logged", null);
Assert.AreEqual(1, m_countingAppender.Counter, "Test 1 event logged");
}
///
///
[Test] public void TestBufferSize5()
{
SetupRepository();
m_bufferingForwardingAppender.BufferSize = 5;
m_bufferingForwardingAppender.ActivateOptions();
Assert.AreEqual(m_countingAppender.Counter, 0);
ILogger logger = m_hierarchy.GetLogger("test");
logger.Log(typeof(BufferingAppenderTest), Level.Warn, "Message 1", null);
Assert.AreEqual(0, m_countingAppender.Counter, "Test 1 event in buffer");
logger.Log(typeof(BufferingAppenderTest), Level.Warn, "Message 2", null);
Assert.AreEqual(0, m_countingAppender.Counter, "Test 2 event in buffer");
logger.Log(typeof(BufferingAppenderTest), Level.Warn, "Message 3", null);
Assert.AreEqual(0, m_countingAppender.Counter, "Test 3 event in buffer");
logger.Log(typeof(BufferingAppenderTest), Level.Warn, "Message 4", null);
Assert.AreEqual(0, m_countingAppender.Counter, "Test 4 event in buffer");
logger.Log(typeof(BufferingAppenderTest), Level.Warn, "Message 5", null);
Assert.AreEqual(0, m_countingAppender.Counter, "Test 5 event in buffer");
logger.Log(typeof(BufferingAppenderTest), Level.Warn, "Message 6", null);
Assert.AreEqual(6, m_countingAppender.Counter, "Test 0 event in buffer. 6 event sent");
logger.Log(typeof(BufferingAppenderTest), Level.Warn, "Message 7", null);
Assert.AreEqual(6, m_countingAppender.Counter, "Test 1 event in buffer. 6 event sent");
logger.Log(typeof(BufferingAppenderTest), Level.Warn, "Message 8", null);
Assert.AreEqual(6, m_countingAppender.Counter, "Test 2 event in buffer. 6 event sent");
}
}
}