summaryrefslogtreecommitdiff
path: root/contrib/test_decoding/expected/decoding_into_rel.out
diff options
context:
space:
mode:
authorHeikki Linnakangas <heikki.linnakangas@iki.fi>2019-08-07 12:40:49 +0300
committerHeikki Linnakangas <heikki.linnakangas@iki.fi>2019-08-07 12:41:22 +0300
commit65468cc705ea8a329f175de7eed44163ce532482 (patch)
tree9342e9f0c47e1a58e88038d5e9635315bf71f699 /contrib/test_decoding/expected/decoding_into_rel.out
parent1ba4d0fe463eaf16bc93024d0634cf224f07a0e8 (diff)
Fix predicate-locking of HOT updated rows.
In serializable mode, heap_hot_search_buffer() incorrectly acquired a predicate lock on the root tuple, not the returned tuple that satisfied the visibility checks. As explained in README-SSI, the predicate lock does not need to be copied or extended to other tuple versions, but for that to work, the correct, visible, tuple version must be locked in the first place. The original SSI commit had this bug in it, but it was fixed back in 2013, in commit 81fbbfe335. But unfortunately, it was reintroduced a few months later in commit b89e151054. Wising up from that, add a regression test to cover this, so that it doesn't get reintroduced again. Also, move the code that sets 't_self', so that it happens at the same time that the other HeapTuple fields are set, to make it more clear that all the code in the loop operate on the "current" tuple in the chain, not the root tuple. Bug spotted by Andres Freund, analysis and original fix by Thomas Munro, test case and some additional changes to the fix by Heikki Linnakangas. Backpatch to all supported versions (9.4). Discussion: https://www.postgresql.org/message-id/20190731210630.nqhszuktygwftjty%40alap3.anarazel.de
Diffstat (limited to 'contrib/test_decoding/expected/decoding_into_rel.out')
0 files changed, 0 insertions, 0 deletions