mirror of
git://git.yoctoproject.org/poky.git
synced 2025-07-19 12:59:02 +02:00
perf-build-test/report: Drop phantomjs and html email reports support
phantomjs isn't reliable and we've moved to sharing the reports via a webserver. Update the scripts to more match those being used in the autobuilder helper where the html email support was removed. (From OE-Core rev: b5c131006e3fad0a15e6cdf81f71dc1e96647028) Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
This commit is contained in:
parent
65d4385d46
commit
10d9a8ba7a
|
@ -87,21 +87,10 @@ if [ $# -ne 0 ]; then
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ -n "$email_to" ]; then
|
|
||||||
if ! [ -x "$(command -v phantomjs)" ]; then
|
|
||||||
echo "ERROR: Sending email needs phantomjs."
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
if ! [ -x "$(command -v optipng)" ]; then
|
|
||||||
echo "ERROR: Sending email needs optipng."
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Open a file descriptor for flock and acquire lock
|
# Open a file descriptor for flock and acquire lock
|
||||||
LOCK_FILE="/tmp/oe-build-perf-test-wrapper.lock"
|
LOCK_FILE="/tmp/oe-build-perf-test-wrapper.lock"
|
||||||
if ! exec 3> "$LOCK_FILE"; then
|
if ! exec 3> "$LOCK_FILE"; then
|
||||||
echo "ERROR: Unable to open lock file"
|
echo "ERROR: Unable to open loemack file"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
if ! flock -n 3; then
|
if ! flock -n 3; then
|
||||||
|
@ -226,7 +215,7 @@ if [ -n "$results_repo" ]; then
|
||||||
if [ -n "$email_to" ]; then
|
if [ -n "$email_to" ]; then
|
||||||
echo "Emailing test report"
|
echo "Emailing test report"
|
||||||
os_name=`get_os_release_var PRETTY_NAME`
|
os_name=`get_os_release_var PRETTY_NAME`
|
||||||
"$script_dir"/oe-build-perf-report-email.py --to "$email_to" --subject "Build Perf Test Report for $os_name" --text $report_txt --html $report_html "${OE_BUILD_PERF_REPORT_EMAIL_EXTRA_ARGS[@]}"
|
"$script_dir"/oe-build-perf-report-email.py --to "$email_to" --subject "Build Perf Test Report for $os_name" --text $report_txt "${OE_BUILD_PERF_REPORT_EMAIL_EXTRA_ARGS[@]}"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Upload report files, unless we're on detached head
|
# Upload report files, unless we're on detached head
|
||||||
|
|
|
@ -19,8 +19,6 @@ import socket
|
||||||
import subprocess
|
import subprocess
|
||||||
import sys
|
import sys
|
||||||
import tempfile
|
import tempfile
|
||||||
from email.mime.image import MIMEImage
|
|
||||||
from email.mime.multipart import MIMEMultipart
|
|
||||||
from email.mime.text import MIMEText
|
from email.mime.text import MIMEText
|
||||||
|
|
||||||
|
|
||||||
|
@ -29,19 +27,6 @@ logging.basicConfig(level=logging.INFO, format="%(levelname)s: %(message)s")
|
||||||
log = logging.getLogger('oe-build-perf-report')
|
log = logging.getLogger('oe-build-perf-report')
|
||||||
|
|
||||||
|
|
||||||
# Find js scaper script
|
|
||||||
SCRAPE_JS = os.path.join(os.path.dirname(__file__), '..', 'lib', 'build_perf',
|
|
||||||
'scrape-html-report.js')
|
|
||||||
if not os.path.isfile(SCRAPE_JS):
|
|
||||||
log.error("Unableto find oe-build-perf-report-scrape.js")
|
|
||||||
sys.exit(1)
|
|
||||||
|
|
||||||
|
|
||||||
class ReportError(Exception):
|
|
||||||
"""Local errors"""
|
|
||||||
pass
|
|
||||||
|
|
||||||
|
|
||||||
def check_utils():
|
def check_utils():
|
||||||
"""Check that all needed utils are installed in the system"""
|
"""Check that all needed utils are installed in the system"""
|
||||||
missing = []
|
missing = []
|
||||||
|
@ -77,137 +62,19 @@ def parse_args(argv):
|
||||||
"the email parts")
|
"the email parts")
|
||||||
parser.add_argument('--text',
|
parser.add_argument('--text',
|
||||||
help="Plain text message")
|
help="Plain text message")
|
||||||
parser.add_argument('--html',
|
|
||||||
help="HTML peport generated by oe-build-perf-report")
|
|
||||||
parser.add_argument('--phantomjs-args', action='append',
|
|
||||||
help="Extra command line arguments passed to PhantomJS")
|
|
||||||
|
|
||||||
args = parser.parse_args(argv)
|
args = parser.parse_args(argv)
|
||||||
|
|
||||||
if not args.html and not args.text:
|
if not args.text:
|
||||||
parser.error("Please specify --html and/or --text")
|
parser.error("Please specify --text")
|
||||||
|
|
||||||
return args
|
return args
|
||||||
|
|
||||||
|
|
||||||
def decode_png(infile, outfile):
|
def send_email(text_fn, subject, recipients, copy=[], blind_copy=[]):
|
||||||
"""Parse/decode/optimize png data from a html element"""
|
|
||||||
with open(infile) as f:
|
|
||||||
raw_data = f.read()
|
|
||||||
|
|
||||||
# Grab raw base64 data
|
|
||||||
b64_data = re.sub('^.*href="data:image/png;base64,', '', raw_data, 1)
|
|
||||||
b64_data = re.sub('">.+$', '', b64_data, 1)
|
|
||||||
|
|
||||||
# Replace file with proper decoded png
|
|
||||||
with open(outfile, 'wb') as f:
|
|
||||||
f.write(base64.b64decode(b64_data))
|
|
||||||
|
|
||||||
subprocess.check_output(['optipng', outfile], stderr=subprocess.STDOUT)
|
|
||||||
|
|
||||||
|
|
||||||
def mangle_html_report(infile, outfile, pngs):
|
|
||||||
"""Mangle html file into a email compatible format"""
|
|
||||||
paste = True
|
|
||||||
png_dir = os.path.dirname(outfile)
|
|
||||||
with open(infile) as f_in:
|
|
||||||
with open(outfile, 'w') as f_out:
|
|
||||||
for line in f_in.readlines():
|
|
||||||
stripped = line.strip()
|
|
||||||
# Strip out scripts
|
|
||||||
if stripped == '<!--START-OF-SCRIPTS-->':
|
|
||||||
paste = False
|
|
||||||
elif stripped == '<!--END-OF-SCRIPTS-->':
|
|
||||||
paste = True
|
|
||||||
elif paste:
|
|
||||||
if re.match('^.+href="data:image/png;base64', stripped):
|
|
||||||
# Strip out encoded pngs (as they're huge in size)
|
|
||||||
continue
|
|
||||||
elif 'www.gstatic.com' in stripped:
|
|
||||||
# HACK: drop references to external static pages
|
|
||||||
continue
|
|
||||||
|
|
||||||
# Replace charts with <img> elements
|
|
||||||
match = re.match('<div id="(?P<id>\w+)"', stripped)
|
|
||||||
if match and match.group('id') in pngs:
|
|
||||||
f_out.write('<img src="cid:{}"\n'.format(match.group('id')))
|
|
||||||
else:
|
|
||||||
f_out.write(line)
|
|
||||||
|
|
||||||
|
|
||||||
def scrape_html_report(report, outdir, phantomjs_extra_args=None):
|
|
||||||
"""Scrape html report into a format sendable by email"""
|
|
||||||
tmpdir = tempfile.mkdtemp(dir='.')
|
|
||||||
log.debug("Using tmpdir %s for phantomjs output", tmpdir)
|
|
||||||
|
|
||||||
if not os.path.isdir(outdir):
|
|
||||||
os.mkdir(outdir)
|
|
||||||
if os.path.splitext(report)[1] not in ('.html', '.htm'):
|
|
||||||
raise ReportError("Invalid file extension for report, needs to be "
|
|
||||||
"'.html' or '.htm'")
|
|
||||||
|
|
||||||
try:
|
|
||||||
log.info("Scraping HTML report with PhangomJS")
|
|
||||||
extra_args = phantomjs_extra_args if phantomjs_extra_args else []
|
|
||||||
subprocess.check_output(['phantomjs', '--debug=true'] + extra_args +
|
|
||||||
[SCRAPE_JS, report, tmpdir],
|
|
||||||
stderr=subprocess.STDOUT)
|
|
||||||
|
|
||||||
pngs = []
|
|
||||||
images = []
|
|
||||||
for fname in os.listdir(tmpdir):
|
|
||||||
base, ext = os.path.splitext(fname)
|
|
||||||
if ext == '.png':
|
|
||||||
log.debug("Decoding %s", fname)
|
|
||||||
decode_png(os.path.join(tmpdir, fname),
|
|
||||||
os.path.join(outdir, fname))
|
|
||||||
pngs.append(base)
|
|
||||||
images.append(fname)
|
|
||||||
elif ext in ('.html', '.htm'):
|
|
||||||
report_file = fname
|
|
||||||
else:
|
|
||||||
log.warning("Unknown file extension: '%s'", ext)
|
|
||||||
#shutil.move(os.path.join(tmpdir, fname), outdir)
|
|
||||||
|
|
||||||
log.debug("Mangling html report file %s", report_file)
|
|
||||||
mangle_html_report(os.path.join(tmpdir, report_file),
|
|
||||||
os.path.join(outdir, report_file), pngs)
|
|
||||||
return (os.path.join(outdir, report_file),
|
|
||||||
[os.path.join(outdir, i) for i in images])
|
|
||||||
finally:
|
|
||||||
shutil.rmtree(tmpdir)
|
|
||||||
|
|
||||||
def send_email(text_fn, html_fn, image_fns, subject, recipients, copy=[],
|
|
||||||
blind_copy=[]):
|
|
||||||
"""Send email"""
|
|
||||||
# Generate email message
|
# Generate email message
|
||||||
text_msg = html_msg = None
|
with open(text_fn) as f:
|
||||||
if text_fn:
|
msg = MIMEText("Yocto build performance test report.\n" + f.read(), 'plain')
|
||||||
with open(text_fn) as f:
|
|
||||||
text_msg = MIMEText("Yocto build performance test report.\n" +
|
|
||||||
f.read(), 'plain')
|
|
||||||
if html_fn:
|
|
||||||
html_msg = msg = MIMEMultipart('related')
|
|
||||||
with open(html_fn) as f:
|
|
||||||
html_msg.attach(MIMEText(f.read(), 'html'))
|
|
||||||
for img_fn in image_fns:
|
|
||||||
# Expect that content id is same as the filename
|
|
||||||
cid = os.path.splitext(os.path.basename(img_fn))[0]
|
|
||||||
with open(img_fn, 'rb') as f:
|
|
||||||
image_msg = MIMEImage(f.read())
|
|
||||||
image_msg['Content-ID'] = '<{}>'.format(cid)
|
|
||||||
html_msg.attach(image_msg)
|
|
||||||
|
|
||||||
if text_msg and html_msg:
|
|
||||||
msg = MIMEMultipart('alternative')
|
|
||||||
msg.attach(text_msg)
|
|
||||||
msg.attach(html_msg)
|
|
||||||
elif text_msg:
|
|
||||||
msg = text_msg
|
|
||||||
elif html_msg:
|
|
||||||
msg = html_msg
|
|
||||||
else:
|
|
||||||
raise ReportError("Neither plain text nor html body specified")
|
|
||||||
|
|
||||||
pw_data = pwd.getpwuid(os.getuid())
|
pw_data = pwd.getpwuid(os.getuid())
|
||||||
full_name = pw_data.pw_gecos.split(',')[0]
|
full_name = pw_data.pw_gecos.split(',')[0]
|
||||||
|
@ -245,25 +112,16 @@ def main(argv=None):
|
||||||
|
|
||||||
try:
|
try:
|
||||||
log.debug("Storing email parts in %s", outdir)
|
log.debug("Storing email parts in %s", outdir)
|
||||||
html_report = images = None
|
|
||||||
if args.html:
|
|
||||||
html_report, images = scrape_html_report(args.html, outdir,
|
|
||||||
args.phantomjs_args)
|
|
||||||
|
|
||||||
if args.to:
|
if args.to:
|
||||||
log.info("Sending email to %s", ', '.join(args.to))
|
log.info("Sending email to %s", ', '.join(args.to))
|
||||||
if args.cc:
|
if args.cc:
|
||||||
log.info("Copying to %s", ', '.join(args.cc))
|
log.info("Copying to %s", ', '.join(args.cc))
|
||||||
if args.bcc:
|
if args.bcc:
|
||||||
log.info("Blind copying to %s", ', '.join(args.bcc))
|
log.info("Blind copying to %s", ', '.join(args.bcc))
|
||||||
send_email(args.text, html_report, images, args.subject,
|
send_email(args.text, args.subject, args.to, args.cc, args.bcc)
|
||||||
args.to, args.cc, args.bcc)
|
|
||||||
except subprocess.CalledProcessError as err:
|
except subprocess.CalledProcessError as err:
|
||||||
log.error("%s, with output:\n%s", str(err), err.output.decode())
|
log.error("%s, with output:\n%s", str(err), err.output.decode())
|
||||||
return 1
|
return 1
|
||||||
except ReportError as err:
|
|
||||||
log.error(err)
|
|
||||||
return 1
|
|
||||||
finally:
|
finally:
|
||||||
if not args.outdir:
|
if not args.outdir:
|
||||||
log.debug("Wiping %s", outdir)
|
log.debug("Wiping %s", outdir)
|
||||||
|
|
Loading…
Reference in New Issue
Block a user