mirror of
https://git.postgresql.org/git/postgresql.git
synced 2026-02-12 01:18:35 +08:00
This can be used to load an injection point and prewarm the backend-level cache before running it, to avoid issues if the point cannot be loaded due to restrictions in the code path where it would be run, like a critical section where no memory allocation can happen (load_external_function() can do allocations when expanding a library name). Tests can use a macro called INJECTION_POINT_LOAD() to load an injection point. The test module injection_points gains some tests, and a SQL function able to load an injection point. Based on a request from Andrey Borodin, who has implemented a test for multixacts requiring this facility. Reviewed-by: Andrey Borodin Discussion: https://postgr.es/m/ZkrBE1e2q2wGvsoN@paquier.xyz
67 lines
1.7 KiB
SQL
67 lines
1.7 KiB
SQL
/* src/test/modules/injection_points/injection_points--1.0.sql */
|
|
|
|
-- complain if script is sourced in psql, rather than via CREATE EXTENSION
|
|
\echo Use "CREATE EXTENSION injection_points" to load this file. \quit
|
|
|
|
--
|
|
-- injection_points_attach()
|
|
--
|
|
-- Attaches the action to the given injection point.
|
|
--
|
|
CREATE FUNCTION injection_points_attach(IN point_name TEXT,
|
|
IN action text)
|
|
RETURNS void
|
|
AS 'MODULE_PATHNAME', 'injection_points_attach'
|
|
LANGUAGE C STRICT PARALLEL UNSAFE;
|
|
|
|
--
|
|
-- injection_points_load()
|
|
--
|
|
-- Load an injection point already attached.
|
|
--
|
|
CREATE FUNCTION injection_points_load(IN point_name TEXT)
|
|
RETURNS void
|
|
AS 'MODULE_PATHNAME', 'injection_points_load'
|
|
LANGUAGE C STRICT PARALLEL UNSAFE;
|
|
|
|
--
|
|
-- injection_points_run()
|
|
--
|
|
-- Executes the action attached to the injection point.
|
|
--
|
|
CREATE FUNCTION injection_points_run(IN point_name TEXT)
|
|
RETURNS void
|
|
AS 'MODULE_PATHNAME', 'injection_points_run'
|
|
LANGUAGE C STRICT PARALLEL UNSAFE;
|
|
|
|
--
|
|
-- injection_points_wakeup()
|
|
--
|
|
-- Wakes up a waiting injection point.
|
|
--
|
|
CREATE FUNCTION injection_points_wakeup(IN point_name TEXT)
|
|
RETURNS void
|
|
AS 'MODULE_PATHNAME', 'injection_points_wakeup'
|
|
LANGUAGE C STRICT PARALLEL UNSAFE;
|
|
|
|
--
|
|
-- injection_points_set_local()
|
|
--
|
|
-- Trigger switch to link any future injection points attached to the
|
|
-- current process, useful to make SQL tests concurrently-safe.
|
|
--
|
|
CREATE FUNCTION injection_points_set_local()
|
|
RETURNS void
|
|
AS 'MODULE_PATHNAME', 'injection_points_set_local'
|
|
LANGUAGE C STRICT PARALLEL UNSAFE;
|
|
|
|
--
|
|
-- injection_points_detach()
|
|
--
|
|
-- Detaches the current action, if any, from the given injection point.
|
|
--
|
|
CREATE FUNCTION injection_points_detach(IN point_name TEXT)
|
|
RETURNS void
|
|
AS 'MODULE_PATHNAME', 'injection_points_detach'
|
|
LANGUAGE C STRICT PARALLEL UNSAFE;
|