From: | Andrew Dunstan <andrew(at)dunslane(dot)net> |
---|---|
To: | Andres Freund <andres(at)anarazel(dot)de>, pgsql-hackers(at)postgresql(dot)org |
Subject: | Re: Why does wait_for_log() return current file size |
Date: | 2025-03-29 16:09:58 |
Message-ID: | 7552b0a0-ed4c-45ed-95d6-c86baf771967@dunslane.net |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-hackers |
On 2025-03-29 Sa 11:15 AM, Andres Freund wrote:
> Hi,
>
> In a test I'd like to use wait_for_log() to find a bunch of log messages
> emitted in sequence. A reasonable looking pattern for that would be:
>
> $log_location = -s $node->logfile;
>
> $log_location = $node->wait_for_log(qr/first-message/, $log_location);
> $log_location = $node->wait_for_log(qr/second-message/, $log_location);
>
> Except that that doesn't work, because what wait_for_log returns is:
>
> my $log =
> PostgreSQL::Test::Utils::slurp_file($self->logfile, $offset);
>
> return $offset + length($log) if ($log =~ m/$regexp/);
>
> Which, afaict, boils down to the current end of the logfile.
>
> Could we instead determine where in the string our regex matched, and return
> $offset + $that_magic_number
>
> Assuming that could be made work, does anybody see a reason not to do that?
In principle it seems quite reasonable, but I haven't looked at all the
current uses to see if they will be upset.
cheers
andrew
--
Andrew Dunstan
EDB:https://www.enterprisedb.com
From | Date | Subject | |
---|---|---|---|
Next Message | David G. Johnston | 2025-03-29 16:12:00 | Re: Make COPY format extendable: Extract COPY TO format implementations |
Previous Message | Andrew Dunstan | 2025-03-29 16:06:53 | Re: in BeginCopyTo make materialized view using COPY TO instead of COPY (query). |