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 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149
|
#!/usr/local/bin/perl
#
# $Id: 50chopblanks.t,v 1.1.1.1 2004/08/08 15:03:59 matt Exp $
#
# This driver should check whether 'ChopBlanks' works.
#
#
# Make -w happy
#
use vars qw($test_dsn $test_user $test_password $mdriver $verbose $state
$dbdriver);
use vars qw($COL_NULLABLE $COL_KEY);
$test_dsn = '';
$test_user = '';
$test_password = '';
#
# Include lib.pl
#
use DBI;
use strict;
$mdriver = "";
{
my $file;
foreach $file ("lib.pl", "t/lib.pl") {
do "./$file"; if ($@) { print STDERR "Error while executing lib.pl: $@\n";
exit 10;
}
if ($mdriver ne '') {
last;
}
}
}
sub ServerError() {
print STDERR ("Cannot connect: ", $DBI::errstr, "\n",
"\tEither your server is not up and running or you have no\n",
"\tpermissions for acessing the DSN $test_dsn.\n",
"\tThis test requires a running server and write permissions.\n",
"\tPlease make sure your server is running and you have\n",
"\tpermissions, then retry.\n");
exit 10;
}
#
# Main loop; leave this untouched, put tests after creating
# the new table.
#
while (Testing()) {
my ($dbh, $sth, $query);
#
# Connect to the database
Test($state or ($dbh = DBI->connect($test_dsn, $test_user,
$test_password)))
or ServerError();
#
# Find a possible new table name
#
my $table = '';
Test($state or $table = FindNewTable($dbh))
or ErrMsgF("Cannot determine a legal table name: Error %s.\n",
$dbh->errstr);
#
# Create a new table; EDIT THIS!
#
Test($state or ($query = TableDefinition($table,
["id", "INTEGER", 4, $COL_NULLABLE],
["name", "CHAR", 64, $COL_NULLABLE]),
$dbh->do($query)))
or ErrMsgF("Cannot create table: Error %s.\n",
$dbh->errstr);
#
# and here's the right place for inserting new tests:
#
my @rows
= ([1, 'NULL'],
[2, ' '],
[3, ' a b c ']);
my $ref;
foreach $ref (@rows) {
my ($id, $name) = @$ref;
if (!$state) {
$query = sprintf("INSERT INTO $table (id, name) VALUES ($id, %s)",
$dbh->quote($name));
}
Test($state or $dbh->do($query))
or ErrMsgF("INSERT failed: query $query, error %s.\n",
$dbh->errstr);
$query = "SELECT id, name FROM $table WHERE id = $id\n";
Test($state or ($sth = $dbh->prepare($query)))
or ErrMsgF("prepare failed: query $query, error %s.\n",
$dbh->errstr);
# First try to retreive without chopping blanks.
$sth->{'ChopBlanks'} = 0;
Test($state or $sth->execute)
or ErrMsgF("execute failed: query %s, error %s.\n", $query,
$sth->errstr);
Test($state or defined($ref = $sth->fetchrow_arrayref))
or ErrMsgF("fetch failed: query $query, error %s.\n",
$sth->errstr);
Test($state or ($$ref[1] eq $name)
or ($name =~ /^$$ref[1]\s+$/ &&
($dbdriver eq 'mysql' || $dbdriver eq 'ODBC')))
or ErrMsgF("problems with ChopBlanks = 0:"
. " expected '%s', got '%s'.\n",
$name, $$ref[1]);
Test($state or $sth->finish());
# Now try to retreive with chopping blanks.
$sth->{'ChopBlanks'} = 1;
Test($state or $sth->execute)
or ErrMsg("execute failed: query $query, error %s.\n",
$sth->errstr);
my $n = $name;
$n =~ s/\s+$//;
Test($state or ($ref = $sth->fetchrow_arrayref))
or ErrMsgF("fetch failed: query $query, error %s.\n",
$sth->errstr);
Test($state or ($$ref[1] eq $n))
or ErrMsgF("problems with ChopBlanks = 1:"
. " expected '%s', got '%s'.\n",
$n, $$ref[1]);
Test($state or $sth->finish)
or ErrMsgF("Cannot finish: %s.\n", $sth->errstr);
}
#
# Finally drop the test table.
#
Test($state or $dbh->do("DROP TABLE $table"))
or ErrMsgF("Cannot DROP test table $table: %s.\n",
$dbh->errstr);
# ... and disconnect
Test($state or $dbh->disconnect)
or ErrMsgF("Cannot disconnect: %s.\n", $dbh->errmsg);
}
|