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:
Peter Eisentraut 2018-10-05 15:20:01 +02:00
parent f8c10f616f
commit ae307861d8
2 changed files with 56 additions and 2 deletions

View File

@ -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

View File

@ -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;