1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67
|
#!perl
use strict;
use warnings;
use Test::More;
plan tests => 36;
use_ok( 'SQL::ReservedWords::PostgreSQL' );
my @methods = qw[
is_reserved
is_reserved_by_postgresql7
is_reserved_by_postgresql8
reserved_by
words
];
can_ok( 'SQL::ReservedWords::PostgreSQL', @methods );
foreach my $method ( @methods ) {
ok ! __PACKAGE__->can($method), "$method was not exported by default";
}
ok my @words = SQL::ReservedWords::PostgreSQL->words, 'Got words';
cmp_ok @words, '==', 93, 'Got 93 words';
ok SQL::ReservedWords::PostgreSQL->is_reserved('localtime'), 'LOCALTIME is reserved';
ok SQL::ReservedWords::PostgreSQL->is_reserved_by_postgresql7('localtime'), 'LOCALTIME is reserved by PostgreSQL 7';
ok SQL::ReservedWords::PostgreSQL->is_reserved_by_postgresql8('localtime'), 'LOCALTIME is reserved by PostgreSQL 8';
ok SQL::ReservedWords::PostgreSQL->is_reserved('symmetric'), 'SYMMETRIC is reserved';
ok ! SQL::ReservedWords::PostgreSQL->is_reserved_by_postgresql7('symmetric'), 'SYMMETRIC is not reserved PostgreSQL 7';
ok SQL::ReservedWords::PostgreSQL->is_reserved_by_postgresql8('symmetric'), 'SYMMETRIC is reserved PostgreSQL 8';
ok SQL::ReservedWords::PostgreSQL->is_reserved('array'), 'ARRAY is reserved';
ok SQL::ReservedWords::PostgreSQL->is_reserved_by_postgresql7('array'), 'ARRAY is reserved by PostgreSQL 7';
ok SQL::ReservedWords::PostgreSQL->is_reserved_by_postgresql8('array'), 'ARRAY is reserved by PostgreSQL 8';
ok ! SQL::ReservedWords::PostgreSQL->is_reserved('bogus'), 'BOGUS is not reserved';
ok ! SQL::ReservedWords::PostgreSQL->is_reserved_by_postgresql7('bogus'), 'BOGUS is not reserved by PostgreSQL 7';
ok ! SQL::ReservedWords::PostgreSQL->is_reserved_by_postgresql8('bougus'), 'BOGUS is not reserved by PostgreSQL 8';
ok ! SQL::ReservedWords::PostgreSQL->is_reserved(undef), 'undef is not reserved';
is_deeply [ SQL::ReservedWords::PostgreSQL->reserved_by('localtime') ],
[ 'PostgreSQL 7.3', 'PostgreSQL 7.4', 'PostgreSQL 8.0', 'PostgreSQL 8.1' ],
'Got right reserved by for LOCALTIME';
is_deeply [ SQL::ReservedWords::PostgreSQL->reserved_by('symmetric') ],
[ 'PostgreSQL 8.1' ],
'Got right reserved by for SYMMETRIC';
is_deeply [ SQL::ReservedWords::PostgreSQL->reserved_by('array') ],
[ 'PostgreSQL 7.4', 'PostgreSQL 8.0', 'PostgreSQL 8.1' ],
'Got right reserved by for ARRAY';
is_deeply [ SQL::ReservedWords::PostgreSQL->reserved_by('bogus') ],
[ ],
'Got right reserved by for BOGUS';
use_ok 'SQL::ReservedWords::PostgreSQL', @methods;
foreach my $method ( @methods ) {
cmp_ok __PACKAGE__->can($method), '==', SQL::ReservedWords::PostgreSQL->can($method), "$method was exported";
}
ok @words = words(), 'Got words';
ok is_reserved('localtime'), 'LOCALTIME is reserved';
ok is_reserved_by_postgresql7('localtime'), 'LOCALTIME is reserved by PostgreSQL 7';
ok is_reserved_by_postgresql8('localtime'), 'LOCALTIME is reserved by PostgreSQL 8';
|