Path: blob/master/test/functional/cmdline_options_tester/src/Stopwatch.java
6004 views
/*******************************************************************************1* Copyright (c) 2004, 2019 IBM Corp. and others2*3* This program and the accompanying materials are made available under4* the terms of the Eclipse Public License 2.0 which accompanies this5* distribution and is available at https://www.eclipse.org/legal/epl-2.0/6* or the Apache License, Version 2.0 which accompanies this distribution and7* is available at https://www.apache.org/licenses/LICENSE-2.0.8*9* This Source Code may also be made available under the following10* Secondary Licenses when the conditions for such availability set11* forth in the Eclipse Public License, v. 2.0 are satisfied: GNU12* General Public License, version 2 with the GNU Classpath13* Exception [1] and GNU General Public License, version 2 with the14* OpenJDK Assembly Exception [2].15*16* [1] https://www.gnu.org/software/classpath/license.html17* [2] http://openjdk.java.net/legal/assembly-exception.html18*19* SPDX-License-Identifier: EPL-2.0 OR Apache-2.0 OR GPL-2.0 WITH Classpath-exception-2.0 OR LicenseRef-GPL-2.0 WITH Assembly-exception20*******************************************************************************/2122import java.util.*;23import java.io.*;24import java.text.*;2526/**27* STOP watch to calculate time spent in milliseconds in each test28* ToDo: Move to System.nanoTime() instead of System.currentTimeMillis() once test source29* is built with 1.5 or higher.30* Currently millisecond calculation entirely depends on OS update of timer values31* which happens only once in few tens of milliseconds. So getting millisecond directly from os may32* not be accurate.33*34*/35public class Stopwatch {3637private long startTime = -1;38private long stopTime = -1;39private boolean running = false;40private Calendar calendar = Calendar.getInstance();41TimeZone timeZone = calendar.getTimeZone();42DateFormat df = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss");4344public Stopwatch start() {45System.out.println("Test start time: " + df.format(calendar.getTime()) + " " + timeZone.getDisplayName());46startTime = System.currentTimeMillis();47running = true;48return this;49}5051public Stopwatch stop() {52stopTime = System.currentTimeMillis();53running = false;54return this;55}5657/** getTimeSpent will return the elapsed time in milliseconds58* if the watch has never been started then return zero59*/60public long getTimeSpent() {61if (startTime == -1) {62return 0;63}64if (running) {65return System.currentTimeMillis() - startTime;66} else {67return stopTime - startTime;68}69}70}717273