On 2020-03-23 06:02, Amit Langote wrote:
Okay, added some tests.

Attached updated patches.

I have committed the worker.c refactoring patch.

"Add subscription support to replicate into partitioned tables" still has lacking test coverage. Your changes in relation.c are not exercised at all because the partitioned table branch in apply_handle_update() is never taken. This is critical and tricky code, so I would look for significant testing.

The code looks okay to me.  I would remove this code

+       memset(entry->attrmap->attnums, -1,
+              entry->attrmap->maplen * sizeof(AttrNumber));

because the entries are explicitly filled right after anyway, and filling the bytes with -1 has an unclear effect. There is also seemingly some fishiness in this code around whether attribute numbers are zero- or one-based. Perhaps this could be documented briefly. Maybe I'm misunderstanding something.

--
Peter Eisentraut              http://www.2ndQuadrant.com/
PostgreSQL Development, 24x7 Support, Remote DBA, Training & Services


Reply via email to