Re: BUG #18877: PostgreSQL triggers assertion failure - Mailing list pgsql-bugs

From Tom Lane
Subject Re: BUG #18877: PostgreSQL triggers assertion failure
Date
Msg-id 2387814.1743825262@sss.pgh.pa.us
Whole thread Raw
In response to BUG #18877: PostgreSQL triggers assertion failure  (PG Bug reporting form <noreply@postgresql.org>)
Responses Re: BUG #18877: PostgreSQL triggers assertion failure
Re: BUG #18877: PostgreSQL triggers assertion failure
List pgsql-bugs
PG Bug reporting form <noreply@postgresql.org> writes:
> In the debug build of PostgreSQL 17.4, compiled with `configure
> --enable-debug --prefix=$(pwd) --exec-prefix=$(pwd) --enable-cassert`,
> triggered Assertion Failure when executing the following statement:

> ```sql
> SELECT ALL GROUP BY ALL ( ), CUBE ( CASE WHEN FALSE THEN TRUE END )
> INTERSECT ALL SELECT ALL FROM JSON_ARRAY ( WITH any_cte_name AS ( ( TABLE
> v00 ) ) VALUES ( FALSE ) ), any_table_name GROUP BY CUBE ( CASE WHEN TRUE
> THEN FALSE END );
> ```

Minimized a bit, that's

regression=# SELECT 1 FROM JSON_ARRAY ( WITH any_cte_name AS ( ( select 1 ) ) VALUES ( FALSE ) );
server closed the connection unexpectedly

This is another case of "don't let the parser process the same
querytree twice".  I can make it go away with

diff --git a/src/backend/parser/parse_expr.c b/src/backend/parser/parse_expr.c
index 9caf1e481a2..bc602f00ae3 100644
--- a/src/backend/parser/parse_expr.c
+++ b/src/backend/parser/parse_expr.c
@@ -3772,7 +3772,7 @@ transformJsonArrayQueryConstructor(ParseState *pstate,
     /* Transform query only for counting target list entries. */
     qpstate = make_parsestate(pstate);

-    query = transformStmt(qpstate, ctor->query);
+    query = transformStmt(qpstate, copyObject(ctor->query));

     if (count_nonjunk_tlist_entries(query->targetList) != 1)
         ereport(ERROR,

However ... it's possible that this isn't the stupidest, most
brute-force code in Postgres, but I'll wager it's in the top ten.
Is it really necessary to transform the subquery twice just to
produce this error?  It seems like the constructed EXPR_SUBLINK
should produce the same error all by itself.  I tried nuking this
whole stanza to see whether that would happen, and then there are a
couple of regression test cases that don't produce the same results.
But I feel like it could be made to work with a bit more thought.

            regards, tom lane



pgsql-bugs by date:

Previous
From: Tom Lane
Date:
Subject: Re: BUG #18879: PostgreSQL returns memory error.
Next
From: Tender Wang
Date:
Subject: Re: BUG #18877: PostgreSQL triggers assertion failure