DBIx-TempDB
view release on metacpan or search on metacpan
lib/DBIx/TempDB.pm view on Meta::CPAN
$name =~ s!^/+!!;
$name =~ s!\W!_!g;
$name = lc $name;
return $name if $self->url->canonical_engine ne 'sqlite';
return File::Spec->catfile($self->_tempdir, "$name.sqlite");
}
sub _schema_dsn {
my $self = shift;
local $self->{database_name} = $self->{schema_database};
return $self->dsn;
}
sub _tempdir {
shift->{tempdir} ||= File::Spec->tmpdir;
}
1;
=encoding utf8
=head1 NAME
DBIx::TempDB - Create a temporary database
=head1 VERSION
0.16
=head1 SYNOPSIS
use Test::More;
use DBIx::TempDB;
use DBI;
# provide credentials with environment variables
plan skip_all => 'TEST_PG_DSN=postgresql://postgres@localhost' unless $ENV{TEST_PG_DSN};
# create a temp database
my $tmpdb = DBIx::TempDB->new($ENV{TEST_PG_DSN});
# print complete url to db server with database name
diag $tmpdb->url;
# useful for reading in fixtures
$tmpdb->execute("create table users (name text)");
$tmpdb->execute_file("path/to/file.sql");
# connect to the temp database
my $db = DBI->connect($tmpdb->dsn);
# run tests...
done_testing;
# database is cleaned up when test exit
=head1 DESCRIPTION
L<DBIx::TempDB> is a module which allows you to create a temporary database,
which only lives as long as your process is alive. This can be very
convenient when you want to run tests in parallel, without messing up the
state between tests.
This module currently support PostgreSQL, MySQL and SQLite by installing the optional
L<DBD::Pg>, L<DBD::mysql> and/or L<DBD::SQLite> modules.
Please create an L<issue|https://github.com/jhthorsen/dbix-tempdb/issues>
or pull request for more backend support.
=head1 CAVEAT
Creating a database is easy, but making sure it gets clean up when your
process exit is a totally different ball game. This means that
L<DBIx::TempDB> might fill up your server with random databases, unless
you choose the right "drop strategy". Have a look at the L</drop_from_child>
parameter you can give to L</new> and test the different values and select
the one that works for you.
=head1 ENVIRONMENT VARIABLES
=head2 DBIX_TEMP_DB_KEEP_DATABASE
Setting this variable will disable the core feature in this module:
A unique database will be created, but it will not get dropped/deleted.
=head2 DBIX_TEMP_DB_URL
This variable is set by L</create_database> and contains the complete
URL pointing to the temporary database.
Note that calling L</create_database> on different instances of
L<DBIx::TempDB> will overwrite C<DBIX_TEMP_DB_URL>.
=head1 METHODS
=head2 create_database
$tmpdb = $tmpdb->create_database;
This method will create a temp database for the current process. Calling this
method multiple times will simply do nothing. This method is normally
automatically called by L</new>.
The database name generate is defined by the L</template> parameter passed to
L</new>, but normalization will be done to make it work for the given database.
=head2 drop_databases
$tmpdb->drop_databases;
$tmpdb->drop_databases({tmpdb => "include"});
$tmpdb->drop_databases({tmpdb => "only"});
$tmpdb->drop_databases({name => "some_database_name"});
Used to drop either sibling databases (default), sibling databases and the
current database or a given database by name.
=head2 dsn
($dsn, $user, $pass, $attrs) = $tmpdb->dsn;
( run in 4.527 seconds using v1.01-cache-2.11-cpan-0bb4e1dffa6 )