From c180b9fa713668a6aef82e6a69f1d6631971bb4e Mon Sep 17 00:00:00 2001 From: "Wei-Chun, Chang" Date: Thu, 31 Aug 2023 12:02:01 +0800 Subject: [PATCH] Add metric statistics and skip message Signed-off-by: Wei-Chun, Chang --- piperider_cli/dbtutil.py | 25 ++++++++++++++----------- 1 file changed, 14 insertions(+), 11 deletions(-) diff --git a/piperider_cli/dbtutil.py b/piperider_cli/dbtutil.py index b5ac55f37..4dc813a5d 100644 --- a/piperider_cli/dbtutil.py +++ b/piperider_cli/dbtutil.py @@ -420,6 +420,7 @@ def is_chosen(key, metric): metric_map[metric.get('name')] = metric def _create_metric(name, filter=None, alias=None): + statistics = Statistics() metric = metric_map.get(name) if metric.get('type') == 'simple': @@ -490,21 +491,18 @@ def _create_metric(name, filter=None, alias=None): label=metric.get('label'), description=metric.get('description'), ref_id=metric.get('unique_id')) - statistics = Statistics() - statistics.add_field_one('total') - for f in m.model.filters: - if primary_entity not in f['field']: + if primary_entity in f['field']: + f['field'] = f['field'].replace(f'{primary_entity}__', '') + else: console.print( - f"[[bold yellow]Warning[/bold yellow]] Skip metric '{metric.get('name')}'. " - f"Property 'filter' is not supported.") + f"[[bold yellow]Skip[/bold yellow]] Metric '{metric.get('name')}'. " + f"Dimension of foreign entities is not supported.") statistics.add_field_one('nosupport') return None - else: - f['field'] = f['field'].replace(f'{primary_entity}__', '') if m.calculation_method == 'median': console.print( - f"[[bold yellow]Warning[/bold yellow]] Skip metric '{metric.get('name')}'. " + f"[[bold yellow]Skip[/bold yellow]] Metric '{metric.get('name')}'. " f"Aggregation type 'median' is not supported.") statistics.add_field_one('nosupport') return None @@ -517,8 +515,9 @@ def _create_metric(name, filter=None, alias=None): for ref_metric in metric.get('type_params').get('metrics'): if ref_metric.get('offset_window') is not None: console.print( - f"[[bold yellow]Warning[/bold yellow]] Skip metric '{metric.get('name')}'. " + f"[[bold yellow]Skip[/bold yellow]] Metric '{metric.get('name')}'. " f"Derived metric property 'offset_window' is not supported.") + statistics.add_field_one('nosupport') return None m2 = _create_metric( ref_metric.get('name'), @@ -572,11 +571,15 @@ def _create_metric(name, filter=None, alias=None): return m else: console.print( - f"[[bold yellow]Warning[/bold yellow]] Skip metric '{metric.get('name')}'. " + f"[[bold yellow]Skip[/bold yellow]] Metric '{metric.get('name')}'. " f"Metric type 'Cumulative' is not supported.") + statistics.add_field_one('nosupport') return None for key, metric in manifest.get('metrics').items(): + statistics = Statistics() + statistics.add_field_one('total') + if not is_chosen(key, metric): continue