From: | Andres Freund <andres(at)anarazel(dot)de> |
---|---|
To: | Noah Misch <noah(at)leadboat(dot)com> |
Cc: | Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us>, Smolkin Grigory <smallkeen(at)gmail(dot)com>, pgsql-hackers(at)postgresql(dot)org |
Subject: | Re: race condition in pg_class |
Date: | 2025-03-18 19:03:52 |
Message-ID: | kx6xu7suexal5vwsxpy7ybgkcznx6hgywbuhkr6qabcwxjqax2@i4pcpk75jvaa |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-hackers |
Hi,
On 2024-05-12 16:29:23 -0700, Noah Misch wrote:
> Author: Noah Misch <noah(at)leadboat(dot)com>
> Commit: Noah Misch <noah(at)leadboat(dot)com>
>
> Make TAP todo_start effects the same under Meson and prove_check.
>
> This could have caused spurious failures only on SPARC Linux, because
> today's only todo_start tests for that platform. Back-patch to v16,
> where Meson support first appeared.
>
> Reviewed by FIXME.
>
> Discussion: https://postgr.es/m/FIXME
>
> diff --git a/src/tools/testwrap b/src/tools/testwrap
> index d01e610..9a270be 100755
> --- a/src/tools/testwrap
> +++ b/src/tools/testwrap
> @@ -41,12 +41,22 @@ env_dict = {**os.environ,
> 'TESTDATADIR': os.path.join(testdir, 'data'),
> 'TESTLOGDIR': os.path.join(testdir, 'log')}
>
> -sp = subprocess.run(args.test_command, env=env_dict)
> +sp = subprocess.Popen(args.test_command, env=env_dict, stdout=subprocess.PIPE)
> +# Meson categorizes a passing TODO test point as bad
> +# (https://github.com/mesonbuild/meson/issues/13183) Remove the TODO
> +# directive, so Meson computes the file result like Perl does. This could
> +# have the side effect of delaying stdout lines relative to stderr. That
> +# doesn't affect the log file, and the TAP protocol uses stdout only.
> +for line in sp.stdout:
> + if line.startswith(b'ok '):
> + line = line.replace(b' # TODO ', b' # testwrap-overridden-TODO ', 1)
> + sys.stdout.buffer.write(line)
> +returncode = sp.wait()
This has the issue that it causes the testwrap output to be buffered, which
makes running tests with ``meson test -v <testname>` update the output less
promptly, only updating whenever the output buffer is flushed.
That's not the end of the world, but it'd be nice to get the output more
promptly again. It doesn't matter that much when running the tests normally,
but if you run them with valgrind or such and you just want to see the first
failure, because it's going to take an hour to finish all tests...
The easiest fix is to just explicitly flush after each line, as in the
attached.
Greetings,
Andres Freund
Attachment | Content-Type | Size |
---|---|---|
v1-0001-meson-Flush-stdout-in-testwrap.patch | text/x-diff | 764 bytes |
From | Date | Subject | |
---|---|---|---|
Next Message | Nathan Bossart | 2025-03-18 19:08:42 | Re: optimize file transfer in pg_upgrade |
Previous Message | Álvaro Herrera | 2025-03-18 19:03:30 | Re: NOT ENFORCED constraint feature |