Avoid crash in rare case of concurrent DROP
authorAlvaro Herrera <alvherre@alvh.no-ip.org>
Fri, 5 Nov 2021 15:29:35 +0000 (12:29 -0300)
committerAlvaro Herrera <alvherre@alvh.no-ip.org>
Fri, 5 Nov 2021 15:29:35 +0000 (12:29 -0300)
commitd74b54b3ddf710926a44bf3f9c87c00e6f82d825
tree0f76a43eb2be17ba29166c80b962556604966dce
parentdf80f9da5c6541e744eeb20eaca919c7fc189999
Avoid crash in rare case of concurrent DROP

When a role being dropped contains is referenced by catalog objects that
are concurrently also being dropped, a crash can result while trying to
construct the string that describes the objects.  Suppress that by
ignoring objects whose descriptions are returned as NULL.

The majority of relevant codesites were already cautious about this
already; we had just missed a couple.

This is an old bug, so backpatch all the way back.

Reported-by: Alexander Lakhin <exclusion@gmail.com>
Discussion: https://postgr.es/m/17126-21887f04508cb5c8@postgresql.org
src/backend/catalog/dependency.c
src/backend/catalog/pg_shdepend.c