sql-glider 0.1.16__tar.gz → 0.1.18__tar.gz
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- {sql_glider-0.1.16 → sql_glider-0.1.18}/PKG-INFO +1 -1
- {sql_glider-0.1.16 → sql_glider-0.1.18}/src/sqlglider/_version.py +2 -2
- {sql_glider-0.1.16 → sql_glider-0.1.18}/src/sqlglider/lineage/analyzer.py +5 -4
- {sql_glider-0.1.16 → sql_glider-0.1.18}/src/sqlglider/schema/extractor.py +13 -2
- {sql_glider-0.1.16 → sql_glider-0.1.18}/src/sqlglider/utils/schema.py +2 -2
- {sql_glider-0.1.16 → sql_glider-0.1.18}/tests/sqlglider/lineage/test_analyzer.py +16 -16
- {sql_glider-0.1.16 → sql_glider-0.1.18}/tests/sqlglider/schema/test_extractor.py +52 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/.github/workflows/ci.yml +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/.github/workflows/publish.yml +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/.gitignore +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/.python-version +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/ARCHITECTURE.md +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/CLAUDE.md +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/LICENSE +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/README.md +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/plans/2025-12-05-column-level-lineage.md +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/plans/2025-12-05-reverse-lineage.md +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/plans/2025-12-06-config-file-support.md +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/plans/2025-12-06-graph-lineage.md +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/plans/2025-12-06-unify-single-multi-query.md +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/plans/2025-12-07-sample-data-model.md +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/plans/2025-12-07-sql-templating.md +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/plans/2025-12-08-tables-command.md +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/plans/2025-12-09-graph-query-paths.md +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/plans/2025-12-13-dissect-command.md +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/plans/2025-12-14-tables-pull-command.md +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/plans/2026-01-25-fix-union-lineage-chain.md +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/plans/2026-01-26-file-scoped-schema-context.md +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/plans/2026-01-28-sparksql-table-extraction.md +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/plans/2026-01-29-no-star-flag.md +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/plans/2026-01-29-resolve-schema.md +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/plans/2026-01-29-schema-pruning-optimization.md +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/plans/2026-01-29-tables-scrape-command.md +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/pyproject.toml +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/sample_data_model/README.md +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/sample_data_model/business/expire_dim_customer.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/sample_data_model/business/load_fact_orders.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/sample_data_model/business/load_fact_payments.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/sample_data_model/business/merge_dim_customer.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/sample_data_model/business/merge_dim_product.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/sample_data_model/business/update_dim_customer_metrics.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/sample_data_model/complex/conditional_merge.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/sample_data_model/complex/cte_insert.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/sample_data_model/complex/multi_table_transform.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/sample_data_model/ddl/dim_customer.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/sample_data_model/ddl/dim_product.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/sample_data_model/ddl/fact_orders.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/sample_data_model/ddl/fact_payments.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/sample_data_model/ddl/raw_addresses.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/sample_data_model/ddl/raw_customers.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/sample_data_model/ddl/raw_order_items.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/sample_data_model/ddl/raw_orders.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/sample_data_model/ddl/raw_payments.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/sample_data_model/ddl/raw_products.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/sample_data_model/ddl/stg_customers.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/sample_data_model/ddl/stg_orders.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/sample_data_model/ddl/stg_payments.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/sample_data_model/ddl/stg_products.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/sample_data_model/incremental/incr_fact_orders.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/sample_data_model/incremental/incr_fact_payments.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/sample_data_model/incremental/incr_pres_sales_summary.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/sample_data_model/maintenance/delete_expired_customers.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/sample_data_model/maintenance/update_product_status.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/sample_data_model/presentation/load_pres_customer_360.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/sample_data_model/presentation/load_pres_customer_cohort.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/sample_data_model/presentation/load_pres_product_performance.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/sample_data_model/presentation/load_pres_sales_summary.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/sample_data_model/staging/load_stg_customers.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/sample_data_model/staging/load_stg_orders.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/sample_data_model/staging/load_stg_payments.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/sample_data_model/staging/load_stg_products.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/sqlglider.toml.example +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/src/sqlglider/__init__.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/src/sqlglider/catalog/__init__.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/src/sqlglider/catalog/base.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/src/sqlglider/catalog/databricks.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/src/sqlglider/catalog/registry.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/src/sqlglider/cli.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/src/sqlglider/dissection/__init__.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/src/sqlglider/dissection/analyzer.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/src/sqlglider/dissection/formatters.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/src/sqlglider/dissection/models.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/src/sqlglider/global_models.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/src/sqlglider/graph/__init__.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/src/sqlglider/graph/builder.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/src/sqlglider/graph/formatters.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/src/sqlglider/graph/merge.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/src/sqlglider/graph/models.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/src/sqlglider/graph/query.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/src/sqlglider/graph/serialization.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/src/sqlglider/lineage/__init__.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/src/sqlglider/lineage/formatters.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/src/sqlglider/schema/__init__.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/src/sqlglider/templating/__init__.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/src/sqlglider/templating/base.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/src/sqlglider/templating/jinja.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/src/sqlglider/templating/registry.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/src/sqlglider/templating/variables.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/src/sqlglider/utils/__init__.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/src/sqlglider/utils/config.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/src/sqlglider/utils/file_utils.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/tests/__init__.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/tests/fixtures/multi_file_queries/analytics_pipeline.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/tests/fixtures/multi_file_queries/analytics_pipeline_union_merge.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/tests/fixtures/multi_file_queries/customers.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/tests/fixtures/multi_file_queries/orders.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/tests/fixtures/multi_file_queries/reports.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/tests/fixtures/multi_file_queries/view_based_merge.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/tests/fixtures/original_queries/test_cte.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/tests/fixtures/original_queries/test_cte_query.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/tests/fixtures/original_queries/test_cte_view_star.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/tests/fixtures/original_queries/test_generated_column_query.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/tests/fixtures/original_queries/test_multi.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/tests/fixtures/original_queries/test_multi_query.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/tests/fixtures/original_queries/test_single_query.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/tests/fixtures/original_queries/test_subquery.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/tests/fixtures/original_queries/test_tables.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/tests/fixtures/original_queries/test_view.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/tests/fixtures/original_queries/test_view_window_cte.sql +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/tests/fixtures/sample_manifest.csv +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/tests/sqlglider/__init__.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/tests/sqlglider/catalog/__init__.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/tests/sqlglider/catalog/test_base.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/tests/sqlglider/catalog/test_databricks.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/tests/sqlglider/catalog/test_registry.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/tests/sqlglider/dissection/__init__.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/tests/sqlglider/dissection/test_analyzer.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/tests/sqlglider/dissection/test_formatters.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/tests/sqlglider/dissection/test_models.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/tests/sqlglider/graph/__init__.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/tests/sqlglider/graph/test_builder.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/tests/sqlglider/graph/test_formatters.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/tests/sqlglider/graph/test_merge.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/tests/sqlglider/graph/test_models.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/tests/sqlglider/graph/test_query.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/tests/sqlglider/graph/test_serialization.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/tests/sqlglider/lineage/__init__.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/tests/sqlglider/lineage/test_formatters.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/tests/sqlglider/schema/__init__.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/tests/sqlglider/templating/__init__.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/tests/sqlglider/templating/test_base.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/tests/sqlglider/templating/test_jinja.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/tests/sqlglider/templating/test_registry.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/tests/sqlglider/templating/test_variables.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/tests/sqlglider/test_cli.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/tests/sqlglider/utils/__init__.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/tests/sqlglider/utils/test_config.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/tests/sqlglider/utils/test_file_utils.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/tests/sqlglider/utils/test_schema.py +0 -0
- {sql_glider-0.1.16 → sql_glider-0.1.18}/uv.lock +0 -0
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Metadata-Version: 2.4
|
|
2
2
|
Name: sql-glider
|
|
3
|
-
Version: 0.1.
|
|
3
|
+
Version: 0.1.18
|
|
4
4
|
Summary: SQL Utility Toolkit for better understanding, use, and governance of your queries in a native environment.
|
|
5
5
|
Project-URL: Homepage, https://github.com/rycowhi/sql-glider/
|
|
6
6
|
Project-URL: Repository, https://github.com/rycowhi/sql-glider/
|
|
@@ -28,7 +28,7 @@ version_tuple: VERSION_TUPLE
|
|
|
28
28
|
commit_id: COMMIT_ID
|
|
29
29
|
__commit_id__: COMMIT_ID
|
|
30
30
|
|
|
31
|
-
__version__ = version = '0.1.
|
|
32
|
-
__version_tuple__ = version_tuple = (0, 1,
|
|
31
|
+
__version__ = version = '0.1.18'
|
|
32
|
+
__version_tuple__ = version_tuple = (0, 1, 18)
|
|
33
33
|
|
|
34
34
|
__commit_id__ = commit_id = None
|
|
@@ -1177,7 +1177,7 @@ class LineageAnalyzer:
|
|
|
1177
1177
|
if table.db:
|
|
1178
1178
|
parts.append(table.db)
|
|
1179
1179
|
parts.append(table.name)
|
|
1180
|
-
return ".".join(parts)
|
|
1180
|
+
return ".".join(parts).lower()
|
|
1181
1181
|
|
|
1182
1182
|
def _resolve_table_reference(self, ref: str, select_node: exp.Select) -> str:
|
|
1183
1183
|
"""
|
|
@@ -1522,7 +1522,7 @@ class LineageAnalyzer:
|
|
|
1522
1522
|
|
|
1523
1523
|
if columns:
|
|
1524
1524
|
# Store with UNKNOWN type - SQLGlot only needs column names for expansion
|
|
1525
|
-
self._file_schema[target_name] = {col: "UNKNOWN" for col in columns}
|
|
1525
|
+
self._file_schema[target_name] = {col.lower(): "UNKNOWN" for col in columns}
|
|
1526
1526
|
|
|
1527
1527
|
def _extract_schema_from_dql(self, expr: exp.Expression) -> None:
|
|
1528
1528
|
"""Infer table schemas from column references in DQL.
|
|
@@ -1634,8 +1634,9 @@ class LineageAnalyzer:
|
|
|
1634
1634
|
|
|
1635
1635
|
if actual_table not in self._file_schema:
|
|
1636
1636
|
self._file_schema[actual_table] = {}
|
|
1637
|
-
|
|
1638
|
-
|
|
1637
|
+
col_lower = col_name.lower()
|
|
1638
|
+
if col_lower not in self._file_schema[actual_table]:
|
|
1639
|
+
self._file_schema[actual_table][col_lower] = "UNKNOWN"
|
|
1639
1640
|
|
|
1640
1641
|
def _extract_columns_from_select(
|
|
1641
1642
|
self, select_node: Union[exp.Select, exp.Union, exp.Intersect, exp.Except]
|
|
@@ -41,7 +41,14 @@ def extract_schemas_from_files(
|
|
|
41
41
|
if console is None:
|
|
42
42
|
console = Console(stderr=True)
|
|
43
43
|
|
|
44
|
-
schema: SchemaDict =
|
|
44
|
+
schema: SchemaDict = (
|
|
45
|
+
{
|
|
46
|
+
k.lower(): {c.lower(): v for c, v in cols.items()}
|
|
47
|
+
for k, cols in initial_schema.items()
|
|
48
|
+
}
|
|
49
|
+
if initial_schema
|
|
50
|
+
else {}
|
|
51
|
+
)
|
|
45
52
|
total = len(file_paths)
|
|
46
53
|
|
|
47
54
|
with Progress(
|
|
@@ -65,7 +72,11 @@ def extract_schemas_from_files(
|
|
|
65
72
|
strict_schema=strict_schema,
|
|
66
73
|
)
|
|
67
74
|
file_schema = analyzer.extract_schema_only()
|
|
68
|
-
|
|
75
|
+
for table_name, columns in file_schema.items():
|
|
76
|
+
if table_name in schema:
|
|
77
|
+
schema[table_name].update(columns)
|
|
78
|
+
else:
|
|
79
|
+
schema[table_name] = columns
|
|
69
80
|
except SchemaResolutionError:
|
|
70
81
|
raise
|
|
71
82
|
except Exception:
|
|
@@ -46,7 +46,7 @@ def parse_ddl_to_schema(ddl: str, dialect: str = "spark") -> Dict[str, Dict[str,
|
|
|
46
46
|
table_name = _get_qualified_name(target)
|
|
47
47
|
|
|
48
48
|
if columns:
|
|
49
|
-
schema[table_name] = {col: "UNKNOWN" for col in columns}
|
|
49
|
+
schema[table_name] = {col.lower(): "UNKNOWN" for col in columns}
|
|
50
50
|
|
|
51
51
|
return schema
|
|
52
52
|
|
|
@@ -59,4 +59,4 @@ def _get_qualified_name(table: exp.Table) -> str:
|
|
|
59
59
|
if table.db:
|
|
60
60
|
parts.append(table.db)
|
|
61
61
|
parts.append(table.name)
|
|
62
|
-
return ".".join(parts)
|
|
62
|
+
return ".".join(parts).lower()
|
|
@@ -119,39 +119,39 @@ class TestCaseInsensitiveForwardLineage:
|
|
|
119
119
|
# Lowercase
|
|
120
120
|
(
|
|
121
121
|
"target_table.customer_name",
|
|
122
|
-
"
|
|
122
|
+
"target_table.customer_name",
|
|
123
123
|
["customers.customer_name"],
|
|
124
124
|
),
|
|
125
125
|
(
|
|
126
126
|
"target_table.region",
|
|
127
|
-
"
|
|
127
|
+
"target_table.region",
|
|
128
128
|
["customers.region"],
|
|
129
129
|
),
|
|
130
130
|
(
|
|
131
131
|
"target_table.total_amount",
|
|
132
|
-
"
|
|
132
|
+
"target_table.total_amount",
|
|
133
133
|
["orders.order_amount"],
|
|
134
134
|
),
|
|
135
135
|
# Uppercase
|
|
136
136
|
(
|
|
137
|
-
"
|
|
138
|
-
"
|
|
137
|
+
"target_table.CUSTOMER_NAME",
|
|
138
|
+
"target_table.customer_name",
|
|
139
139
|
["customers.customer_name"],
|
|
140
140
|
),
|
|
141
141
|
(
|
|
142
|
-
"
|
|
143
|
-
"
|
|
142
|
+
"target_table.REGION",
|
|
143
|
+
"target_table.region",
|
|
144
144
|
["customers.region"],
|
|
145
145
|
),
|
|
146
146
|
# Mixed case
|
|
147
147
|
(
|
|
148
148
|
"TaRgEt_TaBlE.CuStOmEr_NaMe",
|
|
149
|
-
"
|
|
149
|
+
"target_table.customer_name",
|
|
150
150
|
["customers.customer_name"],
|
|
151
151
|
),
|
|
152
152
|
(
|
|
153
153
|
"target_TABLE.REGION",
|
|
154
|
-
"
|
|
154
|
+
"target_table.region",
|
|
155
155
|
["customers.region"],
|
|
156
156
|
),
|
|
157
157
|
],
|
|
@@ -346,39 +346,39 @@ class TestCaseInsensitiveReverseLineage:
|
|
|
346
346
|
(
|
|
347
347
|
"customers.customer_name",
|
|
348
348
|
"customers.customer_name",
|
|
349
|
-
["
|
|
349
|
+
["target_table.customer_name"],
|
|
350
350
|
),
|
|
351
351
|
(
|
|
352
352
|
"customers.region",
|
|
353
353
|
"customers.region",
|
|
354
|
-
["
|
|
354
|
+
["target_table.region"],
|
|
355
355
|
),
|
|
356
356
|
(
|
|
357
357
|
"orders.order_amount",
|
|
358
358
|
"orders.order_amount",
|
|
359
|
-
["
|
|
359
|
+
["target_table.segment", "target_table.total_amount"],
|
|
360
360
|
),
|
|
361
361
|
# Uppercase
|
|
362
362
|
(
|
|
363
363
|
"CUSTOMERS.CUSTOMER_NAME",
|
|
364
364
|
"customers.customer_name",
|
|
365
|
-
["
|
|
365
|
+
["target_table.customer_name"],
|
|
366
366
|
),
|
|
367
367
|
(
|
|
368
368
|
"CUSTOMERS.REGION",
|
|
369
369
|
"customers.region",
|
|
370
|
-
["
|
|
370
|
+
["target_table.region"],
|
|
371
371
|
),
|
|
372
372
|
# Mixed case
|
|
373
373
|
(
|
|
374
374
|
"CuStOmErS.CuStOmEr_NaMe",
|
|
375
375
|
"customers.customer_name",
|
|
376
|
-
["
|
|
376
|
+
["target_table.customer_name"],
|
|
377
377
|
),
|
|
378
378
|
(
|
|
379
379
|
"cUsToMeRs.ReGiOn",
|
|
380
380
|
"customers.region",
|
|
381
|
-
["
|
|
381
|
+
["target_table.region"],
|
|
382
382
|
),
|
|
383
383
|
],
|
|
384
384
|
)
|
|
@@ -81,6 +81,58 @@ class TestExtractSchemasFromFiles:
|
|
|
81
81
|
assert "id" in schema["customers"]
|
|
82
82
|
assert "order_id" in schema["orders"]
|
|
83
83
|
|
|
84
|
+
def test_merges_columns_for_same_table(self, tmp_path, console):
|
|
85
|
+
"""Test that columns are merged when the same table appears in multiple files."""
|
|
86
|
+
file1 = tmp_path / "a.sql"
|
|
87
|
+
file1.write_text("SELECT c.id, c.name FROM customers c;")
|
|
88
|
+
|
|
89
|
+
file2 = tmp_path / "b.sql"
|
|
90
|
+
file2.write_text("SELECT c.id, c.age FROM customers c;")
|
|
91
|
+
|
|
92
|
+
schema = extract_schemas_from_files(
|
|
93
|
+
[file1, file2], dialect="spark", console=console
|
|
94
|
+
)
|
|
95
|
+
|
|
96
|
+
assert "customers" in schema
|
|
97
|
+
assert "id" in schema["customers"]
|
|
98
|
+
assert "name" in schema["customers"]
|
|
99
|
+
assert "age" in schema["customers"]
|
|
100
|
+
|
|
101
|
+
def test_merges_columns_case_insensitive(self, tmp_path, console):
|
|
102
|
+
"""Test that tables with different casing are merged into one entry."""
|
|
103
|
+
file1 = tmp_path / "a.sql"
|
|
104
|
+
file1.write_text("SELECT c.id, c.name FROM Customers c;")
|
|
105
|
+
|
|
106
|
+
file2 = tmp_path / "b.sql"
|
|
107
|
+
file2.write_text("SELECT c.id, c.AGE FROM customers c;")
|
|
108
|
+
|
|
109
|
+
schema = extract_schemas_from_files(
|
|
110
|
+
[file1, file2], dialect="spark", console=console
|
|
111
|
+
)
|
|
112
|
+
|
|
113
|
+
assert "customers" in schema
|
|
114
|
+
assert len([k for k in schema if k.lower() == "customers"]) == 1
|
|
115
|
+
assert "id" in schema["customers"]
|
|
116
|
+
assert "name" in schema["customers"]
|
|
117
|
+
assert "age" in schema["customers"]
|
|
118
|
+
|
|
119
|
+
def test_initial_schema_normalized(self, tmp_path, console):
|
|
120
|
+
"""Test that initial schema keys are normalized to lowercase."""
|
|
121
|
+
sql_file = tmp_path / "query.sql"
|
|
122
|
+
sql_file.write_text("SELECT o.id FROM orders o;")
|
|
123
|
+
|
|
124
|
+
initial = {"Existing_Table": {"Col1": "UNKNOWN"}}
|
|
125
|
+
schema = extract_schemas_from_files(
|
|
126
|
+
[sql_file],
|
|
127
|
+
dialect="spark",
|
|
128
|
+
initial_schema=initial,
|
|
129
|
+
console=console,
|
|
130
|
+
)
|
|
131
|
+
|
|
132
|
+
assert "existing_table" in schema
|
|
133
|
+
assert "col1" in schema["existing_table"]
|
|
134
|
+
assert "orders" in schema
|
|
135
|
+
|
|
84
136
|
def test_initial_schema_preserved(self, tmp_path, console):
|
|
85
137
|
"""Test that initial schema is included in result."""
|
|
86
138
|
sql_file = tmp_path / "query.sql"
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{sql_glider-0.1.16 → sql_glider-0.1.18}/sample_data_model/business/update_dim_customer_metrics.sql
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{sql_glider-0.1.16 → sql_glider-0.1.18}/sample_data_model/incremental/incr_fact_payments.sql
RENAMED
|
File without changes
|
{sql_glider-0.1.16 → sql_glider-0.1.18}/sample_data_model/incremental/incr_pres_sales_summary.sql
RENAMED
|
File without changes
|
{sql_glider-0.1.16 → sql_glider-0.1.18}/sample_data_model/maintenance/delete_expired_customers.sql
RENAMED
|
File without changes
|
{sql_glider-0.1.16 → sql_glider-0.1.18}/sample_data_model/maintenance/update_product_status.sql
RENAMED
|
File without changes
|
{sql_glider-0.1.16 → sql_glider-0.1.18}/sample_data_model/presentation/load_pres_customer_360.sql
RENAMED
|
File without changes
|
{sql_glider-0.1.16 → sql_glider-0.1.18}/sample_data_model/presentation/load_pres_customer_cohort.sql
RENAMED
|
File without changes
|
|
File without changes
|
{sql_glider-0.1.16 → sql_glider-0.1.18}/sample_data_model/presentation/load_pres_sales_summary.sql
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{sql_glider-0.1.16 → sql_glider-0.1.18}/tests/fixtures/multi_file_queries/analytics_pipeline.sql
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{sql_glider-0.1.16 → sql_glider-0.1.18}/tests/fixtures/multi_file_queries/view_based_merge.sql
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
{sql_glider-0.1.16 → sql_glider-0.1.18}/tests/fixtures/original_queries/test_cte_view_star.sql
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
{sql_glider-0.1.16 → sql_glider-0.1.18}/tests/fixtures/original_queries/test_multi_query.sql
RENAMED
|
File without changes
|
{sql_glider-0.1.16 → sql_glider-0.1.18}/tests/fixtures/original_queries/test_single_query.sql
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{sql_glider-0.1.16 → sql_glider-0.1.18}/tests/fixtures/original_queries/test_view_window_cte.sql
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|