001/* 002 * Logback: the reliable, generic, fast and flexible logging framework. 003 * Copyright (C) 1999-2024, QOS.ch. All rights reserved. 004 * 005 * This program and the accompanying materials are dual-licensed under 006 * either the terms of the Eclipse Public License v1.0 as published by 007 * the Eclipse Foundation 008 * 009 * or (per the licensee's choosing) 010 * 011 * under the terms of the GNU Lesser General Public License version 2.1 012 * as published by the Free Software Foundation. 013 */ 014package ch.qos.logback.core.testUtil; 015 016abstract public class AbstractMultiThreadedHarness { 017 018 abstract public void waitUntilEndCondition() throws InterruptedException; 019 020 public void execute(RunnableWithCounterAndDone[] runnableArray) throws InterruptedException { 021 Thread[] threadArray = new Thread[runnableArray.length]; 022 023 for (int i = 0; i < runnableArray.length; i++) { 024 System.out.println("Starting "+runnableArray[i]); 025 threadArray[i] = new Thread(runnableArray[i], "Harness[" + i + "]"); 026 } 027 for (Thread t : threadArray) { 028 t.start(); 029 } 030 031 waitUntilEndCondition(); 032 for (RunnableWithCounterAndDone r : runnableArray) { 033 r.setDone(true); 034 } 035 for (Thread t : threadArray) { 036 t.join(); 037 } 038 } 039}