summaryrefslogtreecommitdiff
path: root/t/28_schemachange.t
diff options
context:
space:
mode:
Diffstat (limited to 't/28_schemachange.t')
-rw-r--r--t/28_schemachange.t60
1 files changed, 60 insertions, 0 deletions
diff --git a/t/28_schemachange.t b/t/28_schemachange.t
new file mode 100644
index 0000000..66cef08
--- /dev/null
+++ b/t/28_schemachange.t
@@ -0,0 +1,60 @@
+#!/usr/bin/perl
+
+# This test works, but as far as I can tell this doesn't actually test
+# the thing that the test was originally meant to test.
+
+use strict;
+BEGIN {
+ $| = 1;
+ $^W = 1;
+}
+
+use Test::More tests => 9;
+use t::lib::Test;
+
+my $create1 = 'CREATE TABLE table1 (id INTEGER NOT NULL, name CHAR (64) NOT NULL)';
+my $create2 = 'CREATE TABLE table2 (id INTEGER NOT NULL, name CHAR (64) NOT NULL)';
+my $drop1 = 'DROP TABLE table1';
+my $drop2 = 'DROP TABLE table2';
+
+# diag("Parent connecting... ($$)\n");
+SCOPE: {
+ my $dbh = connect_ok( dbfile => 'foo' );
+ ok( $dbh->do($create1), $create1 );
+ ok( $dbh->do($create2), $create2 );
+ ok( $dbh->disconnect, '->disconnect ok' );
+}
+my $dbfile = dbfile('foo');
+
+my $pid;
+# diag("Forking... ($$)");
+if ( not defined( $pid = fork() ) ) {
+ die("fork: $!");
+
+} elsif ( $pid == 0 ) {
+ # Pause to let the parent connect
+ sleep(2);
+
+ # diag("Child starting... ($$)");
+ my $dbh = DBI->connect(
+ "dbi:SQLite:dbname=$dbfile", '', ''
+ ) or die 'connect failed';
+ $dbh->do($drop2) or die "DROP ok";
+ $dbh->disconnect or die "disconnect ok";
+ # diag("Child exiting... ($$)");
+
+ exit(0);
+
+}
+
+SCOPE: {
+ # Parent process
+ my $dbh = connect_ok( dbfile => 'foo' );
+ # diag("Waiting for child... ($$)");
+ ok( waitpid($pid, 0) != -1, "waitpid" );
+
+ # Make sure the child actually deleted table2
+ ok( $dbh->do($drop1), $drop1 ) or diag("Error: '$DBI::errstr'");
+ ok( $dbh->do($create2), $create2 ) or diag("Error: '$DBI::errstr'");
+ ok( $dbh->disconnect, '->disconnect ok' );
+}