mirror of
https://git.postgresql.org/git/postgresql.git
synced 2025-01-18 18:44:06 +08:00
Test that event triggers work in functions and procedures
This ensures that we have coverage of all the ProcessUtilityContext variants.
This commit is contained in:
parent
f8c10f616f
commit
ae307861d8
src/test/regress
@ -112,10 +112,45 @@ create table event_trigger_fire5 (a int);
|
|||||||
NOTICE: test_event_trigger: ddl_command_start CREATE TABLE
|
NOTICE: test_event_trigger: ddl_command_start CREATE TABLE
|
||||||
NOTICE: test_event_trigger: ddl_command_start CREATE TABLE
|
NOTICE: test_event_trigger: ddl_command_start CREATE TABLE
|
||||||
NOTICE: test_event_trigger: ddl_command_end CREATE TABLE
|
NOTICE: test_event_trigger: ddl_command_end CREATE TABLE
|
||||||
|
-- non-top-level command
|
||||||
|
create function f1() returns int
|
||||||
|
language plpgsql
|
||||||
|
as $$
|
||||||
|
begin
|
||||||
|
create table event_trigger_fire6 (a int);
|
||||||
|
return 0;
|
||||||
|
end $$;
|
||||||
|
NOTICE: test_event_trigger: ddl_command_start CREATE FUNCTION
|
||||||
|
NOTICE: test_event_trigger: ddl_command_start CREATE FUNCTION
|
||||||
|
NOTICE: test_event_trigger: ddl_command_end CREATE FUNCTION
|
||||||
|
select f1();
|
||||||
|
NOTICE: test_event_trigger: ddl_command_start CREATE TABLE
|
||||||
|
NOTICE: test_event_trigger: ddl_command_start CREATE TABLE
|
||||||
|
NOTICE: test_event_trigger: ddl_command_end CREATE TABLE
|
||||||
|
f1
|
||||||
|
----
|
||||||
|
0
|
||||||
|
(1 row)
|
||||||
|
|
||||||
|
-- non-top-level command
|
||||||
|
create procedure p1()
|
||||||
|
language plpgsql
|
||||||
|
as $$
|
||||||
|
begin
|
||||||
|
create table event_trigger_fire7 (a int);
|
||||||
|
end $$;
|
||||||
|
NOTICE: test_event_trigger: ddl_command_start CREATE PROCEDURE
|
||||||
|
NOTICE: test_event_trigger: ddl_command_end CREATE PROCEDURE
|
||||||
|
call p1();
|
||||||
|
NOTICE: test_event_trigger: ddl_command_start CREATE TABLE
|
||||||
|
NOTICE: test_event_trigger: ddl_command_start CREATE TABLE
|
||||||
|
NOTICE: test_event_trigger: ddl_command_end CREATE TABLE
|
||||||
-- clean up
|
-- clean up
|
||||||
alter event trigger regress_event_trigger disable;
|
alter event trigger regress_event_trigger disable;
|
||||||
drop table event_trigger_fire2, event_trigger_fire3, event_trigger_fire4, event_trigger_fire5;
|
drop table event_trigger_fire2, event_trigger_fire3, event_trigger_fire4, event_trigger_fire5, event_trigger_fire6, event_trigger_fire7;
|
||||||
NOTICE: test_event_trigger: ddl_command_end DROP TABLE
|
NOTICE: test_event_trigger: ddl_command_end DROP TABLE
|
||||||
|
drop routine f1(), p1();
|
||||||
|
NOTICE: test_event_trigger: ddl_command_end DROP ROUTINE
|
||||||
-- regress_event_trigger_end should fire on these commands
|
-- regress_event_trigger_end should fire on these commands
|
||||||
grant all on table event_trigger_fire1 to public;
|
grant all on table event_trigger_fire1 to public;
|
||||||
NOTICE: test_event_trigger: ddl_command_end GRANT
|
NOTICE: test_event_trigger: ddl_command_end GRANT
|
||||||
|
@ -106,9 +106,28 @@ create table event_trigger_fire4 (a int);
|
|||||||
reset session_replication_role;
|
reset session_replication_role;
|
||||||
-- fires all three
|
-- fires all three
|
||||||
create table event_trigger_fire5 (a int);
|
create table event_trigger_fire5 (a int);
|
||||||
|
-- non-top-level command
|
||||||
|
create function f1() returns int
|
||||||
|
language plpgsql
|
||||||
|
as $$
|
||||||
|
begin
|
||||||
|
create table event_trigger_fire6 (a int);
|
||||||
|
return 0;
|
||||||
|
end $$;
|
||||||
|
select f1();
|
||||||
|
-- non-top-level command
|
||||||
|
create procedure p1()
|
||||||
|
language plpgsql
|
||||||
|
as $$
|
||||||
|
begin
|
||||||
|
create table event_trigger_fire7 (a int);
|
||||||
|
end $$;
|
||||||
|
call p1();
|
||||||
|
|
||||||
-- clean up
|
-- clean up
|
||||||
alter event trigger regress_event_trigger disable;
|
alter event trigger regress_event_trigger disable;
|
||||||
drop table event_trigger_fire2, event_trigger_fire3, event_trigger_fire4, event_trigger_fire5;
|
drop table event_trigger_fire2, event_trigger_fire3, event_trigger_fire4, event_trigger_fire5, event_trigger_fire6, event_trigger_fire7;
|
||||||
|
drop routine f1(), p1();
|
||||||
|
|
||||||
-- regress_event_trigger_end should fire on these commands
|
-- regress_event_trigger_end should fire on these commands
|
||||||
grant all on table event_trigger_fire1 to public;
|
grant all on table event_trigger_fire1 to public;
|
||||||
|
Loading…
Reference in New Issue
Block a user