mirror of
https://github.com/postgres/postgres.git
synced 2025-10-24 01:29:19 +03:00
This commit expands more the refactoring of the regression tests of
pg_stat_statements, with tests moved out of pg_stat_statements.sql into
separate files. The following file structure is now used:
- select is mostly the former pg_stat_statements.sql, renamed.
- dml for INSERT/UPDATE/DELETE and MERGE
- user_activity, to test role-level checks and stat resets.
- wal, to check the WAL generation after some queries.
Like e8dbdb1
, there is no change in terms of code coverage or results,
and this finishes the split I was aiming for in these tests. Most of
the tests used "test" of "pgss_test" as names for the tables used, these
are renamed to less generic names.
Reviewed-by: Bertrand Drouvot
Discussion: https://postgr.es/m/Y/7Y9U/y/keAW3qH@paquier.xyz
21 lines
600 B
SQL
21 lines
600 B
SQL
--
|
|
-- Validate WAL generation metrics
|
|
--
|
|
|
|
SET pg_stat_statements.track_utility = FALSE;
|
|
|
|
CREATE TABLE pgss_wal_tab (a int, b char(20));
|
|
|
|
INSERT INTO pgss_wal_tab VALUES(generate_series(1, 10), 'aaa');
|
|
UPDATE pgss_wal_tab SET b = 'bbb' WHERE a > 7;
|
|
DELETE FROM pgss_wal_tab WHERE a > 9;
|
|
DROP TABLE pgss_wal_tab;
|
|
|
|
-- Check WAL is generated for the above statements
|
|
SELECT query, calls, rows,
|
|
wal_bytes > 0 as wal_bytes_generated,
|
|
wal_records > 0 as wal_records_generated,
|
|
wal_records >= rows as wal_records_ge_rows
|
|
FROM pg_stat_statements ORDER BY query COLLATE "C";
|
|
SELECT pg_stat_statements_reset();
|