FileDocCategorySizeDatePackage
RFATestCase.javaAPI DocApache log4j 1.2.158009Sat Aug 25 00:09:34 BST 2007org.apache.log4j

RFATestCase

public class RFATestCase extends TestCase
Test of RollingFileAppender.
author
Curt Arnold

Fields Summary
Constructors Summary
public RFATestCase(String name)

    super(name);
  
Methods Summary
public voidtearDown()

      LogManager.resetConfiguration();
  
public voidtest1()
Test basic rolling functionality using property file configuration.

     Logger logger = Logger.getLogger(RFATestCase.class);
      PropertyConfigurator.configure("input/RFA1.properties");

      // Write exactly 10 bytes with each log
      for (int i = 0; i < 25; i++) {
        if (i < 10) {
          logger.debug("Hello---" + i);
        } else if (i < 100) {
          logger.debug("Hello--" + i);
        }
      }

      assertTrue(new File("output/RFA-test1.log").exists());
      assertTrue(new File("output/RFA-test1.log.1").exists());
    
public voidtest2()
Test basic rolling functionality using API configuration.

      Logger logger = Logger.getLogger(RFATestCase.class);
      Logger root = Logger.getRootLogger();
      PatternLayout layout = new PatternLayout("%m\n");
      org.apache.log4j.RollingFileAppender rfa =
        new org.apache.log4j.RollingFileAppender();
      rfa.setName("ROLLING");
      rfa.setLayout(layout);
      rfa.setAppend(false);
      rfa.setMaxBackupIndex(3);
      rfa.setMaximumFileSize(100);
      rfa.setFile("output/RFA-test2.log");
      rfa.activateOptions();
      root.addAppender(rfa);

      // Write exactly 10 bytes with each log
      for (int i = 0; i < 55; i++) {
        if (i < 10) {
          logger.debug("Hello---" + i);
        } else if (i < 100) {
          logger.debug("Hello--" + i);
        }
      }

      assertTrue(new File("output/RFA-test2.log").exists());
      assertTrue(new File("output/RFA-test2.log.1").exists());
      assertTrue(new File("output/RFA-test2.log.2").exists());
      assertTrue(new File("output/RFA-test2.log.3").exists());
      assertFalse(new File("output/RFA-test2.log.4").exists());
    
public voidtest2ParamConstructor()
Tests 2 parameter constructor.

throws
IOException if IOException during test.

        SimpleLayout layout = new SimpleLayout();
        RollingFileAppender appender =
                new RollingFileAppender(layout,"output/rfa_2param.log");
        assertEquals(1, appender.getMaxBackupIndex());
        assertEquals(10*1024*1024, appender.getMaximumFileSize());
    
public voidtest3ParamConstructor()
Tests 3 parameter constructor.

throws
IOException if IOException during test.

        SimpleLayout layout = new SimpleLayout();
        RollingFileAppender appender =
                new RollingFileAppender(layout,"output/rfa_3param.log", false);
        assertEquals(1, appender.getMaxBackupIndex());
    
public voidtestLockDotOne()
Test locking of .1 file.

      Logger logger = Logger.getLogger(RFATestCase.class);
      Logger root = Logger.getRootLogger();
      PatternLayout layout = new PatternLayout("%m\n");
      org.apache.log4j.RollingFileAppender rfa =
        new org.apache.log4j.RollingFileAppender();
      rfa.setName("ROLLING");
      rfa.setLayout(layout);
      rfa.setAppend(false);
      rfa.setMaxBackupIndex(10);
      rfa.setMaximumFileSize(100);
      rfa.setFile("output/RFA-dot1.log");
      rfa.activateOptions();
      root.addAppender(rfa);

      new File("output/RFA-dot1.log.2").delete();

      FileWriter dot1 = new FileWriter("output/RFA-dot1.log.1");
      dot1.write("Locked file");
      FileWriter dot5 = new FileWriter("output/RFA-dot1.log.5");
      dot5.write("Unlocked file");
      dot5.close();

      // Write exactly 10 bytes with each log
      for (int i = 0; i < 15; i++) {
        if (i < 10) {
          logger.debug("Hello---" + i);
        } else if (i < 100) {
          logger.debug("Hello--" + i);
        }
      }
      dot1.close();

      for (int i = 15; i < 25; i++) {
            logger.debug("Hello--" + i);
      }
      rfa.close();


      assertTrue(new File("output/RFA-dot1.log.7").exists());
      //
      //     if .2 is the locked file then
      //       renaming wasn't successful until the file was closed
      if (new File("output/RFA-dot1.log.2").length() < 15) {
          assertEquals(50, new File("output/RFA-dot1.log").length());
          assertEquals(200, new File("output/RFA-dot1.log.1").length());
      } else {
          assertTrue(new File("output/RFA-dot1.log").exists());
          assertTrue(new File("output/RFA-dot1.log.1").exists());
          assertTrue(new File("output/RFA-dot1.log.2").exists());
          assertTrue(new File("output/RFA-dot1.log.3").exists());
          assertFalse(new File("output/RFA-dot1.log.4").exists());
      }
    
public voidtestLockDotThree()
Test locking of .3 file.

      Logger logger = Logger.getLogger(RFATestCase.class);
      Logger root = Logger.getRootLogger();
      PatternLayout layout = new PatternLayout("%m\n");
      org.apache.log4j.RollingFileAppender rfa =
        new org.apache.log4j.RollingFileAppender();
      rfa.setName("ROLLING");
      rfa.setLayout(layout);
      rfa.setAppend(false);
      rfa.setMaxBackupIndex(10);
      rfa.setMaximumFileSize(100);
      rfa.setFile("output/RFA-dot3.log");
      rfa.activateOptions();
      root.addAppender(rfa);

      new File("output/RFA-dot3.log.1").delete();
      new File("output/RFA-dot3.log.2").delete();
      new File("output/RFA-dot3.log.4").delete();

      FileWriter dot3 = new FileWriter("output/RFA-dot3.log.3");
      dot3.write("Locked file");
      FileWriter dot5 = new FileWriter("output/RFA-dot3.log.5");
      dot5.write("Unlocked file");
      dot5.close();

      // Write exactly 10 bytes with each log
      for (int i = 0; i < 15; i++) {
        if (i < 10) {
          logger.debug("Hello---" + i);
        } else if (i < 100) {
          logger.debug("Hello--" + i);
        }
      }
      dot3.close();

      for (int i = 15; i < 35; i++) {
          logger.debug("Hello--" + i);
      }
      rfa.close();

      assertTrue(new File("output/RFA-dot3.log.8").exists());
      //
      //     if .3 is the locked file then
      //       renaming wasn't successful until file was closed
      if (new File("output/RFA-dot3.log.5").exists()) {
          assertEquals(50, new File("output/RFA-dot3.log").length());
          assertEquals(100, new File("output/RFA-dot3.log.1").length());
          assertEquals(200, new File("output/RFA-dot3.log.2").length());
      } else {
          assertTrue(new File("output/RFA-dot3.log").exists());
          assertTrue(new File("output/RFA-dot3.log.1").exists());
          assertTrue(new File("output/RFA-dot3.log.2").exists());
          assertTrue(new File("output/RFA-dot3.log.3").exists());
          assertFalse(new File("output/RFA-dot3.log.4").exists());
      }