# # Copyright Openedhand Ltd 2008 # Author: Richard Purdie # # Designed for use with the Poky autobuilder only and provides custom hooks for # certain specific events. def do_autobuilder_failure_report(event): from bb.event import getName from bb import data, mkdirhier, build import os, glob if data.getVar('PN', event.data, True) != "clutter": return import smtplib import email.Message version = data.expand("${PN}: ${PV}-${PR}", event.data) recipients = ["richard@o-hand.com"] COMMASPACE = ', ' message = email.Message.Message() message["To"] = COMMASPACE.join(recipients) message["From"] = "Poky Autobuilder Failure " message["Subject"] = "Poky Autobuild Failure Report - " + version mesg = "Poky Build Failure for:\n\n" for var in ["DISTRO", "MACHINE", "PN", "PV", "PR"]: mesg += var + ": " + data.getVar(var, event.data, True) + "\n" mesg += "\nLog of the failure follows:\n\n" log_file = glob.glob("%s/log.%s.*" % (data.getVar('T', event.data, True), event.task)) if len(log_file) != 0: mesg += "".join(open(log_file[0], 'r').readlines()) message.set_payload(mesg) mailServer = smtplib.SMTP("pug.o-hand.com") mailServer.sendmail(message["From"], recipients, message.as_string()) mailServer.quit() # we want to be an event handler addhandler poky_autobuilder_notifier_eventhandler python poky_autobuilder_notifier_eventhandler() { from bb import note, error, data from bb.event import getName if e.data is None: return name = getName(e) if name == "TaskFailed": do_autobuilder_failure_report(e) return }