forked from sclorg/ci-scripts
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsend_results.py
111 lines (98 loc) · 3.39 KB
/
send_results.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
#!/usr/bin/python
# -*- coding: utf-8 -*-
#
import smtplib
import sys
from pathlib import Path
from typing import List
from email.mime.text import MIMEText
from email.mime.multipart import MIMEMultipart
COMMASPACE = ", "
class SendResults:
results_dir: Path = None
sender: str = ""
target: str = ""
recipients: List[str] = []
msg: MIMEMultipart = None
# Body message for an email
html = """
<html>
<head></head>
<body>
<p>
Nightly build testing of RHSCL containers for target {target} {results}
{cont}
</p>
</body>
</html>
"""
title: str = "RHSCL nightly build testing for target {target} "
def __init__(self):
"""
Parse position arguments
1st argument: directory
2nd argument: sender
3rd and rest arguments: recipients
"""
self.get_cli_args()
self.msg = MIMEMultipart()
self.msg["From"] = self.sender
self.msg["To"] = COMMASPACE.join(self.recipients)
self.msg.preamble = self.title
def get_cli_args(self):
"""
Parse CLI arguments
"""
# Directory, where are stored logs
if len(sys.argv) < 5:
print(
"Script `send_results.py` expects at least 3 arguments."
"./send_results.py <directory> <target> <sender> <recipient_1> <recipient_2> ..."
)
sys.exit(1)
self.results_dir = Path(sys.argv[1])
self.target = sys.argv[2]
self.sender = sys.argv[3]
self.recipients = sys.argv[4:]
if not self.results_dir.exists() and not self.results_dir.is_dir():
print("The directory specified as the first argument does not exist.")
sys.exit(1)
def iterate_over_dir(self) -> List:
failed_containers: List = []
for filename in self.results_dir.iterdir():
if not filename.is_file() and not str(filename).endswith(".log"):
continue
# Open log file and attach it into message
print(f"Failed container {str(filename)}.")
with filename.open() as fp:
file_attachment = MIMEText(fp.read(), "plain")
file_attachment.add_header(
"Content-Disposition", "attachment", filename=filename.name
)
self.msg.attach(file_attachment)
# Delete log file and append into failed_containers array
failed_containers.append(filename.stem)
filename.unlink()
return failed_containers
def send_results(self):
"""
Sends an email based on the logs from the given directory
"""
failed_containers: List = self.iterate_over_dir()
if not failed_containers:
return
short_result = "failed."
self.msg["Subject"] = self.title.format(target=self.target) + short_result
html = self.html.format(
target=self.target.capitalize(),
results=short_result,
cont="<br>Failed containers: <br>" + "<br>".join(failed_containers),
)
self.msg.attach(MIMEText(html, "html"))
s = smtplib.SMTP("localhost")
s.sendmail(self.sender, self.recipients, self.msg.as_string())
print("Email sent.")
s.quit()
if __name__ == "__main__":
sr = SendResults()
sr.send_results()