0745245
0745245
This patch should fix the logic error in checking for the MaxWaitTime of
0745245
a job in src/dird/job.c.  It fixes bug #802.
0745245
0745245
Apply it to Bacula version 2.0.3 with:
0745245
0745245
  cd <bacula-source>
0745245
  patch -p0 <2.0.3-maxwaittime.patch
0745245
  make
0745245
  ...
0745245
  make install
0745245
0745245
0745245
0745245
Index: src/dird/job.c
0745245
===================================================================
0745245
--- src/dird/job.c	(revision 4349)
0745245
+++ src/dird/job.c	(working copy)
0745245
@@ -481,7 +481,6 @@
0745245
 static bool job_check_maxwaittime(JCR *control_jcr, JCR *jcr)
0745245
 {
0745245
    bool cancel = false;
0745245
-   bool ok_to_cancel = false;
0745245
    JOB *job = jcr->job;
0745245
 
0745245
    if (job_canceled(jcr)) {
0745245
@@ -493,69 +492,18 @@
0745245
    } 
0745245
    if (jcr->JobLevel == L_FULL && job->FullMaxWaitTime != 0 &&
0745245
          (watchdog_time - jcr->start_time) >= job->FullMaxWaitTime) {
0745245
-      ok_to_cancel = true;
0745245
+      cancel = true;
0745245
    } else if (jcr->JobLevel == L_DIFFERENTIAL && job->DiffMaxWaitTime != 0 &&
0745245
          (watchdog_time - jcr->start_time) >= job->DiffMaxWaitTime) {
0745245
-      ok_to_cancel = true;
0745245
+      cancel = true;
0745245
    } else if (jcr->JobLevel == L_INCREMENTAL && job->IncMaxWaitTime != 0 &&
0745245
          (watchdog_time - jcr->start_time) >= job->IncMaxWaitTime) {
0745245
-      ok_to_cancel = true;
0745245
+      cancel = true;
0745245
    } else if (job->MaxWaitTime != 0 &&
0745245
          (watchdog_time - jcr->start_time) >= job->MaxWaitTime) {
0745245
-      ok_to_cancel = true;
0745245
-   }
0745245
-   if (!ok_to_cancel) {
0745245
-      return false;
0745245
-   }
0745245
-
0745245
-/*
0745245
- * I don't see the need for all this -- kes 17Dec06
0745245
- */
0745245
-#ifdef xxx
0745245
-   Dmsg3(800, "Job %d (%s): MaxWaitTime of %d seconds exceeded, "
0745245
-         "checking status\n",
0745245
-         jcr->JobId, jcr->Job, job->MaxWaitTime);
0745245
-   switch (jcr->JobStatus) {
0745245
-   case JS_Created:
0745245
-   case JS_Blocked:
0745245
-   case JS_WaitFD:
0745245
-   case JS_WaitSD:
0745245
-   case JS_WaitStoreRes:
0745245
-   case JS_WaitClientRes:
0745245
-   case JS_WaitJobRes:
0745245
-   case JS_WaitPriority:
0745245
-   case JS_WaitMaxJobs:
0745245
-   case JS_WaitStartTime:
0745245
       cancel = true;
0745245
-      Dmsg0(200, "JCR blocked in #1\n");
0745245
-      break;
0745245
-   case JS_Running:
0745245
-      Dmsg0(800, "JCR running, checking SD status\n");
0745245
-      switch (jcr->SDJobStatus) {
0745245
-      case JS_WaitMount:
0745245
-      case JS_WaitMedia:
0745245
-      case JS_WaitFD:
0745245
-         cancel = true;
0745245
-         Dmsg0(800, "JCR blocked in #2\n");
0745245
-         break;
0745245
-      default:
0745245
-         Dmsg0(800, "JCR not blocked in #2\n");
0745245
-         break;
0745245
-      }
0745245
-      break;
0745245
-   case JS_Terminated:
0745245
-   case JS_ErrorTerminated:
0745245
-   case JS_Canceled:
0745245
-   case JS_FatalError:
0745245
-      Dmsg0(800, "JCR already dead in #3\n");
0745245
-      break;
0745245
-   default:
0745245
-      Jmsg1(jcr, M_ERROR, 0, _("Unhandled job status code %d\n"),
0745245
-            jcr->JobStatus);
0745245
    }
0745245
-   Dmsg3(800, "MaxWaitTime result: %scancel JCR %p (%s)\n",
0745245
-         cancel ? "" : "do not ", jcr, jcr->Job);
0745245
-#endif
0745245
+
0745245
    return cancel;
0745245
 }
0745245
 
0745245
@@ -574,36 +522,6 @@
0745245
       return false;
0745245
    }
0745245
 
0745245
-#ifdef xxx
0745245
-   switch (jcr->JobStatus) {
0745245
-   case JS_Created:
0745245
-   case JS_Running:
0745245
-   case JS_Blocked:
0745245
-   case JS_WaitFD:
0745245
-   case JS_WaitSD:
0745245
-   case JS_WaitStoreRes:
0745245
-   case JS_WaitClientRes:
0745245
-   case JS_WaitJobRes:
0745245
-   case JS_WaitPriority:
0745245
-   case JS_WaitMaxJobs:
0745245
-   case JS_WaitStartTime:
0745245
-   case JS_Differences:
0745245
-      cancel = true;
0745245
-      break;
0745245
-   case JS_Terminated:
0745245
-   case JS_ErrorTerminated:
0745245
-   case JS_Canceled:
0745245
-   case JS_FatalError:
0745245
-      cancel = false;
0745245
-      break;
0745245
-   default:
0745245
-      Jmsg1(jcr, M_ERROR, 0, _("Unhandled job status code %d\n"),
0745245
-            jcr->JobStatus);
0745245
-   }
0745245
-
0745245
-   Dmsg3(200, "MaxRunTime result: %scancel JCR %p (%s)\n",
0745245
-         cancel ? "" : "do not ", jcr, jcr->Job);
0745245
-#endif
0745245
    return true;
0745245
 }
0745245