#!/usr/bin/perl -w
#
# @(#)$Id: t22mconn.t,v 2003.2 2003/01/03 19:02:36 jleffler Exp $
#
# Test DISCONNECT ALL for DBD::Informix
#
# Copyright 1996-99 Jonathan Leffler
# Copyright 2000 Informix Software Inc
# Copyright 2002-03 IBM
use DBD::Informix::TestHarness;
use strict;
my ($dbase1, $user1, $pass1) = &primary_connection();
my ($dbase2, $user2, $pass2) = &secondary_connection();
if (&is_shared_memory_connection($dbase1) &&
&is_shared_memory_connection($dbase2))
{
&stmt_note("1..0 # Skip: Two shared memory connections - multi-connection test skipped\n");
exit(0);
}
my $dbh1;
&stmt_note("# Connect to: $dbase1\n");
&stmt_fail() unless ($dbh1 = DBI->connect("DBI:Informix:$dbase1", $user1, $pass1));
print "# Driver Information\n";
print "# Name: $dbh1->{Driver}->{Name}\n";
print "# Version: $dbh1->{Driver}->{Version}\n";
print "# Product: $dbh1->{ix_ProductName}\n";
print "# Product Version: $dbh1->{ix_ProductVersion}\n";
print "# Multiple Connections: $dbh1->{ix_MultipleConnections}\n";
print "# \n";
if ($dbh1->{ix_MultipleConnections} == 0)
{
&stmt_note("1..0 # Skip: Multiple connections are not supported\n");
&all_ok();
}
&stmt_note("1..8\n");
&stmt_ok();
&print_dbinfo($dbh1);
my $dbh2;
&stmt_note("# Connect to: $dbase2\n");
&stmt_fail() unless ($dbh2 = DBI->connect("DBI:Informix:$dbase2", $user2, $pass2));
&stmt_ok();
&print_dbinfo($dbh2);
my $stmt1 =
"SELECT TabName FROM 'informix'.SysTables" .
" WHERE TabID <= 10 AND TabType MATCHES '[TV]'" .
" ORDER BY TabName";
my $stmt2 =
"SELECT ColName, ColType FROM 'informix'.SysColumns" .
" WHERE TabID = 1 AND ColNo <= 12 ORDER BY ColName";
my $st1;
&stmt_fail() unless ($st1 = $dbh1->prepare($stmt1));
&stmt_ok();
my $st2;
&stmt_fail() unless ($st2 = $dbh2->prepare($stmt2));
&stmt_ok();
&stmt_fail() unless ($st1->execute);
&stmt_ok();
&stmt_fail() unless ($st2->execute);
&stmt_ok();
my @row1;
my $row2;
LOOP: while (1)
{
# Yes, these are intentionally different!
last LOOP unless (@row1 = $st1->fetchrow);
last LOOP unless ($row2 = $st2->fetch);
print "# 1: $row1[0]\n";
print "# 2: ${$row2}[0]\n";
print "# 2: ${$row2}[1]\n";
}
&stmt_ok();
&stmt_fail() unless ($dbh1->{Driver}->disconnect_all);
&stmt_ok();
&all_ok();