AlterSubscription_refresh: avoid stomping on global variable
authorAlvaro Herrera <alvherre@alvh.no-ip.org>
Fri, 7 May 2021 15:46:37 +0000 (11:46 -0400)
committerAlvaro Herrera <alvherre@alvh.no-ip.org>
Fri, 7 May 2021 15:46:37 +0000 (11:46 -0400)
commit4e8c0f1a0d0d095a749a329a216c88a340a455b6
treeb14ab58659aed08d1c7a6a34ea158443dbb0bdd9
parent8b82de0164c13eb3b113a525dc7eda7887f5238b
AlterSubscription_refresh: avoid stomping on global variable

This patch replaces use of the global "wrconn" variable in
AlterSubscription_refresh with a local variable of the same name, making
it consistent with other functions in subscriptioncmds.c (e.g.
DropSubscription).

The global wrconn is only meant to be used for logical apply/tablesync worker.
Abusing it this way is known to cause trouble if an apply worker
manages to do a subscription refresh, such as reported by Jeremy Finzel
and diagnosed by Andres Freund back in November 2020, at
https://www.postgresql.org/message-id/20201111215820.qihhrz7fayu6myfi@alap3.anarazel.de

Backpatch to 10.  In branch master, also move the connection establishment
to occur outside the PG_TRY block; this way we can remove a test for NULL in
PG_FINALLY, and it also makes the code more consistent with similar code in
the same file.

Author: Peter Smith <peter.b.smith@fujitsu.com>
Reviewed-by: Bharath Rupireddy <bharath.rupireddyforpostgres@gmail.com>
Reviewed-by: Japin Li <japinli@hotmail.com>
Discussion: https://postgr.es/m/CAHut+Pu7Jv9L2BOEx_Z0UtJxfDevQSAUW2mJqWU+CtmDrEZVAg@mail.gmail.com
src/backend/commands/subscriptioncmds.c