aboutsummaryrefslogtreecommitdiff
path: root/src/backend/commands/async.c
diff options
context:
space:
mode:
authorMichael Paquier <michael@paquier.xyz>2022-02-09 10:15:26 +0900
committerMichael Paquier <michael@paquier.xyz>2022-02-09 10:15:26 +0900
commitb0a55f4d4ad58e4bc152f8c1696b4af46525e3f1 (patch)
tree3b568508ec8877c14d7f8b5c1d6c47b29c405510 /src/backend/commands/async.c
parentd5c2a91e54cd083429dbb89113addf56bdac6a48 (diff)
downloadpostgresql-b0a55f4d4ad58e4bc152f8c1696b4af46525e3f1.tar.gz
postgresql-b0a55f4d4ad58e4bc152f8c1696b4af46525e3f1.zip
Add TAP test to automate the equivalent of check_guc
src/backend/utils/misc/check_guc is a script that cross-checks the consistency of the GUCs with postgresql.conf.sample, making sure that its format is in line with what guc.c has. It has never been run automatically, and has rotten over the years, creating a lot of false positives as per a report from Justin Pryzby. d10e41d has introduced a SQL function to publish the most relevant flags associated to a GUC, with tests added in the main regression test suite to make sure that we avoid most of the inconsistencies in the GUC settings, based on recent reports, but there was nothing able to cross-check postgresql.conf.sample with the contents of guc.c. This commit adds a TAP test that covers the remaining gap. It emulates the most relevant checks that check_guc does, so as any format mistakes are detected in postgresql.conf.sample at development stage, with the following checks: - Check that parameters marked as NOT_IN_SAMPLE are not in the sample file. - Check that there are no dead entries in postgresql.conf.sample for parameters not marked as NOT_IN_SAMPLE. - Check that no parameters are missing from the sample file if listed in guc.c without NOT_IN_SAMPLE. The idea of building a list of the GUCs by parsing the sample file comes from Justin, and he wrote the regex used in the patch to find all the GUCs (this same formatting rule basically applies for the last 20~ years or so). In order to test this patch, I have played with manual modifications of postgresql.conf.sample and guc.c, making sure that we detect problems with the GUC rules and the sample file format. The test is located in src/test/modules/test_misc, which is the best location I could think about for such sanity checks. Reviewed-by: Justin Pryzby Discussion: https://postgr.es/m/Yf9YGSwPiMu0c7fP@paquier.xyz
Diffstat (limited to 'src/backend/commands/async.c')
0 files changed, 0 insertions, 0 deletions