/* * Copyright (c) 2001, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License version 2 only, as * published by the Free Software Foundation. * * This code is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License * version 2 for more details (a copy is included in the LICENSE file that * accompanied this code). * * You should have received a copy of the GNU General Public License version * 2 along with this work; if not, write to the Free Software Foundation, * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. * * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA * or visit www.oracle.com if you need additional information or have any * questions. */ package nsk.share; /** * Terminator is used to terminate a stress test with PASS exit status * before the test is terminated as timed out (and so failed). * *
Terminator class holds a thread which sleeps for the given amount * of time, and then wakes up and executes System.exit() * with the given exit status. That thread is daemon, so it doesn't * prevent application from exiting once all its threads finish * before it's time for termination. Appointing terminator in zero * delay implies immediate exit(). * *
There is a limitation: you may appoint no more than one terminator * per application. */ public class Terminator { /** * Use specific appoint() method to appoint terminator. * * @see #appoint(int) * @see #appoint(int,int) */ protected Terminator() {} /** * One terminator per application, or null (by default). */ private static Thread terminator = null; /** *
Return timeout (or waittime) value munus the margin * value (which is assumed 1 minute by default). * *
Treat args[0] as $TIMEOUT value, or seek for * -waittime=$WAITTIME value. If both parameters * (or either none of them) are assigned, throw an exception to * report parameters inconsistency. * *
Also, seek for -margin=... assignment, or assume margin
* is 1 minute.
*
* @param args Is usually obtained via the application's command-line.
*
* @throws IllegalArgumentException If args[] is inconsistent.
*
* @see #appoint(int)
* @see #appoint(int,int)
*/
public static int parseAppointment(String args[]) {
int timeout=-1, margin=1;
int timeouts=0, waittimes=0, margins=0;
for (int i=0; i