From: | Michael Paquier <michael(at)paquier(dot)xyz> |
---|---|
To: | Thomas Munro <thomas(dot)munro(at)gmail(dot)com> |
Cc: | Noah Misch <noah(at)leadboat(dot)com>, Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us>, Kyotaro Horiguchi <horikyota(dot)ntt(at)gmail(dot)com>, exclusion(at)gmail(dot)com, pgsql-bugs(at)lists(dot)postgresql(dot)org |
Subject: | Re: BUG #17928: Standby fails to decode WAL on termination of primary |
Date: | 2023-08-20 23:32:39 |
Message-ID: | ZOKil9ifJmmAb6di@paquier.xyz |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-bugs |
On Fri, Aug 18, 2023 at 01:55:32PM +0900, Michael Paquier wrote:
> A new perl routine able to do a pg_control --includedir that scans a
> defined header with a regexp would be able to make the job for the
> constants. If you're interested, I can code that up.
Please find attached a patch, that applies on top of the TAP test,
to implement a logic able to extract from header files the values
wanted. This is Utils::scan_header(), for example:
my @scan_result = scan_header('server/access/xlog_internal.h',
'#define\s+XLOG_PAGE_MAGIC\s+(\w+)');
my $XLP_PAGE_MAGIC = hex($scan_result[0]);
This uses group capture so as it is possible to get more than one
field. Guessing the size of the C structure is possible, but I've
found these options to be a bit awkward implementation-wise:
- Config would not help for the Postgres-specific declarations, like
TimeLineId, etc.
- I saw something that was specific to GCC.. cannot put my finger on
it now.
Another possibility would be to store the size in a different variable
in xlog_internal.h, coupled with a StaticAssertDecl() to make sure
that it matches with the real size. While it has the same maintenance
cost as RECORD_HEADER_SIZE in the test itself, that's catching a
mismatching size at compilation-time rather than at test-time.
I am not sure that I'll be able to do more on this topic this week, at
least that's some progress.
--
Michael
Attachment | Content-Type | Size |
---|---|---|
v2-0001-Add-TAP-tests-for-end-of-WAL-conditions.patch | text/x-diff | 12.8 KB |
v2-0002-Don-t-trust-unvalidated-xl_tot_len.patch | text/x-diff | 7.8 KB |
v2-0003-Implement-routine-to-scan-and-extra-values-from-h.patch | text/x-diff | 2.7 KB |
From | Date | Subject | |
---|---|---|---|
Next Message | Michael Paquier | 2023-08-21 07:14:20 | Re: BUG #18057: unaccent removes intentional spaces |
Previous Message | James Inform | 2023-08-20 21:12:35 | Re: BUG #18060: Left joining rows using random() function in join condition doesn't work as expected. |