Alex Savatieiev | c905571 | 2019-03-01 14:43:56 -0600 | [diff] [blame] | 1 | import os |
| 2 | |
Alex Savatieiev | c905571 | 2019-03-01 14:43:56 -0600 | [diff] [blame] | 3 | from cfg_checker.common import logger_cli |
| 4 | from cfg_checker.helpers import args_utils |
| 5 | from cfg_checker.reports import reporter |
| 6 | |
Alex | 3ebc563 | 2019-04-18 16:47:18 -0500 | [diff] [blame] | 7 | import comparer |
| 8 | |
| 9 | import validator |
| 10 | |
Alex Savatieiev | c905571 | 2019-03-01 14:43:56 -0600 | [diff] [blame] | 11 | |
| 12 | def do_list(args): |
| 13 | logger_cli.info("# Reclass list") |
Alex | 4148552 | 2019-04-12 17:26:18 -0500 | [diff] [blame] | 14 | _arg_path = args_utils.get_arg(args, 'models_path') |
| 15 | logger_cli.info("-> Current path is: {}".format(_arg_path)) |
| 16 | _path = args_utils.get_path_arg(_arg_path) |
Alex | 3ebc563 | 2019-04-18 16:47:18 -0500 | [diff] [blame] | 17 | |
| 18 | logger_cli.info("# ...models path is '{}'".format(_path)) |
| 19 | |
Alex Savatieiev | c905571 | 2019-03-01 14:43:56 -0600 | [diff] [blame] | 20 | models = {} |
| 21 | for _folder in os.listdir(args.models_path): |
| 22 | # validate item as a model |
| 23 | _model_path = os.path.join( |
| 24 | args.models_path, |
| 25 | _folder |
| 26 | ) |
| 27 | _validated = validator.basic_model_validation_by_path(_model_path) |
Alex | 3ebc563 | 2019-04-18 16:47:18 -0500 | [diff] [blame] | 28 | |
Alex Savatieiev | c905571 | 2019-03-01 14:43:56 -0600 | [diff] [blame] | 29 | if not _validated: |
| 30 | logger_cli.info("-> '{}' not a valid model".format(_folder)) |
| 31 | continue |
| 32 | else: |
| 33 | models[_folder] = _model_path |
Alex | 3ebc563 | 2019-04-18 16:47:18 -0500 | [diff] [blame] | 34 | |
Alex Savatieiev | c905571 | 2019-03-01 14:43:56 -0600 | [diff] [blame] | 35 | logger_cli.info("-> '{}' at '{}'".format(_folder, _model_path)) |
Alex | 3ebc563 | 2019-04-18 16:47:18 -0500 | [diff] [blame] | 36 | |
Alex Savatieiev | c905571 | 2019-03-01 14:43:56 -0600 | [diff] [blame] | 37 | # TODO: collect info about the model |
| 38 | |
| 39 | return |
| 40 | |
| 41 | |
| 42 | def do_diff(args): |
Alex | b8af13a | 2019-04-16 18:38:12 -0500 | [diff] [blame] | 43 | logger_cli.info("# Reclass comparer (HTML report)") |
Alex | 4148552 | 2019-04-12 17:26:18 -0500 | [diff] [blame] | 44 | _filename = args_utils.get_arg(args, 'html') |
Alex Savatieiev | c905571 | 2019-03-01 14:43:56 -0600 | [diff] [blame] | 45 | # checking folder params |
| 46 | _model1 = args_utils.get_path_arg(args.model1) |
| 47 | _model2 = args_utils.get_path_arg(args.model2) |
Alex | 3ebc563 | 2019-04-18 16:47:18 -0500 | [diff] [blame] | 48 | |
Alex Savatieiev | c905571 | 2019-03-01 14:43:56 -0600 | [diff] [blame] | 49 | # Do actual compare using hardcoded model names |
| 50 | mComparer = comparer.ModelComparer() |
| 51 | |
| 52 | mComparer.model_name_1 = os.path.split(_model1)[1] |
| 53 | mComparer.model_path_1 = _model1 |
| 54 | mComparer.model_name_2 = os.path.split(_model2)[1] |
| 55 | mComparer.model_path_2 = _model2 |
Alex | 3ebc563 | 2019-04-18 16:47:18 -0500 | [diff] [blame] | 56 | |
Alex Savatieiev | c905571 | 2019-03-01 14:43:56 -0600 | [diff] [blame] | 57 | mComparer.load_model_tree( |
| 58 | mComparer.model_name_1, |
| 59 | mComparer.model_path_1 |
| 60 | ) |
| 61 | mComparer.load_model_tree( |
| 62 | mComparer.model_name_2, |
| 63 | mComparer.model_path_2 |
| 64 | ) |
| 65 | |
| 66 | diffs = mComparer.generate_model_report_tree() |
| 67 | |
| 68 | report = reporter.ReportToFile( |
| 69 | reporter.HTMLModelCompare(), |
| 70 | _filename |
| 71 | ) |
| 72 | logger_cli.info("# Generating report to {}".format(_filename)) |
| 73 | report({ |
| 74 | "nodes": {}, |
| 75 | "diffs": diffs |
| 76 | }) |