blob: acd3bb1ef74607fa06368e08923ab8cc491c82ee [file] [log] [blame]
Alex3ebc5632019-04-18 16:47:18 -05001from cfg_checker.common import logger_cli
Alexe0c5b9e2019-04-23 18:51:23 -05002from cfg_checker.modules.network.mapper import NetworkMapper
Alex3ebc5632019-04-18 16:47:18 -05003from cfg_checker.modules.network.network_errors import NetworkErrors
Alex Savatieievf526dc02019-03-06 10:11:32 -06004from cfg_checker.reports import reporter
Alex Savatieiev9b2f6512019-02-20 18:05:00 -06005
6
Alexe0c5b9e2019-04-23 18:51:23 -05007class NetworkChecker(object):
Alex3ebc5632019-04-18 16:47:18 -05008 def __init__(self):
Alexe0c5b9e2019-04-23 18:51:23 -05009 logger_cli.debug("... init error logs folder")
Alex3ebc5632019-04-18 16:47:18 -050010 self.errors = NetworkErrors()
Alexe0c5b9e2019-04-23 18:51:23 -050011 self.mapper = NetworkMapper(self.errors)
Alex3ebc5632019-04-18 16:47:18 -050012
Alex836fac82019-08-22 13:36:16 -050013 def check_networks(self, map=True):
Alexe0c5b9e2019-04-23 18:51:23 -050014 self.mapper.map_network(self.mapper.RECLASS)
15 self.mapper.map_network(self.mapper.RUNTIME)
Alex3ebc5632019-04-18 16:47:18 -050016
Alex836fac82019-08-22 13:36:16 -050017 self.mapper.create_map()
18 if map:
19 self.mapper.print_map()
Alex Savatieiev42b89fa2019-03-07 18:45:26 -060020
Alex3ebc5632019-04-18 16:47:18 -050021 def print_summary(self):
Alex3ebc5632019-04-18 16:47:18 -050022 logger_cli.info(self.errors.get_summary(print_zeros=False))
Alex3ebc5632019-04-18 16:47:18 -050023
24 def print_error_details(self):
25 # Detailed errors
Alexb151fbe2019-04-22 16:53:30 -050026 logger_cli.info(
27 "\n{}\n".format(
28 self.errors.get_errors()
29 )
30 )
Alex3ebc5632019-04-18 16:47:18 -050031
Alex Savatieiev9b2f6512019-02-20 18:05:00 -060032 def create_html_report(self, filename):
33 """
34 Create static html showing network schema-like report
35
36 :return: none
37 """
38 logger_cli.info("### Generating report to '{}'".format(filename))
39 _report = reporter.ReportToFile(
40 reporter.HTMLNetworkReport(),
41 filename
42 )
43 _report({
Alex836fac82019-08-22 13:36:16 -050044 "nodes": self.mapper.nodes,
45 "map": self.mapper.map,
46 "mcp_release": self.mapper.cluster['mcp_release'],
47 "openstack_release": self.mapper.cluster['openstack_release']
Alex41485522019-04-12 17:26:18 -050048
Alex Savatieiev9b2f6512019-02-20 18:05:00 -060049 })
50 logger_cli.info("-> Done")