Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 1 | #/usr/bin/env python |
| 2 | ''' |
admin | bae64d8 | 2013-08-01 10:50:15 -0700 | [diff] [blame] | 3 | Created on 07-Jan-2013 |
Jeremy Songster | ae01bba | 2016-07-11 15:39:17 -0700 | [diff] [blame] | 4 | Modified 2015 by ON.Lab |
Jon Hall | 81d3d39 | 2015-04-24 14:40:35 -0700 | [diff] [blame] | 5 | |
Jeremy Songster | ae01bba | 2016-07-11 15:39:17 -0700 | [diff] [blame] | 6 | Please refer questions to either the onos test mailing list at <onos-test@onosproject.org>, |
| 7 | the System Testing Plans and Results wiki page at <https://wiki.onosproject.org/x/voMg>, |
| 8 | or the System Testing Guide page at <https://wiki.onosproject.org/x/WYQg> |
admin | bae64d8 | 2013-08-01 10:50:15 -0700 | [diff] [blame] | 9 | |
| 10 | TestON is free software: you can redistribute it and/or modify |
| 11 | it under the terms of the GNU General Public License as published by |
| 12 | the Free Software Foundation, either version 2 of the License, or |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 13 | (at your option) any later version. |
admin | bae64d8 | 2013-08-01 10:50:15 -0700 | [diff] [blame] | 14 | |
| 15 | TestON is distributed in the hope that it will be useful, |
| 16 | but WITHOUT ANY WARRANTY; without even the implied warranty of |
| 17 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| 18 | GNU General Public License for more details. |
| 19 | |
| 20 | You should have received a copy of the GNU General Public License |
Jon Hall | 81d3d39 | 2015-04-24 14:40:35 -0700 | [diff] [blame] | 21 | along with TestON. If not, see <http://www.gnu.org/licenses/>. |
admin | bae64d8 | 2013-08-01 10:50:15 -0700 | [diff] [blame] | 22 | |
| 23 | |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 24 | ''' |
| 25 | |
admin | bae64d8 | 2013-08-01 10:50:15 -0700 | [diff] [blame] | 26 | import logging |
| 27 | import datetime |
| 28 | import re |
| 29 | import os |
| 30 | class Logger: |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 31 | ''' |
admin | bae64d8 | 2013-08-01 10:50:15 -0700 | [diff] [blame] | 32 | Add continuous logs and reports of the test. |
Jon Hall | 81d3d39 | 2015-04-24 14:40:35 -0700 | [diff] [blame] | 33 | |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 34 | @author: Raghav Kashyap(raghavkashyap@paxterrasolutions.com) |
| 35 | ''' |
| 36 | def _printHeader(self,main) : |
| 37 | ''' |
admin | bae64d8 | 2013-08-01 10:50:15 -0700 | [diff] [blame] | 38 | Log's header will be append to the Log file |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 39 | ''' |
| 40 | logmsg = "\n"+" " * 32+"+----------------+\n" +"-" * 30+" { Script And Files } "+"-" * 30+"\n" +" " * 32+"+----------------+\n"; |
admin | bae64d8 | 2013-08-01 10:50:15 -0700 | [diff] [blame] | 41 | logmsg = logmsg + "\n\tScript Log File : " + main.LogFileName + "" |
| 42 | logmsg = logmsg + "\n\tReport Log File : " + main.ReportFileName + "" |
| 43 | for component in main.componentDictionary.keys(): |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 44 | logmsg = logmsg + "\n\t"+component+" Session Log : " + main.logdir+"/"+component+".session" + "" |
Jon Hall | 81d3d39 | 2015-04-24 14:40:35 -0700 | [diff] [blame] | 45 | |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 46 | logmsg = logmsg + "\n\tTest Script :" + path + "Tests/" + main.TEST + ".py"+ "" |
admin | bae64d8 | 2013-08-01 10:50:15 -0700 | [diff] [blame] | 47 | logmsg = logmsg + "\n\tTest Params : " + path + "Tests/" + main.TEST + ".params" + "" |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 48 | logmsg = logmsg + "\n\tTopology : " + path + "Tests/" +main.TEST + ".topo" + "" |
| 49 | logmsg = logmsg + "\n"+" " * 30+"+" +"-" * 18+"+" +"\n" +"-" * 27+" { Script Exec Params } "+"-" * 27 +"\n" +" " * 30 +"+"+"-" * 18 +"+\n"; |
| 50 | values = "\n\t" + str(main.params) |
| 51 | values = re.sub(",", "\n\t", values) |
| 52 | values = re.sub("{", "\n\t", values) |
| 53 | values = re.sub("}", "\n\t", values) |
admin | bae64d8 | 2013-08-01 10:50:15 -0700 | [diff] [blame] | 54 | logmsg = logmsg + values |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 55 | logmsg = logmsg + "\n\n"+" " * 31+"+---------------+\n" +"-" * 29+" { Components Used } " +"-" * 29+"\n"+" " * 31+"+---------------+\n" |
admin | bae64d8 | 2013-08-01 10:50:15 -0700 | [diff] [blame] | 56 | component_list = [] |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 57 | component_list.append(None) |
Jon Hall | 81d3d39 | 2015-04-24 14:40:35 -0700 | [diff] [blame] | 58 | |
admin | bae64d8 | 2013-08-01 10:50:15 -0700 | [diff] [blame] | 59 | # Listing the components in the order of test_target component should be first. |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 60 | if type(main.componentDictionary) == dict: |
admin | bae64d8 | 2013-08-01 10:50:15 -0700 | [diff] [blame] | 61 | for key in main.componentDictionary.keys(): |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 62 | if main.test_target == key : |
| 63 | component_list[0] = key+"-Test Target" |
| 64 | else : |
| 65 | component_list.append(key) |
Jon Hall | 81d3d39 | 2015-04-24 14:40:35 -0700 | [diff] [blame] | 66 | |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 67 | for index in range(len(component_list)) : |
| 68 | if index==0: |
| 69 | if component_list[index]: |
| 70 | logmsg+="\t"+component_list[index]+"\n" |
| 71 | elif index > 0 : |
| 72 | logmsg+="\t"+str(component_list[index])+"\n" |
Jon Hall | 81d3d39 | 2015-04-24 14:40:35 -0700 | [diff] [blame] | 73 | |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 74 | logmsg = logmsg + "\n\n"+" " * 30+"+--------+\n" +"-" * 28+" { Topology } "+"-" * 28 +"\n" +" " * 30+"+--------+\n" |
| 75 | values = "\n\t" + str(main.topology['COMPONENT']) |
| 76 | values = re.sub(",", "\n\t", values) |
| 77 | values = re.sub("{", "\n\t", values) |
| 78 | values = re.sub("}", "\n\t", values) |
admin | bae64d8 | 2013-08-01 10:50:15 -0700 | [diff] [blame] | 79 | logmsg = logmsg + values |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 80 | logmsg = logmsg + "\n"+"-" * 60+"\n" |
Jon Hall | 81d3d39 | 2015-04-24 14:40:35 -0700 | [diff] [blame] | 81 | |
admin | bae64d8 | 2013-08-01 10:50:15 -0700 | [diff] [blame] | 82 | # enter into log file all headers |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 83 | logfile = open(main.LogFileName,"w+") |
| 84 | logfile.write (logmsg) |
admin | bae64d8 | 2013-08-01 10:50:15 -0700 | [diff] [blame] | 85 | print logmsg |
| 86 | main.logHeader = logmsg |
admin | bae64d8 | 2013-08-01 10:50:15 -0700 | [diff] [blame] | 87 | logfile.close() |
Jon Hall | 81d3d39 | 2015-04-24 14:40:35 -0700 | [diff] [blame] | 88 | |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 89 | #enter into report file all headers |
| 90 | main.reportFile = open(main.ReportFileName,"w+") |
| 91 | main.reportFile.write(logmsg) |
admin | bae64d8 | 2013-08-01 10:50:15 -0700 | [diff] [blame] | 92 | main.reportFile.close() |
Jon Hall | 81d3d39 | 2015-04-24 14:40:35 -0700 | [diff] [blame] | 93 | |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 94 | #Sumamry file header |
| 95 | currentTime = str( main.STARTTIME.strftime("%d %b %Y %H:%M:%S") ) |
Jon Hall | 79bec22 | 2015-04-30 16:23:30 -0700 | [diff] [blame] | 96 | main.summaryFile = open( main.SummaryFileName, "w+" ) |
| 97 | main.summaryFile.write( main.TEST + " at " + currentTime + "\n" ) |
| 98 | main.summaryFile.close() |
| 99 | |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 100 | #wiki file header |
| 101 | currentTime = str( main.STARTTIME.strftime("%d %b %Y %H:%M:%S") ) |
Jon Hall | 81d3d39 | 2015-04-24 14:40:35 -0700 | [diff] [blame] | 102 | main.wikiFile = open( main.WikiFileName, "w+" ) |
Jon Hall | 79bec22 | 2015-04-30 16:23:30 -0700 | [diff] [blame] | 103 | main.wikiFile.write( main.TEST + " at " + currentTime + "<p></p>\n" ) |
Jon Hall | 81d3d39 | 2015-04-24 14:40:35 -0700 | [diff] [blame] | 104 | main.wikiFile.close() |
| 105 | |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 106 | def initlog(self,main): |
| 107 | ''' |
admin | bae64d8 | 2013-08-01 10:50:15 -0700 | [diff] [blame] | 108 | Initialise all the log handles. |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 109 | ''' |
admin | bae64d8 | 2013-08-01 10:50:15 -0700 | [diff] [blame] | 110 | main._getTest() |
Jon Hall | 81d3d39 | 2015-04-24 14:40:35 -0700 | [diff] [blame] | 111 | main.STARTTIME = datetime.datetime.now() |
admin | bae64d8 | 2013-08-01 10:50:15 -0700 | [diff] [blame] | 112 | |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 113 | currentTime = re.sub("-|\s|:|\.", "_", str(main.STARTTIME.strftime("%d %b %Y %H:%M:%S"))) |
admin | bae64d8 | 2013-08-01 10:50:15 -0700 | [diff] [blame] | 114 | if main.logdir: |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 115 | main.logdir = main.logdir+ "/"+main.TEST + "_" + currentTime |
admin | bae64d8 | 2013-08-01 10:50:15 -0700 | [diff] [blame] | 116 | else: |
| 117 | main.logdir = main.logs_path + main.TEST + "_" + currentTime |
Jon Hall | 81d3d39 | 2015-04-24 14:40:35 -0700 | [diff] [blame] | 118 | |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 119 | os.mkdir(main.logdir) |
Jon Hall | 81d3d39 | 2015-04-24 14:40:35 -0700 | [diff] [blame] | 120 | |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 121 | main.LogFileName = main.logdir + "/" + main.TEST + "_" +str(currentTime) + ".log" |
| 122 | main.ReportFileName = main.logdir + "/" + main.TEST + "_" + str(currentTime) + ".rpt" |
Jon Hall | 79bec22 | 2015-04-30 16:23:30 -0700 | [diff] [blame] | 123 | main.WikiFileName = main.logdir + "/" + main.TEST + "Wiki.txt" |
| 124 | main.SummaryFileName = main.logdir + "/" + main.TEST + "Summary.txt" |
Jon Hall | 94fd047 | 2014-12-08 11:52:42 -0800 | [diff] [blame] | 125 | main.JenkinsCSV = main.logdir + "/" + main.TEST + ".csv" |
Devin Lim | 90803a8 | 2017-08-29 13:41:44 -0700 | [diff] [blame] | 126 | main.resultFile = main.logdir + "/" + main.TEST + "Result.txt" |
| 127 | |
Jon Hall | 2507978 | 2015-10-13 13:54:39 -0700 | [diff] [blame] | 128 | main.TOTAL_TC_SUCCESS = 0 |
Jon Hall | 81d3d39 | 2015-04-24 14:40:35 -0700 | [diff] [blame] | 129 | |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 130 | #### Add log-level - Report |
| 131 | logging.addLevelName(9, "REPORT") |
| 132 | logging.addLevelName(7, "EXACT") |
| 133 | logging.addLevelName(11, "CASE") |
| 134 | logging.addLevelName(12, "STEP") |
| 135 | main.log = logging.getLogger(main.TEST) |
| 136 | def report(msg): |
| 137 | ''' |
admin | bae64d8 | 2013-08-01 10:50:15 -0700 | [diff] [blame] | 138 | Will append the report message to the logs. |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 139 | ''' |
| 140 | main.log._log(9,msg,"OpenFlowAutoMattion","OFAutoMation") |
admin | bae64d8 | 2013-08-01 10:50:15 -0700 | [diff] [blame] | 141 | currentTime = datetime.datetime.now() |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 142 | currentTime = currentTime.strftime("%d %b %Y %H:%M:%S") |
| 143 | newmsg = "\n[REPORT] " +"["+ str(currentTime)+"] "+msg |
admin | bae64d8 | 2013-08-01 10:50:15 -0700 | [diff] [blame] | 144 | print newmsg |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 145 | main.reportFile = open(main.ReportFileName,"a+") |
| 146 | main.reportFile.write(newmsg) |
admin | bae64d8 | 2013-08-01 10:50:15 -0700 | [diff] [blame] | 147 | main.reportFile.close() |
Jon Hall | 81d3d39 | 2015-04-24 14:40:35 -0700 | [diff] [blame] | 148 | |
| 149 | main.log.report = report |
| 150 | |
Jon Hall | 79bec22 | 2015-04-30 16:23:30 -0700 | [diff] [blame] | 151 | def summary( msg ): |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 152 | ''' |
Jon Hall | 79bec22 | 2015-04-30 16:23:30 -0700 | [diff] [blame] | 153 | Will append the message to the txt file for the summary. |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 154 | ''' |
| 155 | main.log._log(6,msg,"OpenFlowAutoMattion","OFAutoMation") |
| 156 | main.summaryFile = open(main.SummaryFileName,"a+") |
| 157 | main.summaryFile.write(msg+"\n") |
Jon Hall | 79bec22 | 2015-04-30 16:23:30 -0700 | [diff] [blame] | 158 | main.summaryFile.close() |
| 159 | |
| 160 | main.log.summary = summary |
| 161 | |
Jon Hall | 81d3d39 | 2015-04-24 14:40:35 -0700 | [diff] [blame] | 162 | def wiki( msg ): |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 163 | ''' |
Jon Hall | 81d3d39 | 2015-04-24 14:40:35 -0700 | [diff] [blame] | 164 | Will append the message to the txt file for the wiki. |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 165 | ''' |
| 166 | main.log._log(6,msg,"OpenFlowAutoMattion","OFAutoMation") |
| 167 | main.wikiFile = open(main.WikiFileName,"a+") |
| 168 | main.wikiFile.write(msg+"\n") |
Jon Hall | 81d3d39 | 2015-04-24 14:40:35 -0700 | [diff] [blame] | 169 | main.wikiFile.close() |
| 170 | |
| 171 | main.log.wiki = wiki |
| 172 | |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 173 | def exact(exmsg): |
| 174 | ''' |
admin | bae64d8 | 2013-08-01 10:50:15 -0700 | [diff] [blame] | 175 | Will append the raw formatted message to the logs |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 176 | ''' |
| 177 | main.log._log(7,exmsg,"OpenFlowAutoMattion","OFAutoMation") |
| 178 | main.reportFile = open(main.ReportFileName,"a+") |
| 179 | main.reportFile.write(exmsg) |
admin | bae64d8 | 2013-08-01 10:50:15 -0700 | [diff] [blame] | 180 | main.reportFile.close() |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 181 | logfile = open(main.LogFileName,"a") |
| 182 | logfile.write("\n"+ str(exmsg) +"\n") |
admin | bae64d8 | 2013-08-01 10:50:15 -0700 | [diff] [blame] | 183 | logfile.close() |
| 184 | print exmsg |
Jon Hall | 81d3d39 | 2015-04-24 14:40:35 -0700 | [diff] [blame] | 185 | |
| 186 | main.log.exact = exact |
| 187 | |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 188 | def case(msg): |
| 189 | ''' |
admin | bae64d8 | 2013-08-01 10:50:15 -0700 | [diff] [blame] | 190 | Format of the case type log defined here. |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 191 | ''' |
| 192 | main.log._log(9,msg,"OpenFlowAutoMattion","OFAutoMation") |
admin | bae64d8 | 2013-08-01 10:50:15 -0700 | [diff] [blame] | 193 | currentTime = datetime.datetime.now() |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 194 | newmsg = "["+str(currentTime)+"] " + "["+main.TEST+"] " + "[CASE] " +msg |
| 195 | logfile = open(main.LogFileName,"a") |
| 196 | logfile.write("\n"+ str(newmsg) +"\n") |
admin | bae64d8 | 2013-08-01 10:50:15 -0700 | [diff] [blame] | 197 | logfile.close() |
| 198 | print newmsg |
Jon Hall | 81d3d39 | 2015-04-24 14:40:35 -0700 | [diff] [blame] | 199 | |
Jon Hall | 4ba53f0 | 2015-07-29 13:07:41 -0700 | [diff] [blame] | 200 | main.log.case = case |
Jon Hall | 81d3d39 | 2015-04-24 14:40:35 -0700 | [diff] [blame] | 201 | |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 202 | def step(msg): |
| 203 | ''' |
admin | bae64d8 | 2013-08-01 10:50:15 -0700 | [diff] [blame] | 204 | Format of the step type log defined here. |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 205 | ''' |
| 206 | main.log._log(9,msg,"OpenFlowAutoMattion","OFAutoMation") |
admin | bae64d8 | 2013-08-01 10:50:15 -0700 | [diff] [blame] | 207 | currentTime = datetime.datetime.now() |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 208 | newmsg = "["+str(currentTime)+"] " + "["+main.TEST+"] " + "[STEP] " +msg |
| 209 | logfile = open(main.LogFileName,"a") |
| 210 | logfile.write("\n"+ str(newmsg) +"\n") |
admin | bae64d8 | 2013-08-01 10:50:15 -0700 | [diff] [blame] | 211 | logfile.close() |
| 212 | print newmsg |
Jon Hall | 81d3d39 | 2015-04-24 14:40:35 -0700 | [diff] [blame] | 213 | |
| 214 | main.log.step = step |
| 215 | |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 216 | main.LogFileHandler = logging.FileHandler(main.LogFileName) |
| 217 | self._printHeader(main) |
admin | bae64d8 | 2013-08-01 10:50:15 -0700 | [diff] [blame] | 218 | |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 219 | ### initializing logging module and settig log level |
| 220 | main.log.setLevel(logging.INFO) |
| 221 | main.log.setLevel(logging.DEBUG) # Temporary |
| 222 | main.LogFileHandler.setLevel(logging.INFO) |
Jon Hall | 81d3d39 | 2015-04-24 14:40:35 -0700 | [diff] [blame] | 223 | |
admin | bae64d8 | 2013-08-01 10:50:15 -0700 | [diff] [blame] | 224 | # create console handler with a higher log level |
| 225 | main.ConsoleHandler = logging.StreamHandler() |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 226 | main.ConsoleHandler.setLevel(logging.INFO) |
| 227 | main.ConsoleHandler.setLevel(logging.DEBUG) #Temporary |
admin | bae64d8 | 2013-08-01 10:50:15 -0700 | [diff] [blame] | 228 | # create formatter and add it to the handlers |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 229 | #formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s') |
Jon Hall | 0bde9ba | 2015-03-19 11:32:57 -0700 | [diff] [blame] | 230 | class MyFormatter( logging.Formatter ): |
| 231 | colors = { 'cyan': '\033[96m', 'purple': '\033[95m', |
| 232 | 'blue': '\033[94m', 'green': '\033[92m', |
| 233 | 'yellow': '\033[93m', 'red': '\033[91m', |
| 234 | 'end': '\033[0m' } |
| 235 | |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 236 | FORMATS = {'DEFAULT': '%(asctime)s - %(name)s - %(levelname)s - %(message)s'} |
Jon Hall | 0bde9ba | 2015-03-19 11:32:57 -0700 | [diff] [blame] | 237 | if COLORS: # NOTE:colors will only be loaded if command is run from one line |
| 238 | # IE: './cli.py run testname' |
| 239 | # This is to prevent issues with Jenkins parsing |
| 240 | # TODO: Make colors configurable |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 241 | levels = { logging.ERROR : colors['red'] + |
| 242 | FORMATS['DEFAULT'] + |
| 243 | colors['end'], |
| 244 | logging.WARN : colors['yellow'] + |
| 245 | FORMATS['DEFAULT'] + |
| 246 | colors['end'], |
| 247 | logging.DEBUG : colors['purple'] + |
| 248 | FORMATS['DEFAULT'] + |
| 249 | colors['end'] } |
Jon Hall | 0bde9ba | 2015-03-19 11:32:57 -0700 | [diff] [blame] | 250 | FORMATS.update( levels ) |
| 251 | |
| 252 | def format( self, record ): |
| 253 | self._fmt = self.FORMATS.get( record.levelno, |
| 254 | self.FORMATS[ 'DEFAULT' ] ) |
| 255 | return logging.Formatter.format( self, record ) |
| 256 | formatter = MyFormatter() |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 257 | main.ConsoleHandler.setFormatter(formatter) |
| 258 | main.LogFileHandler.setFormatter(formatter) |
admin | bae64d8 | 2013-08-01 10:50:15 -0700 | [diff] [blame] | 259 | |
| 260 | # add the handlers to logger |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 261 | main.log.addHandler(main.ConsoleHandler) |
| 262 | main.log.addHandler(main.LogFileHandler) |
Jon Hall | 81d3d39 | 2015-04-24 14:40:35 -0700 | [diff] [blame] | 263 | |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 264 | def testSummary(self,main): |
| 265 | ''' |
admin | bae64d8 | 2013-08-01 10:50:15 -0700 | [diff] [blame] | 266 | testSummary will take care about the Summary of test. |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 267 | ''' |
| 268 | |
admin | bae64d8 | 2013-08-01 10:50:15 -0700 | [diff] [blame] | 269 | main.ENDTIME = datetime.datetime.now() |
| 270 | main.EXECTIME = main.ENDTIME - main.STARTTIME |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 271 | if (main.TOTAL_TC_PASS == 0): |
admin | bae64d8 | 2013-08-01 10:50:15 -0700 | [diff] [blame] | 272 | main.TOTAL_TC_SUCCESS = 0 |
| 273 | else: |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 274 | main.TOTAL_TC_SUCCESS = str((main.TOTAL_TC_PASS*100)/main.TOTAL_TC_RUN) |
| 275 | if (main.TOTAL_TC_RUN == 0) : |
admin | bae64d8 | 2013-08-01 10:50:15 -0700 | [diff] [blame] | 276 | main.TOTAL_TC_EXECPERCENT = 0 |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 277 | else : |
| 278 | main.TOTAL_TC_EXECPERCENT = str((main.TOTAL_TC_RUN*100)/main.TOTAL_TC_PLANNED) |
| 279 | testResult = "\n\n"+"*" * 37+"\n" + "\tTest Execution Summary\n" + "\n"+"*" * 37+" \n" |
| 280 | testResult = testResult + "\n Test Start : " + str(main.STARTTIME.strftime("%d %b %Y %H:%M:%S")) |
| 281 | testResult = testResult + "\n Test End : " + str(main.ENDTIME.strftime("%d %b %Y %H:%M:%S")) |
| 282 | testResult = testResult + "\n Execution Time : " + str(main.EXECTIME) |
| 283 | testResult = testResult + "\n Total tests planned : " + str(main.TOTAL_TC_PLANNED) |
| 284 | testResult = testResult + "\n Total tests RUN : " + str(main.TOTAL_TC_RUN) |
| 285 | testResult = testResult + "\n Total Pass : " + str(main.TOTAL_TC_PASS) |
| 286 | testResult = testResult + "\n Total Fail : " + str(main.TOTAL_TC_FAIL) |
| 287 | testResult = testResult + "\n Total No Result : " + str(main.TOTAL_TC_NORESULT) |
| 288 | testResult = testResult + "\n Success Percentage : " + str(main.TOTAL_TC_SUCCESS) + "%" |
| 289 | testResult = testResult + "\n Execution Result : " + str(main.TOTAL_TC_EXECPERCENT) + "%\n" |
Devin Lim | ec98979 | 2017-08-15 15:57:55 -0700 | [diff] [blame] | 290 | if main.failedCase: |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 291 | testResult = testResult + "\n Case Failed : " + str( main.failedCase ) |
Devin Lim | ec98979 | 2017-08-15 15:57:55 -0700 | [diff] [blame] | 292 | if main.noResultCase: |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 293 | testResult = testResult + "\n Case NoResult : " + str( main.noResultCase ) |
| 294 | testResult = testResult + "\n Case Executed : " + str( main.executedCase ) |
| 295 | testResult = testResult + "\n Case Not Executed : " + str( main.leftCase ) |
| 296 | #main.log.report(testResult) |
admin | bae64d8 | 2013-08-01 10:50:15 -0700 | [diff] [blame] | 297 | main.testResult = testResult |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 298 | main.log.exact(testResult) |
Jon Hall | 94fd047 | 2014-12-08 11:52:42 -0800 | [diff] [blame] | 299 | |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 300 | ##CSV output needed for Jenkin's plot plugin |
| 301 | #NOTE: the elements were orded based on the colors assigned to the data |
| 302 | logfile = open(main.JenkinsCSV ,"w") |
| 303 | logfile.write(",".join( ['Tests Failed', 'Tests Passed', 'Tests Planned'] ) + "\n") |
| 304 | logfile.write(",".join( [str(int(main.TOTAL_TC_FAIL)), str(int(main.TOTAL_TC_PASS)), str(int(main.TOTAL_TC_PLANNED))] ) + "\n") |
Jon Hall | 94fd047 | 2014-12-08 11:52:42 -0800 | [diff] [blame] | 305 | logfile.close() |
| 306 | |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 307 | executedStatus = open(main.resultFile, "w") |
Devin Lim | 90803a8 | 2017-08-29 13:41:44 -0700 | [diff] [blame] | 308 | if main.TOTAL_TC_FAIL == 0 and main.TOTAL_TC_NORESULT + main.TOTAL_TC_PASS == main.TOTAL_TC_PLANNED: |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 309 | executedStatus.write("1\n") |
Devin Lim | 90803a8 | 2017-08-29 13:41:44 -0700 | [diff] [blame] | 310 | else: |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 311 | executedStatus.write("0\n") |
Devin Lim | 90803a8 | 2017-08-29 13:41:44 -0700 | [diff] [blame] | 312 | executedStatus.close() |
| 313 | |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 314 | def updateCaseResults(self,main): |
| 315 | ''' |
admin | bae64d8 | 2013-08-01 10:50:15 -0700 | [diff] [blame] | 316 | Update the case result based on the steps execution and asserting each step in the test-case |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 317 | ''' |
| 318 | case = str(main.CurrentTestCaseNumber) |
| 319 | currentResult = main.testCaseResult.get(case, 2) |
Jon Hall | 81d3d39 | 2015-04-24 14:40:35 -0700 | [diff] [blame] | 320 | |
Jon Hall | 79bec22 | 2015-04-30 16:23:30 -0700 | [diff] [blame] | 321 | if currentResult == 2: |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 322 | main.TOTAL_TC_RUN = main.TOTAL_TC_RUN + 1 |
admin | bae64d8 | 2013-08-01 10:50:15 -0700 | [diff] [blame] | 323 | main.TOTAL_TC_NORESULT = main.TOTAL_TC_NORESULT + 1 |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 324 | main.log.exact("\n "+"*" * 29+"\n" + "\n Result: No Assertion Called \n"+"*" * 29+"\n") |
| 325 | line = "Case "+case+": "+main.CurrentTestCase+" - No Result" |
Jon Hall | 79bec22 | 2015-04-30 16:23:30 -0700 | [diff] [blame] | 326 | elif currentResult == 1: |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 327 | main.TOTAL_TC_RUN = main.TOTAL_TC_RUN + 1 |
| 328 | main.TOTAL_TC_PASS = main.TOTAL_TC_PASS + 1 |
| 329 | main.log.exact("\n"+"*" * 29+"\n Result: Pass \n"+"*" * 29+"\n") |
| 330 | line = "Case "+case+": "+main.CurrentTestCase+" - PASS" |
Jon Hall | 79bec22 | 2015-04-30 16:23:30 -0700 | [diff] [blame] | 331 | elif currentResult == 0: |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 332 | main.TOTAL_TC_RUN = main.TOTAL_TC_RUN + 1 |
admin | bae64d8 | 2013-08-01 10:50:15 -0700 | [diff] [blame] | 333 | main.TOTAL_TC_FAIL = main.TOTAL_TC_FAIL + 1 |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 334 | main.log.exact("\n"+"*" * 29+"\n Result: Failed \n"+"*" * 29+"\n") |
| 335 | line = "Case "+case+": "+main.CurrentTestCase+" - FAIL" |
Jon Hall | 79bec22 | 2015-04-30 16:23:30 -0700 | [diff] [blame] | 336 | else: |
| 337 | main.log.error( " Unknown result of case " + case + |
| 338 | ". Result was: " + currentResult ) |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 339 | line = "Case "+case+": "+main.CurrentTestCase+" - ERROR" |
Jon Hall | 79bec22 | 2015-04-30 16:23:30 -0700 | [diff] [blame] | 340 | main.log.wiki( "<h3>" + line + "</h3>" ) |
| 341 | main.log.summary( line ) |
Jeremy Ronquillo | 4d5f1d0 | 2017-10-13 20:23:57 +0000 | [diff] [blame] | 342 | |