#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 { /// /// 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 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(); 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"); } } }