Re: BUG #17076: Server crashes on composing an error message about invalid modulus for a new table partition - Mailing list pgsql-bugs

From Tom Lane
Subject Re: BUG #17076: Server crashes on composing an error message about invalid modulus for a new table partition
Date
Msg-id 346711.1624919432@sss.pgh.pa.us
Whole thread Raw
In response to Re: BUG #17076: Server crashes on composing an error message about invalid modulus for a new table partition  (Tom Lane <tgl@sss.pgh.pa.us>)
Responses Re: BUG #17076: Server crashes on composing an error message about invalid modulus for a new table partition  (Amit Langote <amitlangote09@gmail.com>)
List pgsql-bugs
I wrote:
> I think the patch has got more problems than that too, as it's far
> from clear why the next remainder would have anything to do with the
> next larger modulus.  IOW I suspect that when it does manage to print
> a partition name without crashing, it's very likely to print the
> wrong partition.

Concretely, this variant of the test case:

drop table hash_parted;
CREATE TABLE hash_parted (
    a int
) PARTITION BY HASH (a);
CREATE TABLE hpart_1 PARTITION OF hash_parted FOR VALUES WITH (MODULUS 50, REMAINDER 0);
CREATE TABLE hpart_2 PARTITION OF hash_parted FOR VALUES WITH (MODULUS 10, REMAINDER 1);
CREATE TABLE hpart_3 PARTITION OF hash_parted FOR VALUES WITH (MODULUS 200, REMAINDER 2);

CREATE TABLE fail_part PARTITION OF hash_parted FOR VALUES WITH (MODULUS 25, REMAINDER 3);

prints

ERROR:  every hash partition modulus must be a factor of the next larger modulus
DETAIL:  The new modulus 25 is not divisible by 10, the modulus of existing partition "hpart_1".

which is obviously wrong.

I think that rescuing this might require scanning through the list of
partitions for one that has the desired modulus.  There could be more
than one match, but I'd be content to take the first one.

            regards, tom lane



pgsql-bugs by date:

Previous
From: Tom Lane
Date:
Subject: Re: BUG #17076: Server crashes on composing an error message about invalid modulus for a new table partition
Next
From: Bruce Momjian
Date:
Subject: Re: BUG #17073: docs - "Improve signal handling reliability"