Re: race condition in pg_class
От | Noah Misch |
---|---|
Тема | Re: race condition in pg_class |
Дата | |
Msg-id | 20250911185729.ad.nmisch@google.com обсуждение исходный текст |
Ответ на | Re: race condition in pg_class (Tom Lane <tgl@sss.pgh.pa.us>) |
Ответы |
Re: race condition in pg_class
|
Список | pgsql-hackers |
On Thu, Sep 11, 2025 at 12:36:04PM -0400, Tom Lane wrote: > inplace010-tests-v1.patch from this message, committed as > 0844b3968, contains this bit: > > new file mode 100644 > index 00000000000..0367c0e37ab > --- /dev/null > +++ b/src/test/regress/sql/database.sql > @@ -0,0 +1,17 @@ > +CREATE DATABASE regression_tbd > + ENCODING utf8 LC_COLLATE "C" LC_CTYPE "C" TEMPLATE template0; > +ALTER DATABASE regression_tbd RENAME TO regression_utf8; > +ALTER DATABASE regression_utf8 SET TABLESPACE regress_tblspace; > +ALTER DATABASE regression_utf8 RESET TABLESPACE; > +ALTER DATABASE regression_utf8 CONNECTION_LIMIT 123; > + > > It emerges that the "ALTER DATABASE regression_utf8 RESET TABLESPACE" > command is a complete no-op [1]. I am guessing that that was not the > behavior you had in mind, and am wondering if we are losing any test > coverage thereby. Did you have a specific reason for manipulating the > TABLESPACE property and not some random GUC setting? I have no specific notes or memories about that RESET TABLESPACE, but I likely wanted "SET TABLESPACE pg_default". RESET TABLESPACE may still have the effect of loading a catcache entry, as a later comment says: -- Test PgDatabaseToastTable. Doing this with GRANT would be slow. BEGIN; UPDATE pg_database SET datacl = array_fill(makeaclitem(10, 10, 'USAGE', false), ARRAY[5e5::int]) WHERE datname = 'regression_utf8'; -- load catcache entry, if nothing else does ALTER DATABASE regression_utf8 RESET TABLESPACE; ROLLBACK; That originated to exercise catcache.c code specific to toast_flatten_tuple() for an inplace-updated catalog. (Commit af8cd16 later removed the inplace-specific code.) SET TABLESPACE rejects transaction blocks, so that would need another way to load a catcache entry. I'm inclined to change it as attached. This doesn't reduce database.sql test coverage of dbcommands.c or catcache.c, so I'll bet it doesn't lose anything vs. the original database.sql commit. Some check-tests runs showed it adding database.sql coverage of catcache.c:1908-1911 and catcache.c:1983-1984, so that's a bonus. > [1] https://www.postgresql.org/message-id/flat/30783e-68c28a00-9-41004480%40130449754 Do you plan to back-patch that? That should dictate whether I back-patch the test change.
Вложения
В списке pgsql-hackers по дате отправления: