From 521727b6f715a6bbbc206456b659d69daf33d9bb Mon Sep 17 00:00:00 2001 From: rtrimana Date: Tue, 20 Apr 2021 09:16:33 -0700 Subject: [PATCH] Fixing a few bugs in the statistics printout. --- .../listener/DPORStateReducerWithSummary.java | 28 +++++++++++++++++++ 1 file changed, 28 insertions(+) diff --git a/src/main/gov/nasa/jpf/listener/DPORStateReducerWithSummary.java b/src/main/gov/nasa/jpf/listener/DPORStateReducerWithSummary.java index 6402577..7c6ed74 100755 --- a/src/main/gov/nasa/jpf/listener/DPORStateReducerWithSummary.java +++ b/src/main/gov/nasa/jpf/listener/DPORStateReducerWithSummary.java @@ -45,6 +45,8 @@ import java.util.logging.Logger; public class DPORStateReducerWithSummary extends ListenerAdapter { // Information printout fields for verbose mode + private long startTime; + private long timeout; private boolean verboseMode; private boolean stateReductionMode; private final PrintWriter out; @@ -113,6 +115,10 @@ public class DPORStateReducerWithSummary extends ListenerAdapter { stateToPredInfo = new HashMap<>(); stateToUniqueTransMap = new HashMap<>(); initializeStatesVariables(); + + // Timeout input from config is in minutes, so we need to convert into millis + timeout = config.getInt("timeout", 0) * 60 * 1000; + startTime = System.currentTimeMillis(); } @Override @@ -182,11 +188,23 @@ public class DPORStateReducerWithSummary extends ListenerAdapter { int summaryOfUniqueTransitions = summarizeUniqueTransitions(); out.println("\n==> DEBUG: ----------------------------------- search finished"); out.println("\n==> DEBUG: State reduction mode : " + stateReductionMode); + if (choices != null) { + out.println("\n==> DEBUG: Number of events : " + choices.length); + } else { + // Without DPOR we don't have choices being assigned with a CG + out.println("\n==> DEBUG: Number of events : 0"); + } out.println("\n==> DEBUG: Number of transitions : " + numOfTransitions); out.println("\n==> DEBUG: Number of unique transitions (DPOR) : " + summaryOfUniqueTransitions); out.println("\n==> DEBUG: ----------------------------------- search finished" + "\n"); fileWriter.println("==> DEBUG: State reduction mode : " + stateReductionMode); + if (choices != null) { + fileWriter.println("==> DEBUG: Number of events : " + choices.length); + } else { + // Without DPOR we don't have choices being assigned with a CG + fileWriter.println("==> DEBUG: Number of events : 0"); + } fileWriter.println("==> DEBUG: Number of transitions : " + numOfTransitions); fileWriter.println("==> DEBUG: Number of unique transitions (DPOR) : " + summaryOfUniqueTransitions); fileWriter.println(); @@ -284,6 +302,16 @@ public class DPORStateReducerWithSummary extends ListenerAdapter { @Override public void instructionExecuted(VM vm, ThreadInfo ti, Instruction nextInsn, Instruction executedInsn) { + // Check the timeout + if (timeout > 0) { + if (System.currentTimeMillis() - startTime > timeout) { + StringBuilder sbTimeOut = new StringBuilder(); + sbTimeOut.append("Execution timeout: " + (timeout / (60 * 1000)) + " minutes have passed!"); + Instruction nextIns = ti.createAndThrowException("java.lang.RuntimeException", sbTimeOut.toString()); + ti.setNextPC(nextIns); + } + } + if (stateReductionMode) { if (!isEndOfExecution) { // Has to be initialized and it is a integer CG -- 2.34.1