use Test::SQL::Translator qw(maybe_plan);
BEGIN {
- maybe_plan(129, 'SQL::Translator::Parser::PostgreSQL');
+ maybe_plan(134, 'SQL::Translator::Parser::PostgreSQL');
SQL::Translator::Parser::PostgreSQL->import('parse');
}
my $t = SQL::Translator->new( trace => 0 );
-my $sql = q[
+my $sql = q{
-- comment on t_test1
create table t_test1 (
-- this is the primary key
name text,
price numeric
);
-
+
CREATE TEMP TABLE products_2 (
product_no integer,
name text,
price numeric
);
+ CREATE TRIGGER test_trigger
+ BEFORE INSERT OR UPDATE OR DELETE
+ ON products_1
+ FOR EACH ROW
+ EXECUTE PROCEDURE foo();
+
alter table t_test1 add f_fk2 integer;
alter table only t_test1 add constraint c_u1 unique (f_varchar);
alter table t_test1 alter f_char set statistics 10;
alter table t_test1 alter f_text set storage extended;
-
+
alter table t_test1 rename column f_text to foo;
alter table t_test1 rename to foo;
alter table t_test1 owner to foo;
commit;
-];
+};
$| = 1;
is( exists $schema->get_table('products_1')->extra()->{'temporary'}, "", "Table is NOT temporary");
is( $schema->get_table('products_2')->extra('temporary'), 1,"Table is TEMP");
is( $schema->get_table('products_3')->extra('temporary'), 1,"Table is TEMPORARY");
+
+# test trigger
+my $trigger = $schema->get_trigger('test_trigger');
+is( $trigger->on_table, 'products_1', "Trigger is on correct table");
+is_deeply( scalar $trigger->database_events, [qw(insert update delete)], "Correct events for trigger");
+
+is( $trigger->perform_action_when, 'before', "Correct time for trigger");
+is( $trigger->scope, 'row', "Correct scope for trigger");
+is( $trigger->action, 'EXECUTE PROCEDURE foo()', "Correct action for trigger");