Alter comments left on 'Related' bugs

Avoid posting confusing 'Fix proposed' or 'Fix merged' comments for
'Related' bugs.

This also fixes a latent bug (the 'add_comment' task was not really
taken into consideration before actually adding a comment).

Fixes bug: #1218044

Change-Id: Ic287050cf5dcf690239484038fb957e897df886f
diff --git a/jeepyb/cmd/update_bug.py b/jeepyb/cmd/update_bug.py
index 1f6850d..e1f1e4a 100644
--- a/jeepyb/cmd/update_bug.py
+++ b/jeepyb/cmd/update_bug.py
@@ -36,15 +36,25 @@
                    '~/.launchpadlib/creds'))
 
 
-def add_change_proposed_message(bugtask, change_url, project, branch):
-    subject = 'Fix proposed to %s (%s)' % (short_project(project), branch)
-    body = 'Fix proposed to branch: %s\nReview: %s' % (branch, change_url)
+def fix_or_related_fix(related):
+    if related:
+        return "Related fix"
+    else:
+        return "Fix"
+
+
+def add_change_proposed_message(bugtask, change_url, project, branch,
+                                related=False):
+    fix = fix_or_related_fix(related)
+    subject = '%s proposed to %s (%s)' % (fix, short_project(project), branch)
+    body = '%s proposed to branch: %s\nReview: %s' % (fix, branch, change_url)
     bugtask.bug.newMessage(subject=subject, content=body)
 
 
 def add_change_merged_message(bugtask, change_url, project, commit,
-                              submitter, branch, git_log):
-    subject = 'Fix merged to %s (%s)' % (short_project(project), branch)
+                              submitter, branch, git_log, related=False):
+    subject = '%s merged to %s (%s)' % (fix_or_related_fix(related),
+                                        short_project(project), branch)
     git_url = 'http://github.com/%s/commit/%s' % (project, commit)
     body = '''Reviewed:  %s
 Committed: %s
@@ -237,6 +247,7 @@
 
         ::
         add_comment       -> Adds a comment to the bug's lp page.
+        sidenote          -> Adds a 'related' comment to the bug's lp page.
         set_in_progress   -> Sets the bug's lp status to 'In Progress'.
         set_fix_released  -> Sets the bug's lp status to 'Fix Released'.
         set_fix_committed -> Sets the bug's lp status to 'Fix Committed'.
@@ -259,7 +270,7 @@
         elif prefix in ('partial',):
             self.changes_needed.extend(('add_comment', 'set_in_progress'))
         elif prefix in ('related', 'impacts', 'affects'):
-            self.changes_needed.extend(('add_comment',))
+            self.changes_needed.extend(('sidenote',))
         else:
             # prefix is not recognized.
             self.changes_needed.extend(('add_comment',))
@@ -301,9 +312,11 @@
                 # Use tag_in_branchname if there isn't any.
                 tag_in_branchname(bugtask, args.branch)
 
-        add_change_merged_message(bugtask, args.change_url, args.project,
-                                  args.commit, args.submitter, args.branch,
-                                  git_log)
+        if task.needs_change('add_comment') or task.needs_change('sidenote'):
+            add_change_merged_message(bugtask, args.change_url, args.project,
+                                      args.commit, args.submitter, args.branch,
+                                      git_log,
+                                      related=task.needs_change('sidenote'))
 
     if args.hook == "patchset-created":
         if args.branch == 'master':
@@ -322,9 +335,11 @@
                                     args.uploader, args.change_url)
                     break
 
-        if args.patchset == '1':
+        if args.patchset == '1' and (task.needs_change('add_comment') or
+                                     task.needs_change('sidenote')):
             add_change_proposed_message(bugtask, args.change_url,
-                                        args.project, args.branch)
+                                        args.project, args.branch,
+                                        related=task.needs_change('sidenote'))
 
 
 def find_bugs(launchpad, git_log, args):