1   /*
2    * Logback: the reliable, generic, fast and flexible logging framework.
3    * Copyright (C) 1999-2024, QOS.ch. All rights reserved.
4    *
5    * This program and the accompanying materials are dual-licensed under
6    * either the terms of the Eclipse Public License v1.0 as published by
7    * the Eclipse Foundation
8    *
9    *   or (per the licensee's choosing)
10   *
11   * under the terms of the GNU Lesser General Public License version 2.1
12   * as published by the Free Software Foundation.
13   */
14  package ch.qos.logback.classic.blackbox.issue.lbclassic135;
15  
16  import org.slf4j.Logger;
17  import ch.qos.logback.core.testUtil.RunnableWithCounterAndDone;
18  
19  public class LoggingRunnable extends RunnableWithCounterAndDone {
20  
21      final Logger logger;
22      final int burstLength;
23  
24      public LoggingRunnable(Logger logger, int burstLength) {
25          this.logger = logger;
26          this.burstLength = burstLength;
27      }
28  
29      public LoggingRunnable(Logger logger) {
30          this(logger, 10);
31      }
32  
33      public void run() {
34          while (!isDone()) {
35              logger.info("hello world ABCDEFGHI");
36              counter++;
37              // don't hog the CPU forever
38              if (counter % burstLength == 0) {
39                  try {
40                      Thread.sleep(1);
41                  } catch (InterruptedException e) {
42                      e.printStackTrace();
43                  }
44              }
45          }
46      }
47  
48  }