DBIx-Class-Migration
view release on metacpan or search on metacpan
lib/DBIx/Class/Migration/PostgresqlSandbox.pm view on Meta::CPAN
$schema_class =~ s/::/-/g;
catdir($self->target_dir, lc($schema_class));
}
sub _determine_auto_start {
my $base_dir = shift;
if(-d $base_dir) {
if( -e catdir($base_dir, 'data','postmaster.pid')) {
return 0;
} else {
return 1;
}
} else {
return 2;
}
}
sub _build_test_postgresql {
my $base_dir = (my $self = shift)->_generate_sandbox_dir;
my $auto_start = _determine_auto_start($base_dir);
my %config = (
auto_start => $auto_start,
base_dir => $base_dir,
initdb_args => $Test::Postgresql58::Defaults{initdb_args},
postmaster_args => $Test::Postgresql58::Defaults{postmaster_args});
unless($auto_start) {
open ( my $pid_fh, '<', catdir($base_dir, 'data','postmaster.pid')) ||
$self->log_die( "Can't open PID file" );
my @lines = <$pid_fh>;
close ($pid_fh);
$config{port} = $lines[3];
}
if(my $testdb = Test::Postgresql58->new(%config)) {
return $testdb;
} else {
$self->log_die( $Test::Postgresql58::errstr );
}
}
sub _write_start {
my $base_dir = (my $self = shift)->test_postgresql->base_dir;
mkpath(my $bin = catdir($base_dir, 'bin'));
open( my $fh, '>', catfile($bin, 'start'))
|| $self->log_die( "Cannot open $bin/start: $!" );
my $test_postgresql = $self->test_postgresql;
my $postmaster = $test_postgresql->{postmaster};
my $data = catdir($base_dir, 'data');
my $port = $test_postgresql->{port};
print $fh <<START;
#!/usr/bin/env sh
$postmaster -p $port -D $data &
START
close($fh);
chmod oct("0755"), catfile($bin, 'start');
}
sub _write_stop {
my $base_dir = (my $self = shift)->test_postgresql->base_dir;
mkpath(my $bin = catdir($base_dir, 'bin'));
open( my $fh, '>', catfile($bin, 'stop'))
|| $self->log_die( "Cannot open $bin/stop: $!" );
my $test_postgresql = $self->test_postgresql;
my $postmaster = $test_postgresql->{postmaster};
my $pid = catdir($base_dir, 'data','postmaster.pid');
print $fh <<STOP;
#!/usr/bin/env sh
kill -INT `head -1 $pid`
STOP
close($fh);
chmod oct("0755"), catfile($bin, 'stop');
}
sub _write_use {
my $base_dir = (my $self = shift)->test_postgresql->base_dir;
mkpath(my $bin = catdir($base_dir, 'bin'));
open( my $fh, '>', catfile($bin, 'use'))
|| $self->log_die( "Cannot open $bin/use: $!" );
my $test_postgresql = $self->test_postgresql;
my $postmaster = $test_postgresql->{postmaster};
my $psql = $postmaster;
$psql =~s/postmaster$/psql/; # ugg
my $port = $test_postgresql->{port};
print $fh <<USE;
#!/usr/bin/env sh
$psql -h localhost --user postgres --port $port -d template1
USE
close($fh);
chmod oct("0755"), catfile($bin, 'use');
}
sub _write_dump {
my $base_dir = (my $self = shift)->test_postgresql->base_dir;
mkpath(my $bin = catdir($base_dir, 'bin'));
open( my $fh, '>', catfile($bin, 'dump'))
|| $self->log_die( "Cannot open $bin/dump: $!" );
my $test_postgresql = $self->test_postgresql;
my $postmaster = $test_postgresql->{postmaster};
my $psql = $postmaster;
$psql =~s/postmaster$/pg_dump/; # ugg
my $port = $test_postgresql->{port};
print $fh <<USE;
#!/usr/bin/env sh
$psql -h localhost --user postgres --port $port \$@
USE
close($fh);
chmod oct("0755"), catfile($bin, 'dump');
}
sub _write_config {
my $base_dir = (my $self = shift)->test_postgresql->base_dir;
mkpath(my $bin = catdir($base_dir, 'bin'));
open( my $fh, '>', catfile($bin, 'config'))
|| $self->log_die( "Cannot open $bin/config $!" );
my $test_postgresql = $self->test_postgresql;
my $postmaster = $test_postgresql->{postmaster};
my $psql = $postmaster;
$psql =~s/postmaster$/pg_dump/; # ugg
my $port = $test_postgresql->{port};
print $fh <<USE;
#!/usr/bin/env perl
my \$connect_info => { dsn => 'DBI:Pg:dbname=template1;host=localhost;port=$port', user => 'postgres', password => '' }
USE
close($fh);
chmod oct("0755"), catfile($bin, 'config');
}
sub make_sandbox {
my $self = shift;
my $base_dir = $self->_generate_sandbox_dir;
if($self->test_postgresql) {
$self->_write_start;
$self->_write_stop;
$self->_write_use;
$self->_write_dump;
$self->_write_config;
my $port = $self->test_postgresql->port;
return "DBI:Pg:dbname=template1;host=127.0.0.1;port=$port",'postgres','';
} else {
$self->log_die( "can't start a postgresql sandbox" );
}
}
## I have to stop the database manually, not sure why, something borks
## postgresql when SQLT->translate in DBIC-DH is called.
#sub DEMOLISH { shift->test_postgresql->stop(SIGINT) }
# ^ 03/04/2015 commenting this out since I 'think' its not an issue anymore
__PACKAGE__->meta->make_immutable;
=head1 NAME
DBIx::Class::Migration::PostgresqlSandbox - Autocreate a postgresql sandbox
=head1 SYNOPSIS
use DBIx::Class::Migration;
my $migration = DBIx::Class::Migration->new(
schema_class=>'Local::Schema',
db_sandbox_class=>'DBIx::Class::Migration::PostgresqlSandbox'),
$migration->prepare;
$migration->install;
=head1 DESCRIPTION
This automatically creates a postgresql sandbox in your C<target_dir> that you can
use for initial prototyping, development and demonstration. If you want to
use this, you will need to add L<Test::Postgresql58> to your C<Makefile.PL> or your
C<dist.ini> file, and get that installed properly. It also requires that you
have Postgresql installed locally (although Postgresql does not need to be running, as
long as we can find in $PATH the binary installation). If your copy of Postgresql
is not installed in a normal location, you might need to locally alter $PATH
so that we can find it. For example, on my Mac, the path to Postgresql binaries
are at C</Library/PostgreSQL/bin> so you can alter the PATH for a single command
like so:
PATH=Library/PostgreSQL/bin:$PATH [command]
( run in 1.820 second using v1.01-cache-2.11-cpan-39bf76dae61 )