summaryrefslogtreecommitdiff
path: root/contrib/postgres_fdw/shippable.c
diff options
context:
space:
mode:
authorTom Lane <tgl@sss.pgh.pa.us>2023-04-12 10:46:30 -0400
committerTom Lane <tgl@sss.pgh.pa.us>2023-04-12 10:46:30 -0400
commitf4badbcf4540d3f15de0e36fabca3ab05b20b922 (patch)
tree86841e95cc940fe8b6b5dfd4564c602796229308 /contrib/postgres_fdw/shippable.c
parent5c32549460fcabfb34ce47f96499bf753aaabeea (diff)
Fix parallel-safety marking when moving initplans to another node.
Our policy since commit ab77a5a45 has been that a plan node having any initplans is automatically not parallel-safe. (This could be relaxed, but not today.) clean_up_removed_plan_level neglected this, and could attach initplans to a parallel-safe child plan node without clearing the plan's parallel-safe flag. That could lead to "subplan was not initialized" errors at runtime, in case an initplan referenced another one and only the referencing one got transmitted to parallel workers. The fix in clean_up_removed_plan_level is trivial enough. materialize_finished_plan also moves initplans from one node to another, but it's okay because it already copies the source node's parallel_safe flag. The other place that does this kind of thing is standard_planner's hack to inject a top-level Gather when debug_parallel_query is active. But that's actually dead code given that we're correctly enforcing the "initplans aren't parallel safe" rule, so just replace it with an Assert that there are no initplans. Also improve some related comments. Normally we'd add a regression test case for this sort of bug. The mistake itself is already reached by existing tests, but there is accidentally no visible problem. The only known test case that creates an actual failure seems too indirect and fragile to justify keeping it as a regression test (not least because it fails to fail in v11, though the bug is clearly present there too). Per report from Justin Pryzby. Back-patch to all supported branches. Discussion: https://postgr.es/m/ZDVt6MaNWkRDO1LQ@telsasoft.com
Diffstat (limited to 'contrib/postgres_fdw/shippable.c')
0 files changed, 0 insertions, 0 deletions