From d9fc084f9fe36cb53c8797efaee0458920ecc5d7 Mon Sep 17 00:00:00 2001 From: T-Santos Date: Wed, 14 Aug 2024 12:29:15 -0400 Subject: [PATCH 1/3] Feature/support for truncate table query parsing (#1) * failing test for truncate table * fix failing truncate table test --------- Co-authored-by: Santos, Tyler (Boston) --- sql_metadata/keywords_lists.py | 2 ++ sql_metadata/parser.py | 2 +- test/test_truncate_table.py | 9 +++++++++ 3 files changed, 12 insertions(+), 1 deletion(-) create mode 100644 test/test_truncate_table.py diff --git a/sql_metadata/keywords_lists.py b/sql_metadata/keywords_lists.py index 8521c296..4abeaea0 100644 --- a/sql_metadata/keywords_lists.py +++ b/sql_metadata/keywords_lists.py @@ -81,6 +81,7 @@ class QueryType(str, Enum): CREATE = "CREATE TABLE" ALTER = "ALTER TABLE" DROP = "DROP TABLE" + TRUNCATE = "TRUNCATE TABLE" class TokenType(str, Enum): @@ -109,6 +110,7 @@ class TokenType(str, Enum): "ALTERTABLE": QueryType.ALTER, "DROPTABLE": QueryType.DROP, "CREATEFUNCTION": QueryType.CREATE, + "TRUNCATETABLE": QueryType.TRUNCATE, } # all the keywords we care for - rest is ignored in assigning diff --git a/sql_metadata/parser.py b/sql_metadata/parser.py index 64f40219..d003c547 100644 --- a/sql_metadata/parser.py +++ b/sql_metadata/parser.py @@ -116,7 +116,7 @@ def query_type(self) -> str: ) if tokens[index].normalized == "CREATE": switch = self._get_switch_by_create_query(tokens, index) - elif tokens[index].normalized in ("ALTER", "DROP"): + elif tokens[index].normalized in ("ALTER", "DROP", "TRUNCATE"): switch = tokens[index].normalized + tokens[index + 1].normalized else: switch = tokens[index].normalized diff --git a/test/test_truncate_table.py b/test/test_truncate_table.py new file mode 100644 index 00000000..c70c5d3e --- /dev/null +++ b/test/test_truncate_table.py @@ -0,0 +1,9 @@ +from sql_metadata import Parser +from sql_metadata.keywords_lists import QueryType + + +def test_truncate_table(): + parser = Parser("TRUNCATE TABLE foo") + assert parser.query_type == QueryType.TRUNCATE + assert parser.tables == ["foo"] + assert parser.columns == [] \ No newline at end of file From 17a2d07547a519139cf93c52f735f3d5c5a3be9c Mon Sep 17 00:00:00 2001 From: T-Santos Date: Mon, 26 Aug 2024 12:57:28 -0400 Subject: [PATCH 2/3] Update test/test_truncate_table.py Co-authored-by: Maciej Brencz --- test/test_truncate_table.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/test/test_truncate_table.py b/test/test_truncate_table.py index c70c5d3e..3662dbbc 100644 --- a/test/test_truncate_table.py +++ b/test/test_truncate_table.py @@ -6,4 +6,4 @@ def test_truncate_table(): parser = Parser("TRUNCATE TABLE foo") assert parser.query_type == QueryType.TRUNCATE assert parser.tables == ["foo"] - assert parser.columns == [] \ No newline at end of file + assert parser.columns == [] From 1adad519c0ddcc90a97ca5854aac8894e28111eb Mon Sep 17 00:00:00 2001 From: T-Santos Date: Mon, 26 Aug 2024 13:15:22 -0400 Subject: [PATCH 3/3] Update test_truncate_table.py Add whitespace