naccyde / rpms / systemd

Forked from rpms/systemd a year ago
Clone
a4b143
From a38c3d5d4e94c7e11db1ca22126bb11c6b029886 Mon Sep 17 00:00:00 2001
a4b143
From: =?UTF-8?q?Zbigniew=20J=C4=99drzejewski-Szmek?= <zbyszek@in.waw.pl>
a4b143
Date: Sun, 15 Sep 2013 12:15:38 -0400
a4b143
Subject: [PATCH] transaction.c: do not point users to logs when unit not found
a4b143
a4b143
The logs are unlikely to contain any useful information in this case.
a4b143
a4b143
Also, change "walked on cycle path" to "found dependency on", which
a4b143
is less technical and indicates the direction. With the old message,
a4b143
I was never sure if prior units depended on later ones, or vice versa.
a4b143
a4b143
https://bugzilla.redhat.com/show_bug.cgi?id=996133
a4b143
https://bugzilla.redhat.com/show_bug.cgi?id=997082
a4b143
---
a4b143
 src/core/transaction.c | 14 +++++++++++---
a4b143
 1 file changed, 11 insertions(+), 3 deletions(-)
a4b143
a4b143
diff --git a/src/core/transaction.c b/src/core/transaction.c
a4b143
index 27efef7..203070f 100644
a4b143
--- a/src/core/transaction.c
a4b143
+++ b/src/core/transaction.c
a4b143
@@ -344,7 +344,7 @@ static int transaction_verify_order_one(Transaction *tr, Job *j, Job *from, unsi
a4b143
         assert(!j->transaction_prev);
a4b143
 
a4b143
         /* Does a recursive sweep through the ordering graph, looking
a4b143
-         * for a cycle. If we find cycle we try to break it. */
a4b143
+         * for a cycle. If we find a cycle we try to break it. */
a4b143
 
a4b143
         /* Have we seen this before? */
a4b143
         if (j->generation == generation) {
a4b143
@@ -371,7 +371,7 @@ static int transaction_verify_order_one(Transaction *tr, Job *j, Job *from, unsi
a4b143
 
a4b143
                         /* logging for j not k here here to provide consistent narrative */
a4b143
                         log_info_unit(j->unit->id,
a4b143
-                                      "Walked on cycle path to %s/%s",
a4b143
+                                      "Found dependency on %s/%s",
a4b143
                                       k->unit->id, job_type_to_string(k->type));
a4b143
 
a4b143
                         if (!delete &&
a4b143
@@ -860,7 +860,7 @@ int transaction_add_job_and_dependencies(
a4b143
                 return -EINVAL;
a4b143
         }
a4b143
 
a4b143
-        if (type != JOB_STOP && (unit->load_state == UNIT_ERROR || unit->load_state == UNIT_NOT_FOUND)) {
a4b143
+        if (type != JOB_STOP && unit->load_state == UNIT_ERROR) {
a4b143
                 dbus_set_error(e, BUS_ERROR_LOAD_FAILED,
a4b143
                                "Unit %s failed to load: %s. "
a4b143
                                "See system logs and 'systemctl status %s' for details.",
a4b143
@@ -870,6 +870,14 @@ int transaction_add_job_and_dependencies(
a4b143
                 return -EINVAL;
a4b143
         }
a4b143
 
a4b143
+        if (type != JOB_STOP && unit->load_state == UNIT_NOT_FOUND) {
a4b143
+                dbus_set_error(e, BUS_ERROR_LOAD_FAILED,
a4b143
+                               "Unit %s failed to load: %s.",
a4b143
+                               unit->id,
a4b143
+                               strerror(-unit->load_error));
a4b143
+                return -EINVAL;
a4b143
+        }
a4b143
+
a4b143
         if (type != JOB_STOP && unit->load_state == UNIT_MASKED) {
a4b143
                 dbus_set_error(e, BUS_ERROR_MASKED, "Unit %s is masked.", unit->id);
a4b143
                 return -EADDRNOTAVAIL;