Blame SOURCES/BZ-1744639-yum-cron-make-sure-output-fully-unicode.patch

5e9bef
diff --git a/yum-cron/yum-cron.py b/yum-cron/yum-cron.py
5e9bef
index 23f36d38..fd593d62 100755
5e9bef
--- a/yum-cron/yum-cron.py
5e9bef
+++ b/yum-cron/yum-cron.py
5e9bef
@@ -140,7 +140,11 @@ class UpdateEmitter(object):
5e9bef
         overridden by inheriting classes to emit the messages
5e9bef
         according to their individual methods.
5e9bef
         """
5e9bef
-        pass
5e9bef
+        # Convert any byte strings to unicode objects now (so that we avoid
5e9bef
+        # implicit conversions with the "ascii" codec later when join()-ing the
5e9bef
+        # strings, leading to tracebacks).
5e9bef
+        self.output = [x.decode('utf-8') if isinstance(x, str) else x
5e9bef
+                       for x in self.output]
5e9bef
 
5e9bef
 
5e9bef
 class EmailEmitter(UpdateEmitter):
5e9bef
@@ -220,6 +224,7 @@ class EmailEmitter(UpdateEmitter):
5e9bef
         """Combine the stored messages that have been stored into a
5e9bef
         single email message, and send this message.
5e9bef
         """
5e9bef
+        super(EmailEmitter, self).sendMessages()
5e9bef
         # Don't send empty emails
5e9bef
         if not self.output:
5e9bef
             return
5e9bef
@@ -262,6 +267,7 @@ class StdIOEmitter(UpdateEmitter):
5e9bef
         """Combine the stored messages that have been stored into a
5e9bef
         single email message, and send this message to standard output.
5e9bef
         """
5e9bef
+        super(StdIOEmitter, self).sendMessages()
5e9bef
         # Don't print blank lines
5e9bef
         if not self.output:
5e9bef
             return