diff --git a/britney2/excuse.py b/britney2/excuse.py
index bd7052b..65bbb8f 100644
--- a/britney2/excuse.py
+++ b/britney2/excuse.py
@@ -401,11 +401,15 @@ class Excuse(object):
info = "Impossible %s: %s -> %s" % (d.deptype, self.uvname, desc)
else:
duv = excuses[dep].uvname
- if d.valid:
- info = "%s: %s %s" % (d.deptype, self.uvname, duv, duv)
- else:
+ verdict = excuses[dep].policy_verdict
+ if not d.valid or verdict in (PolicyVerdict.REJECTED_NEEDS_APPROVAL,
+ PolicyVerdict.REJECTED_CANNOT_DETERMINE_IF_PERMANENT,
+ PolicyVerdict.REJECTED_PERMANENTLY):
info = "%s: %s %s (not considered)" % (d.deptype, self.uvname, duv, duv)
- dep_issues[d.verdict].add("Invalidated by %s" % d.deptype.get_description())
+ if not d.valid:
+ dep_issues[d.verdict].add("Invalidated by %s" % d.deptype.get_description())
+ else:
+ info = "%s: %s %s" % (d.deptype, self.uvname, duv, duv)
dep_issues[d.verdict].add(info)
seen = set()
diff --git a/britney2/utils.py b/britney2/utils.py
index a44cdf6..c1d9b48 100644
--- a/britney2/utils.py
+++ b/britney2/utils.py
@@ -728,6 +728,7 @@ def invalidate_excuses(excuses, valid, invalid, invalidated):
exc = excuses[x]
# if the item is valid and it is not marked as `forced', then we
# invalidate this specfic dependency
+
if x in valid and not exc.forced:
# mark this specific dependency as invalid
still_valid = exc.invalidate_dependency(ename, rdep_verdict)