From 897d4b05030ccd41ae51c8cff377e9d70696b0e4 Mon Sep 17 00:00:00 2001 From: gurminder71 <86370145+gurminder71@users.noreply.github.com> Date: Sat, 5 Oct 2024 12:34:58 -0700 Subject: [PATCH] fix: delta generation for SEARCH INDEX as the ASC keyword is not supported (#174) * fix: delta generation for SEARCH INDEX as the ASC keyword is not supported in columns of index * fix: parser definitions for create_search_index --------- Co-authored-by: Niel Markwick --- .../ASTcreate_search_index_statement.java | 25 +++++++++---------- .../spannerddl/parser/ASTtoken_key_list.java | 8 +++--- src/main/jjtree-sources/ddl_parser.jjt | 8 +++--- src/test/resources/ddlParserValidation.txt | 4 +-- src/test/resources/expectedDdlDiff.txt | 6 ++--- src/test/resources/originalDdl.txt | 2 +- 6 files changed, 26 insertions(+), 27 deletions(-) diff --git a/src/main/java/com/google/cloud/solutions/spannerddl/parser/ASTcreate_search_index_statement.java b/src/main/java/com/google/cloud/solutions/spannerddl/parser/ASTcreate_search_index_statement.java index 31c2df9..da0b262 100644 --- a/src/main/java/com/google/cloud/solutions/spannerddl/parser/ASTcreate_search_index_statement.java +++ b/src/main/java/com/google/cloud/solutions/spannerddl/parser/ASTcreate_search_index_statement.java @@ -189,18 +189,17 @@ private void generateAlterStatementsFor( // Look for differences in tokenKeyList // Easiest is to use Maps.difference, but first we need some maps, and we need to preserve order // so convert the keyParts to String, and then add to a LinkedHashMap. - Map originalKeyParts = - getChildByType(original.children, ASTtoken_key_list.class).getKeyParts().stream() + Map originalKeyParts = + getChildByType(original.children, ASTtoken_key_list.class).getPaths().stream() .collect( Collectors.toMap( - ASTkey_part::toString, Function.identity(), (x, y) -> y, LinkedHashMap::new)); - Map newKeyParts = - getChildByType(other.children, ASTtoken_key_list.class).getKeyParts().stream() + ASTpath::toString, Function.identity(), (x, y) -> y, LinkedHashMap::new)); + Map newKeyParts = + getChildByType(other.children, ASTtoken_key_list.class).getPaths().stream() .collect( Collectors.toMap( - ASTkey_part::toString, Function.identity(), (x, y) -> y, LinkedHashMap::new)); - MapDifference keyPartsDiff = - Maps.difference(originalKeyParts, newKeyParts); + ASTpath::toString, Function.identity(), (x, y) -> y, LinkedHashMap::new)); + MapDifference keyPartsDiff = Maps.difference(originalKeyParts, newKeyParts); // Look for differences in storedColumnList // Easiest is to use Maps.difference, but first we need some maps, and we need to preserve order @@ -234,17 +233,17 @@ private void generateAlterStatementsFor( Maps.difference(originalStoredColumns, newStoredColumns); if (allowDropColumnStatements) { - for (ASTkey_part droppedToken : keyPartsDiff.entriesOnlyOnLeft().values()) { + for (ASTpath droppedTokenCol : keyPartsDiff.entriesOnlyOnLeft().values()) { LOG.info( "Dropping token colum {} for search index: {}", - droppedToken.getKeyPath(), + droppedTokenCol.toString(), original.getName()); dropStatements.add( "ALTER SEARCH INDEX " + original.getName() + " DROP COLUMN " - + droppedToken.getKeyPath()); + + droppedTokenCol.toString()); } } @@ -261,9 +260,9 @@ private void generateAlterStatementsFor( + droppedStoredCol.toString()); } - for (ASTkey_part newToken : keyPartsDiff.entriesOnlyOnRight().values()) { + for (ASTpath newToken : keyPartsDiff.entriesOnlyOnRight().values()) { LOG.info( - "Adding token colum {} for search index: {}", newToken.getKeyPath(), original.getName()); + "Adding token colum {} for search index: {}", newToken.toString(), original.getName()); createStatements.add( "ALTER SEARCH INDEX " + original.getName() + " ADD COLUMN " + newToken.toString()); diff --git a/src/main/java/com/google/cloud/solutions/spannerddl/parser/ASTtoken_key_list.java b/src/main/java/com/google/cloud/solutions/spannerddl/parser/ASTtoken_key_list.java index 7b5fa54..1cb4d60 100644 --- a/src/main/java/com/google/cloud/solutions/spannerddl/parser/ASTtoken_key_list.java +++ b/src/main/java/com/google/cloud/solutions/spannerddl/parser/ASTtoken_key_list.java @@ -31,17 +31,17 @@ public ASTtoken_key_list(DdlParser p, int id) { } private void validateChildren() { - AstTreeUtils.validateChildrenClasses(children, ImmutableSet.of(ASTkey_part.class)); + AstTreeUtils.validateChildrenClasses(children, ImmutableSet.of(ASTpath.class)); } @Override public String toString() { validateChildren(); - return "( " + Joiner.on(", ").join(getKeyParts()) + " )"; + return "( " + Joiner.on(", ").join(getPaths()) + " )"; } - public List getKeyParts() { - return AstTreeUtils.getChildrenAssertType(children, ASTkey_part.class); + public List getPaths() { + return AstTreeUtils.getChildrenAssertType(children, ASTpath.class); } @Override diff --git a/src/main/jjtree-sources/ddl_parser.jjt b/src/main/jjtree-sources/ddl_parser.jjt index bca7bd0..9c13873 100644 --- a/src/main/jjtree-sources/ddl_parser.jjt +++ b/src/main/jjtree-sources/ddl_parser.jjt @@ -175,8 +175,8 @@ void alter_search_index_statement() : (qualified_identifier() #name) ( LOOKAHEAD(2) stored_column() #add_stored_column | LOOKAHEAD(2) identifier() #drop_stored_column_name - | LOOKAHEAD(2) key_part() #add_token_column - | LOOKAHEAD(2) key_part() #drop_token_column + | LOOKAHEAD(2) path() #add_token_column + | LOOKAHEAD(2) path() #drop_token_column ) } @@ -410,8 +410,8 @@ void token_key_list() : {} { "(" - [ key_part() - ("," key_part() )* + [ path() + ("," path() )* ] ")" } diff --git a/src/test/resources/ddlParserValidation.txt b/src/test/resources/ddlParserValidation.txt index a89e36d..6295ddd 100644 --- a/src/test/resources/ddlParserValidation.txt +++ b/src/test/resources/ddlParserValidation.txt @@ -137,7 +137,7 @@ CREATE CHANGE STREAM change_stream_name FOR table1, table2 ( ), table3 ( col1, c == Test 13a create search index full CREATE SEARCH INDEX AlbumsIndex -ON Albums ( AlbumTitle_Tokens ASC, Rating_Tokens ASC ) +ON Albums ( AlbumTitle_Tokens, Rating_Tokens ) STORING ( Genre, albumName ) PARTITION BY SingerId ASC ORDER BY ReleaseTimestamp DESC @@ -148,7 +148,7 @@ OPTIONS (sort_order_sharding=TRUE) == Test 13b create search index Simple CREATE SEARCH INDEX AlbumsIndex -ON Albums ( AlbumTitle_Tokens ASC ) +ON Albums ( AlbumTitle_Tokens ) OPTIONS (sort_order_sharding=TRUE) == diff --git a/src/test/resources/expectedDdlDiff.txt b/src/test/resources/expectedDdlDiff.txt index e609603..9eb0843 100644 --- a/src/test/resources/expectedDdlDiff.txt +++ b/src/test/resources/expectedDdlDiff.txt @@ -297,7 +297,7 @@ ALTER INDEX test4 ADD STORED COLUMN col5 CREATE TABLE test2 ( col1 INT64 ) PRIMARY KEY (col1 ASC) -CREATE SEARCH INDEX AlbumsIndex ON Albums ( AlbumTitle_Tokens ASC ) +CREATE SEARCH INDEX AlbumsIndex ON Albums ( AlbumTitle_Tokens ) == TEST 56 Dropping search index - before table dropping @@ -310,12 +310,12 @@ ALTER SEARCH INDEX AlbumsIndex DROP COLUMN col2 ALTER SEARCH INDEX AlbumsIndex DROP STORED COLUMN scol2 ALTER TABLE test1 DROP COLUMN col2 ALTER TABLE test1 ADD COLUMN col3 INT64 -ALTER SEARCH INDEX AlbumsIndex ADD COLUMN col3 ASC +ALTER SEARCH INDEX AlbumsIndex ADD COLUMN col3 ALTER SEARCH INDEX AlbumsIndex ADD STORED COLUMN scol3 == TEST 58 Add col to search index - no stored columns -ALTER SEARCH INDEX AlbumsIndex ADD COLUMN col3 ASC +ALTER SEARCH INDEX AlbumsIndex ADD COLUMN col3 == TEST 59 Add stored col to search index diff --git a/src/test/resources/originalDdl.txt b/src/test/resources/originalDdl.txt index 1188274..e48d2f1 100644 --- a/src/test/resources/originalDdl.txt +++ b/src/test/resources/originalDdl.txt @@ -482,7 +482,7 @@ create table test1 ( col1 int64 ) primary key (col1); create table test2 ( col1 int64 ) primary key (col1); -CREATE SEARCH INDEX AlbumsIndex ON Albums ( AlbumTitle_Tokens ASC, Rating_Tokens ASC ) +CREATE SEARCH INDEX AlbumsIndex ON Albums ( AlbumTitle_Tokens, Rating_Tokens ) == TEST 57 Changing search index - before and after table changes