From 4b92aa9c605e053f4ce3dcfd0f1caac72333ef78 Mon Sep 17 00:00:00 2001 From: clausherther Date: Mon, 2 Nov 2020 16:42:55 -0700 Subject: [PATCH] Refactor row count tests --- .../expect_table_row_count_to_be_between.sql | 22 +++++++++---------- .../expect_table_row_count_to_equal.sql | 13 ++++++----- 2 files changed, 18 insertions(+), 17 deletions(-) diff --git a/macros/schema_tests/table_shape/expect_table_row_count_to_be_between.sql b/macros/schema_tests/table_shape/expect_table_row_count_to_be_between.sql index 762b4f0..99a7ac8 100644 --- a/macros/schema_tests/table_shape/expect_table_row_count_to_be_between.sql +++ b/macros/schema_tests/table_shape/expect_table_row_count_to_be_between.sql @@ -4,16 +4,14 @@ partition_column=None, partition_filter=None ) -%} -with row_count as ( - select count(*) as cnt - from {{ model }} - {% if partition_column and partition_filter %} - where {{ partition_column }} {{ partition_filter }} - {% endif %} -) -select count(*) -from - row_count -where cnt < {{ minimum }} or - cnt > {{ maximum }} +{% set expression %} +count(*) +{% endset %} +{{ dbt_expectations.expression_between(model, + expression=expression, + minimum=minimum, + maximum=maximum, + partition_column=partition_column, + partition_filter=partition_filter + ) }} {%- endmacro -%} \ No newline at end of file diff --git a/macros/schema_tests/table_shape/expect_table_row_count_to_equal.sql b/macros/schema_tests/table_shape/expect_table_row_count_to_equal.sql index 927f5a3..2196ded 100644 --- a/macros/schema_tests/table_shape/expect_table_row_count_to_equal.sql +++ b/macros/schema_tests/table_shape/expect_table_row_count_to_equal.sql @@ -3,9 +3,12 @@ partition_column=None, partition_filter=None ) -%} -select abs({{ expected_number_of_rows }} - count(*)) -from {{ model }} -{% if partition_column and partition_filter %} -where {{ partition_column }} {{ partition_filter }} -{% endif %} +{% set filter_cond = partition_column ~ " " ~ partition_filter if partition_column and partition_filter else None %} +{% set expression %} +count(*) = {{ expected_number_of_rows }} +{% endset %} +{{ dbt_expectations.expression_is_true(model, + expression=expression, + filter_cond=filter_cond) + }} {%- endmacro -%} \ No newline at end of file