blob: c590d135a53c8296f2095c8c412cdd7ef0e5bd21 [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):
Alexe9908f72020-05-19 16:04:53 -05008 def __init__(
9 self,
10 skip_list=None,
11 skip_list_file=None
12 ):
Alexe0c5b9e2019-04-23 18:51:23 -050013 logger_cli.debug("... init error logs folder")
Alex3ebc5632019-04-18 16:47:18 -050014 self.errors = NetworkErrors()
Alexe9908f72020-05-19 16:04:53 -050015 self.mapper = NetworkMapper(
16 self.errors,
17 skip_list=skip_list,
18 skip_list_file=skip_list_file
19 )
Alex3ebc5632019-04-18 16:47:18 -050020
Alex836fac82019-08-22 13:36:16 -050021 def check_networks(self, map=True):
Alexe0c5b9e2019-04-23 18:51:23 -050022 self.mapper.map_network(self.mapper.RECLASS)
23 self.mapper.map_network(self.mapper.RUNTIME)
Alex3ebc5632019-04-18 16:47:18 -050024
Alex836fac82019-08-22 13:36:16 -050025 self.mapper.create_map()
26 if map:
27 self.mapper.print_map()
Alex Savatieiev42b89fa2019-03-07 18:45:26 -060028
Alex3ebc5632019-04-18 16:47:18 -050029 def print_summary(self):
Alex3ebc5632019-04-18 16:47:18 -050030 logger_cli.info(self.errors.get_summary(print_zeros=False))
Alex3ebc5632019-04-18 16:47:18 -050031
32 def print_error_details(self):
33 # Detailed errors
Alexb151fbe2019-04-22 16:53:30 -050034 logger_cli.info(
35 "\n{}\n".format(
36 self.errors.get_errors()
37 )
38 )
Alex3ebc5632019-04-18 16:47:18 -050039
Alex Savatieiev9b2f6512019-02-20 18:05:00 -060040 def create_html_report(self, filename):
41 """
42 Create static html showing network schema-like report
43
44 :return: none
45 """
46 logger_cli.info("### Generating report to '{}'".format(filename))
47 _report = reporter.ReportToFile(
48 reporter.HTMLNetworkReport(),
49 filename
50 )
51 _report({
Alexe9908f72020-05-19 16:04:53 -050052 "domain": self.mapper.domain,
Alex836fac82019-08-22 13:36:16 -050053 "nodes": self.mapper.nodes,
54 "map": self.mapper.map,
55 "mcp_release": self.mapper.cluster['mcp_release'],
56 "openstack_release": self.mapper.cluster['openstack_release']
Alex41485522019-04-12 17:26:18 -050057
Alex Savatieiev9b2f6512019-02-20 18:05:00 -060058 })
59 logger_cli.info("-> Done")