package # hide from PAUSE
DBICTest;
+# load early so that `perl -It/lib -MDBICTest` keeps working
+use ANFANG;
+
use strict;
use warnings;
-use DBICTest::Util qw( local_umask dbg DEBUG_TEST_CONCURRENCY_LOCKS );
-use DBICTest::Schema;
+
+# this noop trick initializes the STDOUT, so that the TAP::Harness
+# issued IO::Select->can_read calls (which are blocking wtf wtf wtf)
+# keep spinning and scheduling jobs
+# This results in an overall much smoother job-queue drainage, since
+# the Harness blocks less
+# (ideally this needs to be addressed in T::H, but a quick patchjob
+# broke everything so tabling it for now)
+BEGIN {
+ # FIXME - there probably is some way to determine a harness run (T::H or
+ # prove) but I do not know it offhand, especially on older environments
+ # Go with the safer option
+ if ($INC{'Test/Builder.pm'}) {
+ local $| = 1;
+ print "#\n";
+ }
+}
+
+
+use DBICTest::Util qw(
+ local_umask tmpdir await_flock
+ dbg DEBUG_TEST_CONCURRENCY_LOCKS PEEPEENESS
+);
use DBICTest::Util::LeakTracer qw/populate_weakregistry assert_empty_weakregistry/;
-use DBIx::Class::_Util 'detected_reinvoked_destructor';
+use DBICTest::Schema;
+use DBIx::Class::_Util qw( detected_reinvoked_destructor scope_guard );
use Carp;
use Path::Class::File ();
-use File::Spec;
use Fcntl qw/:DEFAULT :flock/;
use Config;
-use Scope::Guard ();
=head1 NAME
=head1 SYNOPSIS
- use lib qw(t/lib);
- use DBICTest;
+ BEGIN { do "./t/lib/ANFANG.pm" or die ( $@ || $! ) }
+
+ use warnings;
+ use strict;
use Test::More;
+ use DBICTest;
my $schema = DBICTest->init_schema();
sub import {
my $self = shift;
- my $lockpath = DBICTest::RunMode->tmpdir->file('_dbictest_global.lock');
+ my $lockpath = tmpdir . '_dbictest_global.lock';
{
my $u = local_umask(0); # so that the file opens as 666, and any user can lock
DEBUG_TEST_CONCURRENCY_LOCKS > 1
and dbg "Waiting for EXCLUSIVE global lock...";
- flock ($global_lock_fh, LOCK_EX) or die "Unable to lock $lockpath: $!";
+ await_flock ($global_lock_fh, LOCK_EX) or die "Unable to lock $lockpath: $!";
DEBUG_TEST_CONCURRENCY_LOCKS > 1
and dbg "Got EXCLUSIVE global lock";
DEBUG_TEST_CONCURRENCY_LOCKS > 1
and dbg "Waiting for SHARED global lock...";
- flock ($global_lock_fh, LOCK_SH) or die "Unable to lock $lockpath: $!";
+ await_flock ($global_lock_fh, LOCK_SH) or die "Unable to lock $lockpath: $!";
DEBUG_TEST_CONCURRENCY_LOCKS > 1
and dbg "Got SHARED global lock";
return if (
# this perl leaks handles, delaying DESTROY, can't work right
- DBIx::Class::_ENV_::PEEPEENESS
+ PEEPEENESS
or
! -f $db_file
);
return;
}
elsif ($event eq 'disconnect') {
+ return unless $connected; # we already disconnected earlier
$connected = 0;
}
elsif ($event eq 'DESTROY' and ! $connected ) {
my $guard;
if ( ($ENV{TRAVIS}||'') eq 'true' and my $old_dbg = $schema->storage->debug ) {
- $guard = Scope::Guard->new(sub { $schema->storage->debug($old_dbg) });
+ $guard = scope_guard { $schema->storage->debug($old_dbg) };
$schema->storage->debug(0);
}
my $guard;
if ( ($ENV{TRAVIS}||'') eq 'true' and my $old_dbg = $schema->storage->debug ) {
- $guard = Scope::Guard->new(sub { $schema->storage->debug($old_dbg) });
+ $guard = scope_guard { $schema->storage->debug($old_dbg) };
$schema->storage->debug(0);
}