Обсуждение: pgsql: test_json_parser: Speed up 002_inline.pl

Поиск
Список
Период
Сортировка

pgsql: test_json_parser: Speed up 002_inline.pl

От
Jacob Champion
Дата:
test_json_parser: Speed up 002_inline.pl

Some macOS machines are having trouble with 002_inline, which executes
the JSON parser test executables hundreds of times in a nested loop.
Both developer machines and buildfarm critters have shown excessive test
durations, upwards of 20 seconds.

Push the innermost loop of 002_inline, which iterates through differing
chunk sizes, down into the test executable. (I'd eventually like to push
all of the JSON unit tests down into C, but this is an easy win in the
short term.) Testers have reported a speedup between 4-9x.

Reported-by: Robert Haas <robertmhaas@gmail.com>
Suggested-by: Andres Freund <andres@anarazel.de>
Tested-by: Andrew Dunstan <andrew@dunslane.net>
Tested-by: Tom Lane <tgl@sss.pgh.pa.us>
Tested-by: Robert Haas <robertmhaas@gmail.com>
Discussion: https://postgr.es/m/CA%2BTgmobKoG%2BgKzH9qB7uE4MFo-z1hn7UngqAe9b0UqNbn3_XGQ%40mail.gmail.com
Backpatch-through: 17

Branch
------
master

Details
-------
https://git.postgresql.org/pg/commitdiff/fd726b8379a8191da9e74d28761c967eda13f5f2

Modified Files
--------------
src/test/modules/test_json_parser/README           |  10 +-
src/test/modules/test_json_parser/t/002_inline.pl  |  26 ++++-
.../test_json_parser_incremental.c                 | 127 +++++++++++++--------
3 files changed, 106 insertions(+), 57 deletions(-)