|
Packit |
723767 |
#!/usr/bin/perl
|
|
Packit |
723767 |
|
|
Packit |
723767 |
# This test works, but as far as I can tell this doesn't actually test
|
|
Packit |
723767 |
# the thing that the test was originally meant to test.
|
|
Packit |
723767 |
|
|
Packit |
723767 |
use strict;
|
|
Packit |
723767 |
BEGIN {
|
|
Packit |
723767 |
$| = 1;
|
|
Packit |
723767 |
$^W = 1;
|
|
Packit |
723767 |
}
|
|
Packit |
723767 |
|
|
Packit |
723767 |
use Test::More tests => 9;
|
|
Packit |
723767 |
use lib "t/lib";
|
|
Packit |
723767 |
use SQLiteTest;
|
|
Packit |
723767 |
|
|
Packit |
723767 |
my $create1 = 'CREATE TABLE table1 (id INTEGER NOT NULL, name CHAR (64) NOT NULL)';
|
|
Packit |
723767 |
my $create2 = 'CREATE TABLE table2 (id INTEGER NOT NULL, name CHAR (64) NOT NULL)';
|
|
Packit |
723767 |
my $drop1 = 'DROP TABLE table1';
|
|
Packit |
723767 |
my $drop2 = 'DROP TABLE table2';
|
|
Packit |
723767 |
|
|
Packit |
723767 |
# diag("Parent connecting... ($$)\n");
|
|
Packit |
723767 |
SCOPE: {
|
|
Packit |
723767 |
my $dbh = connect_ok( dbfile => 'foo' );
|
|
Packit |
723767 |
ok( $dbh->do($create1), $create1 );
|
|
Packit |
723767 |
ok( $dbh->do($create2), $create2 );
|
|
Packit |
723767 |
ok( $dbh->disconnect, '->disconnect ok' );
|
|
Packit |
723767 |
}
|
|
Packit |
723767 |
my $dbfile = dbfile('foo');
|
|
Packit |
723767 |
|
|
Packit |
723767 |
my $pid;
|
|
Packit |
723767 |
# diag("Forking... ($$)");
|
|
Packit |
723767 |
if ( not defined( $pid = fork() ) ) {
|
|
Packit |
723767 |
die("fork: $!");
|
|
Packit |
723767 |
|
|
Packit |
723767 |
} elsif ( $pid == 0 ) {
|
|
Packit |
723767 |
# Pause to let the parent connect
|
|
Packit |
723767 |
sleep(2);
|
|
Packit |
723767 |
|
|
Packit |
723767 |
# diag("Child starting... ($$)");
|
|
Packit |
723767 |
my $dbh = DBI->connect(
|
|
Packit |
723767 |
"dbi:SQLite:dbname=$dbfile", '', ''
|
|
Packit |
723767 |
) or die 'connect failed';
|
|
Packit |
723767 |
$dbh->do($drop2) or die "DROP ok";
|
|
Packit |
723767 |
$dbh->disconnect or die "disconnect ok";
|
|
Packit |
723767 |
# diag("Child exiting... ($$)");
|
|
Packit |
723767 |
|
|
Packit |
723767 |
exit(0);
|
|
Packit |
723767 |
|
|
Packit |
723767 |
}
|
|
Packit |
723767 |
|
|
Packit |
723767 |
SCOPE: {
|
|
Packit |
723767 |
# Parent process
|
|
Packit |
723767 |
my $dbh = connect_ok( dbfile => 'foo' );
|
|
Packit |
723767 |
# diag("Waiting for child... ($$)");
|
|
Packit |
723767 |
ok( waitpid($pid, 0) != -1, "waitpid" );
|
|
Packit |
723767 |
|
|
Packit |
723767 |
# Make sure the child actually deleted table2
|
|
Packit |
723767 |
ok( $dbh->do($drop1), $drop1 ) or diag("Error: '$DBI::errstr'");
|
|
Packit |
723767 |
ok( $dbh->do($create2), $create2 ) or diag("Error: '$DBI::errstr'");
|
|
Packit |
723767 |
ok( $dbh->disconnect, '->disconnect ok' );
|
|
Packit |
723767 |
}
|