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
f_varchar character varying (255),
f_double double precision,
f_bigint bigint not null,
- f_char character(10) default 'FOO',
+ f_char character(10) default 'FOO'::character(10),
f_bool boolean,
f_bin bytea,
- f_tz timestamp,
+ f_tz timestamp default '1970-01-01 00:00:00'::TIMESTAMP,
f_text text,
f_fk1 integer not null references t_test2 (f_id),
f_dropped text,
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 column f_char drop default;
- -- The following are allowed by the grammar
+ -- The following are allowed by the grammar
-- but won\'t do anything... - ky
alter table t_text1 alter column f_char set not null;
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( $f8->data_type, 'timestamp', 'Field is a timestamp' );
is( $f8->is_nullable, 1, 'Field can be null' );
is( $f8->size, 0, 'Size is "0"' );
-is( $f8->default_value, undef, 'Default value is undefined' );
+is( $f8->default_value, '1970-01-01 00:00:00', 'Default value is 1970-01-01 00:00:00' );
is( $f8->is_primary_key, 0, 'Field is not PK' );
my $f9 = shift @t1_fields;
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");