@ -9926,11 +9926,6 @@ WARNING: there is no transaction in progress
-- Change application_name of remote connection to special one
-- Change application_name of remote connection to special one
-- so that we can easily terminate the connection later.
-- so that we can easily terminate the connection later.
ALTER SERVER loopback OPTIONS (application_name 'fdw_retry_check');
ALTER SERVER loopback OPTIONS (application_name 'fdw_retry_check');
-- If debug_discard_caches is active, it results in
-- dropping remote connections after every transaction, making it
-- impossible to test termination meaningfully. So turn that off
-- for this test.
SET debug_discard_caches = 0;
-- Make sure we have a remote connection.
-- Make sure we have a remote connection.
SELECT 1 FROM ft1 LIMIT 1;
SELECT 1 FROM ft1 LIMIT 1;
?column?
?column?
@ -9939,13 +9934,12 @@ SELECT 1 FROM ft1 LIMIT 1;
(1 row)
(1 row)
-- Terminate the remote connection and wait for the termination to complete.
-- Terminate the remote connection and wait for the termination to complete.
SELECT pg_terminate_backend(pid, 180000) FROM pg_stat_activity
-- (If a cache flush happens, the remote connection might have already been
-- dropped; so code this step in a way that doesn't fail if no connection.)
DO $$ BEGIN
PERFORM pg_terminate_backend(pid, 180000) FROM pg_stat_activity
WHERE application_name = 'fdw_retry_check';
WHERE application_name = 'fdw_retry_check';
pg_terminate_backend
END $$;
----------------------
t
(1 row)
-- This query should detect the broken connection when starting new remote
-- This query should detect the broken connection when starting new remote
-- transaction, reestablish new connection, and then succeed.
-- transaction, reestablish new connection, and then succeed.
BEGIN;
BEGIN;
@ -9958,13 +9952,10 @@ SELECT 1 FROM ft1 LIMIT 1;
-- If we detect the broken connection when starting a new remote
-- If we detect the broken connection when starting a new remote
-- subtransaction, we should fail instead of establishing a new connection.
-- subtransaction, we should fail instead of establishing a new connection.
-- Terminate the remote connection and wait for the termination to complete.
-- Terminate the remote connection and wait for the termination to complete.
SELECT pg_terminate_backend(pid, 180000) FROM pg_stat_activity
DO $$ BEGIN
PERFORM pg_terminate_backend(pid, 180000) FROM pg_stat_activity
WHERE application_name = 'fdw_retry_check';
WHERE application_name = 'fdw_retry_check';
pg_terminate_backend
END $$;
----------------------
t
(1 row)
SAVEPOINT s;
SAVEPOINT s;
-- The text of the error might vary across platforms, so only show SQLSTATE.
-- The text of the error might vary across platforms, so only show SQLSTATE.
\set VERBOSITY sqlstate
\set VERBOSITY sqlstate
@ -9972,7 +9963,6 @@ SELECT 1 FROM ft1 LIMIT 1; -- should fail
ERROR: 08006
ERROR: 08006
\set VERBOSITY default
\set VERBOSITY default
COMMIT;
COMMIT;
RESET debug_discard_caches;
-- =============================================================================
-- =============================================================================
-- test connection invalidation cases and postgres_fdw_get_connections function
-- test connection invalidation cases and postgres_fdw_get_connections function
-- =============================================================================
-- =============================================================================
@ -11629,74 +11619,66 @@ HINT: There are no valid options in this context.
-- ===================================================================
-- ===================================================================
-- test postgres_fdw.application_name GUC
-- test postgres_fdw.application_name GUC
-- ===================================================================
-- ===================================================================
--- Turn debug_discard_caches off for this test to make sure that
-- To avoid race conditions in checking the remote session's application_name,
--- the remote connection is alive when checking its application_name.
-- use this view to make the remote session itself read its application_name.
SET debug_discard_caches = 0;
CREATE VIEW my_application_name AS
SELECT application_name FROM pg_stat_activity WHERE pid = pg_backend_pid();
CREATE FOREIGN TABLE remote_application_name (application_name text)
SERVER loopback2
OPTIONS (schema_name 'public', table_name 'my_application_name');
SELECT count(*) FROM remote_application_name;
count
-------
1
(1 row)
-- Specify escape sequences in application_name option of a server
-- Specify escape sequences in application_name option of a server
-- object so as to test that they are replaced with status information
-- object so as to test that they are replaced with status information
-- expectedly.
-- expectedly. Note that we are also relying on ALTER SERVER to force
-- the remote session to be restarted with its new application name.
--
--
-- Since pg_stat_activity.application_name may be truncated to less than
-- Since pg_stat_activity.application_name may be truncated to less than
-- NAMEDATALEN characters, note that substring() needs to be used
-- NAMEDATALEN characters, note that substring() needs to be used
-- at the condition of test query to make sure that the string consisting
-- at the condition of test query to make sure that the string consisting
-- of database name and process ID is also less than that.
-- of database name and process ID is also less than that.
ALTER SERVER loopback2 OPTIONS (application_name 'fdw_%d%p');
ALTER SERVER loopback2 OPTIONS (application_name 'fdw_%d%p');
SELECT 1 FROM ft6 LIMIT 1;
SELECT count(*) FROM remote_application_name
?column?
----------
1
(1 row)
SELECT pg_terminate_backend(pid, 180000) FROM pg_stat_activity
WHERE application_name =
WHERE application_name =
substring('fdw_' || current_database() || pg_backend_pid() for
substring('fdw_' || current_database() || pg_backend_pid() for
current_setting('max_identifier_length')::int);
current_setting('max_identifier_length')::int);
pg_terminate_backend
count
----------------------
-------
t
1
(1 row)
(1 row)
-- postgres_fdw.application_name overrides application_name option
-- postgres_fdw.application_name overrides application_name option
-- of a server object if both settings are present.
-- of a server object if both settings are present.
ALTER SERVER loopback2 OPTIONS (SET application_name 'fdw_wrong');
SET postgres_fdw.application_name TO 'fdw_%a%u%%';
SET postgres_fdw.application_name TO 'fdw_%a%u%%';
SELECT 1 FROM ft6 LIMIT 1;
SELECT count(*) FROM remote_application_name
?column?
----------
1
(1 row)
SELECT pg_terminate_backend(pid, 180000) FROM pg_stat_activity
WHERE application_name =
WHERE application_name =
substring('fdw_' || current_setting('application_name') ||
substring('fdw_' || current_setting('application_name') ||
CURRENT_USER || '%' for current_setting('max_identifier_length')::int);
CURRENT_USER || '%' for current_setting('max_identifier_length')::int);
pg_terminate_backend
count
----------------------
-------
t
1
(1 row)
(1 row)
RESET postgres_fdw.application_name;
-- Test %c (session ID) and %C (cluster name) escape sequences.
-- Test %c (session ID) and %C (cluster name) escape sequences.
SET postgres_fdw.application_name TO 'fdw_%C%c';
ALTER SERVER loopback2 OPTIONS (SET application_name 'fdw_%C%c');
SELECT 1 FROM ft6 LIMIT 1;
SELECT count(*) FROM remote_application_name
?column?
----------
1
(1 row)
SELECT pg_terminate_backend(pid, 180000) FROM pg_stat_activity
WHERE application_name =
WHERE application_name =
substring('fdw_' || current_setting('cluster_name') ||
substring('fdw_' || current_setting('cluster_name') ||
to_hex(trunc(EXTRACT(EPOCH FROM (SELECT backend_start FROM
to_hex(trunc(EXTRACT(EPOCH FROM (SELECT backend_start FROM
pg_stat_get_activity(pg_backend_pid()))))::integer) || '.' ||
pg_stat_get_activity(pg_backend_pid()))))::integer) || '.' ||
to_hex(pg_backend_pid())
to_hex(pg_backend_pid())
for current_setting('max_identifier_length')::int);
for current_setting('max_identifier_length')::int);
pg_terminate_backend
count
----------------------
-------
t
1
(1 row)
(1 row)
--Clean up
RESET postgres_fdw.application_name;
RESET debug_discard_caches;
-- ===================================================================
-- ===================================================================
-- test parallel commit
-- test parallel commit
-- ===================================================================
-- ===================================================================