1 # Copyright (c) 2021 Cisco and/or its affiliates.
2 # Licensed under the Apache License, Version 2.0 (the "License");
3 # you may not use this file except in compliance with the License.
4 # You may obtain a copy of the License at:
6 # http://www.apache.org/licenses/LICENSE-2.0
8 # Unless required by applicable law or agreed to in writing, software
9 # distributed under the License is distributed on an "AS IS" BASIS,
10 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
11 # See the License for the specific language governing permissions and
12 # limitations under the License.
14 """CSIT Presentation and Analytics Layer.
21 from pal_errors import PresentationError
22 from specification_parser import Specification
23 from environment import Environment, clean_environment
24 from static_content import prepare_static_content
25 from input_data_parser import InputData
26 from generator_tables import generate_tables
27 from generator_plots import generate_plots
28 from generator_files import generate_files
29 from generator_report import generate_report
30 from generator_cpta import generate_cpta
31 from generator_alerts import Alerting, AlertingError
34 OUTPUTS = (u"none", u"report", u"trending", u"convert_to_json")
38 """Parse arguments from cmd line.
40 :returns: Parsed arguments.
41 :rtype: ArgumentParser
44 parser = argparse.ArgumentParser(
46 formatter_class=argparse.RawDescriptionHelpFormatter
49 u"-s", u"--specification",
52 help=u"Specification YAML file."
58 help=u"Release string of the product."
64 help=u"Calendar week when the report is published."
69 u"NOTSET", u"DEBUG", u"INFO", u"WARNING", u"ERROR", u"CRITICAL"
72 help=u"Logging level."
77 help=u"Force removing the old build(s) if present."
80 u"-o", u"--print-all-oper-data",
82 help=u"Print all operational data to console. Be careful, the output "
83 u"can be really long."
86 u"-i", u"--input-file",
89 help=u"XML file generated by RobotFramework which will be processed "
90 u"instead of downloading the data from Nexus and/or Jenkins. In "
91 u"this case, the section 'input' in the specification file is "
95 u"-d", u"--input-directory",
98 help=u"Directory with XML file(s) generated by RobotFramework or with "
99 u"sub-directories with XML file(s) which will be processed "
100 u"instead of downloading the data from Nexus and/or Jenkins. In "
101 u"this case, the section 'input' in the specification file is "
105 return parser.parse_args()
112 u"NOTSET": logging.NOTSET,
113 u"DEBUG": logging.DEBUG,
114 u"INFO": logging.INFO,
115 u"WARNING": logging.WARNING,
116 u"ERROR": logging.ERROR,
117 u"CRITICAL": logging.CRITICAL
122 format=u"%(asctime)s: %(levelname)s: %(message)s",
123 datefmt=u"%Y/%m/%d %H:%M:%S",
124 level=log_levels[args.logging]
127 logging.info(u"Application started.")
130 spec = Specification(args.specification)
131 spec.read_specification()
132 except PresentationError as err:
133 logging.critical(u"Finished with error.")
136 if spec.output[u"output"] not in OUTPUTS:
138 f"The output {spec.output[u'output']} is not supported."
144 env = Environment(spec.environment, args.force)
145 env.set_environment()
147 prepare_static_content(spec)
149 data = InputData(spec)
151 data.process_local_file(args.input_file)
152 elif args.input_directory:
153 data.process_local_directory(args.input_directory)
155 data.download_and_parse_data(repeat=1)
157 if args.print_all_oper_data:
158 data.print_all_oper_data()
160 generate_tables(spec, data)
161 generate_plots(spec, data)
162 generate_files(spec, data)
164 if spec.output[u"output"] == u"report":
165 generate_report(args.release, spec, args.week)
166 elif spec.output[u"output"] == u"trending":
167 sys.stdout.write(generate_cpta(spec, data))
169 alert = Alerting(spec)
170 alert.generate_alerts()
171 except AlertingError as err:
172 logging.warning(repr(err))
174 logging.info("No output will be generated.")
176 logging.info(u"Successfully finished.")
179 except AlertingError as err:
180 logging.critical(f"Finished with an alerting error.\n{repr(err)}")
181 except PresentationError as err:
182 logging.critical(f"Finished with a PAL error.\n{str(err)}")
183 except (KeyError, ValueError) as err:
184 logging.critical(f"Finished with an error.\n{repr(err)}")
187 clean_environment(spec.environment)
191 if __name__ == u"__main__":