Zbigniew Jędrzejewski-Szmek d66047
From 99e4b98b064042a2c1cea103941a7895b183821e Mon Sep 17 00:00:00 2001
Zbigniew Jędrzejewski-Szmek d66047
From: =?UTF-8?q?Zbigniew=20J=C4=99drzejewski-Szmek?= <zbyszek@in.waw.pl>
Zbigniew Jędrzejewski-Szmek d66047
Date: Mon, 2 Dec 2013 21:52:51 -0500
Zbigniew Jędrzejewski-Szmek d66047
Subject: [PATCH] systemd: treat reload failure as failure
Zbigniew Jędrzejewski-Szmek d66047
Zbigniew Jędrzejewski-Szmek d66047
systemctl reload "suceeded" on stopped units, but it is documented
Zbigniew Jędrzejewski-Szmek d66047
to fail in this case.
Zbigniew Jędrzejewski-Szmek d66047
Zbigniew Jędrzejewski-Szmek d66047
https://bugzilla.redhat.com/show_bug.cgi?id=1036845
Zbigniew Jędrzejewski-Szmek d66047
---
Zbigniew Jędrzejewski-Szmek d66047
 src/core/job.c  | 11 +++++++----
Zbigniew Jędrzejewski-Szmek d66047
 src/core/job.h  |  3 ++-
Zbigniew Jędrzejewski-Szmek d66047
 src/core/unit.c |  5 ++++-
Zbigniew Jędrzejewski-Szmek d66047
 3 files changed, 13 insertions(+), 6 deletions(-)
Zbigniew Jędrzejewski-Szmek d66047
Zbigniew Jędrzejewski-Szmek d66047
diff --git a/src/core/job.c b/src/core/job.c
Zbigniew Jędrzejewski-Szmek d66047
index dc3bc12..7d2b994 100644
Zbigniew Jędrzejewski-Szmek d66047
--- a/src/core/job.c
Zbigniew Jędrzejewski-Szmek d66047
+++ b/src/core/job.c
Zbigniew Jędrzejewski-Szmek d66047
@@ -528,7 +528,7 @@ int job_run_and_invalidate(Job *j) {
Zbigniew Jędrzejewski-Szmek d66047
                         else if (t == UNIT_ACTIVATING)
Zbigniew Jędrzejewski-Szmek d66047
                                 r = -EAGAIN;
Zbigniew Jędrzejewski-Szmek d66047
                         else
Zbigniew Jędrzejewski-Szmek d66047
-                                r = -ENOEXEC;
Zbigniew Jędrzejewski-Szmek d66047
+                                r = -EBADR;
Zbigniew Jędrzejewski-Szmek d66047
                         break;
Zbigniew Jędrzejewski-Szmek d66047
                 }
Zbigniew Jędrzejewski-Szmek d66047
 
Zbigniew Jędrzejewski-Szmek d66047
@@ -557,8 +557,10 @@ int job_run_and_invalidate(Job *j) {
Zbigniew Jędrzejewski-Szmek d66047
         if (j) {
Zbigniew Jędrzejewski-Szmek d66047
                 if (r == -EALREADY)
Zbigniew Jędrzejewski-Szmek d66047
                         r = job_finish_and_invalidate(j, JOB_DONE, true);
Zbigniew Jędrzejewski-Szmek d66047
-                else if (r == -ENOEXEC)
Zbigniew Jędrzejewski-Szmek d66047
+                else if (r == -EBADR)
Zbigniew Jędrzejewski-Szmek d66047
                         r = job_finish_and_invalidate(j, JOB_SKIPPED, true);
Zbigniew Jędrzejewski-Szmek d66047
+                else if (r == -ENOEXEC)
Zbigniew Jędrzejewski-Szmek d66047
+                        r = job_finish_and_invalidate(j, JOB_INVALID, true);
Zbigniew Jędrzejewski-Szmek d66047
                 else if (r == -EAGAIN) {
Zbigniew Jędrzejewski-Szmek d66047
                         j->state = JOB_WAITING;
Zbigniew Jędrzejewski-Szmek d66047
                         m->n_running_jobs--;
Zbigniew Jędrzejewski-Szmek d66047
@@ -784,7 +786,7 @@ int job_finish_and_invalidate(Job *j, JobResult result, bool recursive) {
Zbigniew Jędrzejewski-Szmek d66047
                 goto finish;
Zbigniew Jędrzejewski-Szmek d66047
         }
Zbigniew Jędrzejewski-Szmek d66047
 
Zbigniew Jędrzejewski-Szmek d66047
-        if (result == JOB_FAILED)
Zbigniew Jędrzejewski-Szmek d66047
+        if (result == JOB_FAILED || result == JOB_INVALID)
Zbigniew Jędrzejewski-Szmek d66047
                 j->manager->n_failed_jobs ++;
Zbigniew Jędrzejewski-Szmek d66047
 
Zbigniew Jędrzejewski-Szmek d66047
         job_uninstall(j);
Zbigniew Jędrzejewski-Szmek d66047
@@ -1143,7 +1145,8 @@ static const char* const job_result_table[_JOB_RESULT_MAX] = {
Zbigniew Jędrzejewski-Szmek d66047
         [JOB_TIMEOUT] = "timeout",
Zbigniew Jędrzejewski-Szmek d66047
         [JOB_FAILED] = "failed",
Zbigniew Jędrzejewski-Szmek d66047
         [JOB_DEPENDENCY] = "dependency",
Zbigniew Jędrzejewski-Szmek d66047
-        [JOB_SKIPPED] = "skipped"
Zbigniew Jędrzejewski-Szmek d66047
+        [JOB_SKIPPED] = "skipped",
Zbigniew Jędrzejewski-Szmek d66047
+        [JOB_INVALID] = "invalid",
Zbigniew Jędrzejewski-Szmek d66047
 };
Zbigniew Jędrzejewski-Szmek d66047
 
Zbigniew Jędrzejewski-Szmek d66047
 DEFINE_STRING_TABLE_LOOKUP(job_result, JobResult);
Zbigniew Jędrzejewski-Szmek d66047
diff --git a/src/core/job.h b/src/core/job.h
Zbigniew Jędrzejewski-Szmek d66047
index d90bc96..4237529 100644
Zbigniew Jędrzejewski-Szmek d66047
--- a/src/core/job.h
Zbigniew Jędrzejewski-Szmek d66047
+++ b/src/core/job.h
Zbigniew Jędrzejewski-Szmek d66047
@@ -97,7 +97,8 @@ enum JobResult {
Zbigniew Jędrzejewski-Szmek d66047
         JOB_TIMEOUT,             /* JobTimeout elapsed */
Zbigniew Jędrzejewski-Szmek d66047
         JOB_FAILED,              /* Job failed */
Zbigniew Jędrzejewski-Szmek d66047
         JOB_DEPENDENCY,          /* A required dependency job did not result in JOB_DONE */
Zbigniew Jędrzejewski-Szmek d66047
-        JOB_SKIPPED,             /* JOB_RELOAD of inactive unit; negative result of JOB_VERIFY_ACTIVE */
Zbigniew Jędrzejewski-Szmek d66047
+        JOB_SKIPPED,             /* Negative result of JOB_VERIFY_ACTIVE */
Zbigniew Jędrzejewski-Szmek d66047
+        JOB_INVALID,             /* JOB_RELOAD of inactive unit */
Zbigniew Jędrzejewski-Szmek d66047
         _JOB_RESULT_MAX,
Zbigniew Jędrzejewski-Szmek d66047
         _JOB_RESULT_INVALID = -1
Zbigniew Jędrzejewski-Szmek d66047
 };
Zbigniew Jędrzejewski-Szmek d66047
diff --git a/src/core/unit.c b/src/core/unit.c
Zbigniew Jędrzejewski-Szmek d66047
index b65e798..6c2c4a0 100644
Zbigniew Jędrzejewski-Szmek d66047
--- a/src/core/unit.c
Zbigniew Jędrzejewski-Szmek d66047
+++ b/src/core/unit.c
Zbigniew Jędrzejewski-Szmek d66047
@@ -1239,8 +1239,11 @@ int unit_reload(Unit *u) {
Zbigniew Jędrzejewski-Szmek d66047
         if (state == UNIT_RELOADING)
Zbigniew Jędrzejewski-Szmek d66047
                 return -EALREADY;
Zbigniew Jędrzejewski-Szmek d66047
 
Zbigniew Jędrzejewski-Szmek d66047
-        if (state != UNIT_ACTIVE)
Zbigniew Jędrzejewski-Szmek d66047
+        if (state != UNIT_ACTIVE) {
Zbigniew Jędrzejewski-Szmek d66047
+                log_warning_unit(u->id, "Unit %s cannot be reloaded because it is inactive.",
Zbigniew Jędrzejewski-Szmek d66047
+                                 u->id);
Zbigniew Jędrzejewski-Szmek d66047
                 return -ENOEXEC;
Zbigniew Jędrzejewski-Szmek d66047
+        }
Zbigniew Jędrzejewski-Szmek d66047
 
Zbigniew Jędrzejewski-Szmek d66047
         if ((following = unit_following(u))) {
Zbigniew Jędrzejewski-Szmek d66047
                 log_debug_unit(u->id, "Redirecting reload request from %s to %s.",