From 5bfe8e401f8a04f0397c0cce8be36be48fa718cf Mon Sep 17 00:00:00 2001 From: Amogh Bharadwaj Date: Wed, 3 Jan 2024 23:54:30 +0530 Subject: [PATCH] Fix snowflake qrep tests: geography validation (#976) We were never actually checking the geo column values in snowflake qrep. This PR aims to fix that and also a lint Fixes #973 --- flow/e2e/test_utils.go | 17 ++++++++++++++++- flow/geo/geo.go | 1 + 2 files changed, 17 insertions(+), 1 deletion(-) diff --git a/flow/e2e/test_utils.go b/flow/e2e/test_utils.go index 1ed60196eb..f1e584abf8 100644 --- a/flow/e2e/test_utils.go +++ b/flow/e2e/test_utils.go @@ -367,6 +367,12 @@ func GetOwnersSchema() *model.QRecordSchema { {Name: "f6", Type: qvalue.QValueKindJSON, Nullable: true}, {Name: "f7", Type: qvalue.QValueKindJSON, Nullable: true}, {Name: "f8", Type: qvalue.QValueKindInt16, Nullable: true}, + {Name: "geometryPoint", Type: qvalue.QValueKindGeometry, Nullable: true}, + {Name: "geometry_linestring", Type: qvalue.QValueKindGeometry, Nullable: true}, + {Name: "geometry_polygon", Type: qvalue.QValueKindGeometry, Nullable: true}, + {Name: "geography_point", Type: qvalue.QValueKindGeography, Nullable: true}, + {Name: "geography_linestring", Type: qvalue.QValueKindGeography, Nullable: true}, + {Name: "geography_polygon", Type: qvalue.QValueKindGeography, Nullable: true}, }, } } @@ -377,7 +383,16 @@ func GetOwnersSelectorStringsSF() [2]string { sfFields := make([]string, 0, len(schema.Fields)) for _, field := range schema.Fields { pgFields = append(pgFields, fmt.Sprintf(`"%s"`, field.Name)) - sfFields = append(sfFields, connsnowflake.SnowflakeIdentifierNormalize(field.Name)) + if strings.Contains(field.Name, "geo") { + colName := connsnowflake.SnowflakeIdentifierNormalize(field.Name) + + // Have to apply a WKT transformation here, + // else the sql driver we use receives the values as snowflake's OBJECT + // which is troublesome to deal with. Now it receives it as string. + sfFields = append(sfFields, fmt.Sprintf(`ST_ASWKT(%s) as %s`, colName, colName)) + } else { + sfFields = append(sfFields, connsnowflake.SnowflakeIdentifierNormalize(field.Name)) + } } return [2]string{strings.Join(pgFields, ","), strings.Join(sfFields, ",")} } diff --git a/flow/geo/geo.go b/flow/geo/geo.go index d0479da3eb..a7f87e0174 100644 --- a/flow/geo/geo.go +++ b/flow/geo/geo.go @@ -1,3 +1,4 @@ +//nolint:all package geo import (