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 68 69
|
#!/usr/bin/perl -w
use strict;
use FindBin qw($Bin);
use Test::More tests => 3 + (4 * 5) + (4 * 5);
BEGIN
{
use_ok('Rose::DB');
use_ok('Rose::DB::Cache');
use_ok('Rose::DB::Cache::Entry');
require 't/test-lib.pl';
}
foreach my $db_type (map { "${_}_admin" } qw(mysql pg informix sqlite oracle))
{
SKIP:
{
unless(have_db($db_type))
{
skip("$db_type tests", 4);
}
}
next unless(have_db($db_type));
Rose::DB->default_type($db_type);
my($db, $db2);
ok($db = Rose::DB->new_or_cached(), "new_or_cached 1 - $db_type");
ok(ref $db && $db->isa('Rose::DB'), "new_or_cached 2 - $db_type");
ok($db2 = Rose::DB->new_or_cached(), "new_or_cached 3 - $db_type");
is($db->dbh, $db2->dbh, "new_or_cached dbh check - $db_type");
}
no warnings 'redefine';
*Rose::DB::dbi_connect = sub { shift; DBI->connect_cached(@_) };
foreach my $db_type (map { "${_}_admin" } qw(mysql pg informix sqlite oracle))
{
SKIP:
{
unless(have_db($db_type))
{
skip("$db_type tests", 4);
}
}
next unless(have_db($db_type));
Rose::DB->default_type($db_type);
my($db, $db2);
ok($db = Rose::DB->new(), "dbi_connect override 1 - $db_type");
ok(ref $db && $db->isa('Rose::DB'), "dbi_connect override 2 - $db_type");
ok($db2 = Rose::DB->new(), "dbi_connect override 3 - $db_type");
is($db->dbh, $db2->dbh, "dbi_connect override dbh check - $db_type");
}
|