Re: Question about duplicate JSONTYPE_JSON check - Mailing list pgsql-hackers

From Amit Langote
Subject Re: Question about duplicate JSONTYPE_JSON check
Date
Msg-id CA+HiwqE5wrm7ry-d6KkHk+KucOSg+RN3Gr8_0Axqe7dAoTijDQ@mail.gmail.com
Whole thread Raw
In response to Re: Question about duplicate JSONTYPE_JSON check  (Álvaro Herrera <alvherre@alvh.no-ip.org>)
Responses Re: Question about duplicate JSONTYPE_JSON check
List pgsql-hackers
On Wed, Mar 12, 2025 at 7:09 PM Álvaro Herrera <alvherre@alvh.no-ip.org> wrote:
> On 2025-Mar-12, Amit Langote wrote:
>
> > I was able to construct a test case that crashes due to this bug:
> >
> > CREATE TYPE mood AS ENUM ('happy', 'sad', 'neutral');
> > CREATE FUNCTION mood_to_json(mood) RETURNS json AS $$
> >   SELECT to_json($1::text);
> > $$ LANGUAGE sql IMMUTABLE;
> > CREATE CAST (mood AS json) WITH FUNCTION mood_to_json(mood) AS IMPLICIT;
> >
> > SELECT JSON_OBJECT('happy'::mood: '123'::jsonb);
> > server closed the connection unexpectedly
>
> Good reaction time :-)  I see that that line shows as not even uncovered
> in the report, but as non-existant (no background color as opposed to
> red):
>
> https://coverage.postgresql.org/src/backend/utils/adt/jsonb.c.gcov.html#660
>
> Evidently the compiler must be optimizing it out as dead code.

Ah, I did wonder about the coverage, thanks for pointing it out.

Patch look good for committing?

--
Thanks, Amit Langote



pgsql-hackers by date:

Previous
From: "Hayato Kuroda (Fujitsu)"
Date:
Subject: RE: Selectively invalidate caches in pgoutput module
Next
From: "David G. Johnston"
Date:
Subject: Re: Test mail for pgsql-hackers