From 709815a510f5ed5a30aa199195d758ff0f3c57e1 Mon Sep 17 00:00:00 2001 From: Shlomi Noach <2607934+shlomi-noach@users.noreply.github.com> Date: Tue, 24 Dec 2024 09:56:12 +0200 Subject: [PATCH] stricter checks Signed-off-by: Shlomi Noach <2607934+shlomi-noach@users.noreply.github.com> --- go/vt/schemadiff/partitioning_analysis.go | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/go/vt/schemadiff/partitioning_analysis.go b/go/vt/schemadiff/partitioning_analysis.go index c020f85b06f..f7ec4a1efdf 100644 --- a/go/vt/schemadiff/partitioning_analysis.go +++ b/go/vt/schemadiff/partitioning_analysis.go @@ -578,7 +578,7 @@ func TemporalRangePartitioningRetention(createTableEntity *CreateTableEntity, ex return nil, err } switch { - case dt.IsZero(): + case dt.IsZero() && analysis.FuncExpr != nil: // Partition uses an intval, such as in: // PARTITION p0 VALUES LESS THAN (738156) expireIntval, err := applyFuncExprToDateTime(expireDatetime, analysis.FuncExpr) @@ -588,13 +588,16 @@ func TemporalRangePartitioningRetention(createTableEntity *CreateTableEntity, ex if intval <= expireIntval { alterTable.PartitionSpec.Names = append(alterTable.PartitionSpec.Names, partition.Name) } - default: + case !dt.IsZero(): // Partition uses a datetime, such as in these examples: // - PARTITION p0 VALUES LESS THAN ('2021-01-01 00:00:00') // - PARTITION p0 VALUES LESS THAN (TO_DAYS('2021-01-01')) if dt.Compare(expireDatetime) <= 0 { alterTable.PartitionSpec.Names = append(alterTable.PartitionSpec.Names, partition.Name) } + default: + // Should never get here + return nil, fmt.Errorf("unsupported partitioning in table %s", createTableEntity.Name()) } } if len(alterTable.PartitionSpec.Names) == 0 {