view DBD/t/75mil.t @ 0:cedccb7e0143

Copy of clients/perl directory without Tests from MonetDB changeset 4d2d4532228a.
author Sjoerd Mullender <sjoerd@acm.org>
date Mon, 19 Sep 2016 15:15:52 +0200 (2016-09-19)
parents
children a0ec9e080a5b
line wrap: on
line source
#!perl -I./t

# This Source Code Form is subject to the terms of the Mozilla Public
# License, v. 2.0.  If a copy of the MPL was not distributed with this
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
#
# Copyright 1997 - July 2008 CWI, August 2008 - 2016 MonetDB B.V.

$| = 1;

use strict;
use warnings;
use DBI();
use DBD_TEST();

use Test::More;

if (defined $ENV{DBI_DSN}) {
  if ($ENV{DBI_DSN} =~ /dbi:monetdb:/) {
    plan tests => 30;
  } else {
    plan skip_all => 'dbi:monetdb: specific tests';
  }
} else {
  plan skip_all => 'Cannot test without DB info';
}

pass('MIL tests');

$ENV{DBI_DSN} .= ';language=mil';

my $dbh = DBI->connect or die "Connect failed: $DBI::errstr\n";
pass('Database connection created');

for ( 7 .. 9 )
{
  my $sth = $dbh->prepare("print( $_ );");
  ok( defined $sth,'Statement handle defined');
  ok( $sth->execute,'execute');
  my $row = $sth->fetch;
  is( $#$row, 0,'last index');
  is( $row->[0], $_,'field 0');
}
{
  local $dbh->{PrintError} = 0;
  my $sth = $dbh->prepare('( xyz 1);');
  ok(!$sth->execute,'execute');
  like( $sth->errstr, qr/!ERROR:/,'Error expected');
}
ok( $dbh->do( $_ ), $_) for 'var b := new( int, str );';
ok( $dbh->do( $_ ), $_) for 'insert( b, 3,"T3");';
{
  my $sth = $dbh->prepare('insert( b, ?, ? );');
  ok( defined $sth,'Statement handle defined');
  ok( $sth->bind_param( 1,  7 , DBI::SQL_INTEGER() ),'bind');
  ok( $sth->bind_param( 2,'T7' ),'bind');
  ok( $sth->execute,'execute');
}
{
  my $sth = $dbh->prepare('print( b );');
  ok( defined $sth,'Statement handle defined');
  ok( $sth->execute,'execute');
  for ( 3, 7 )
  {
    my $row = $sth->fetch;
    is( $row->[0],  $_ ,"fetch  $_");
    is( $row->[1],"T$_","fetch T$_");
  }
}
ok( $dbh->rollback,'Rollback');
ok( $dbh->disconnect,'Disconnect');