NAME
Test::PostgreSQL::Docker - A Postgresql mock server for testing perl programs
SYNOPSIS
use
Test::More;
# 1. create a instance of Test::PostgreSQL::Docker with postgres:12-alpine image
my
$server
= Test::PostgreSQL::Docker->new(
tag
=>
'12-alpine'
);
# 2. create/run a container
$server
->run();
# 3. puke initialization data into postgresql on a container
$server
->run_psql_scripts(
"/path/to/fixture.sql"
);
# 4. get a Database Handler(a DBI::db object) from mock server object
my
$dbh
=
$server
->dbh();
# (or call steps of 2 to 4 as method-chain)
my
$dbh
=
$server
->run->run_psql_scripts(
"/path/to/fixture.sql"
)->dbh;
# 5. query to database
my
$sth
=
$dbh
->prepare(
"SELECT * FROM Users WHERE id=?"
);
$sth
->execute(1);
# 6. put your own test code below
my
$row
$sth
->fetchrow_hashref();
is
$row
->{name},
"ytnobody"
;
done_testing;
DESCRIPTION
Test::PostgreSQL::Docker run the postgres container on the Docker, for testing your perl programs.
**NOTE** Maybe this module doesn't work on the Windows, because we don't any test on Windows machine.
METHODS
new
$server
= Test::PostgreSQL::Docker->new(
%opt
)
- docker (str)
-
The path to
docker
. Default is/usr/bin/docker
. - pgname (str)
-
A distribution name. Default is
postgres
. - tag (str)
-
A tag of the PostgreSQL. Default is
latest
. - oid (str)
-
An uniqe id. Default is the object memory addres.
- dbowner (str)
-
Default is
postgres
. - password (str)
-
Default is
postgres
. - dbname (str)
-
Default is
test
. - print_docker_error (bool)
-
Show docker error. Default is
true value
.
run
$server
=
$server
->run(
%opt
)
1. Check image with docker pull
.
2. docker run
3. connect database
- skip_pull (bool)
-
Skip image check. Default is
true
. - skip_connect (bool)
-
Skip connect database. Default is
false
.
oid
$oid
=
$server
->oid()
Return an unique id.
container_name
$container_name
=
$server
->container_name()
Return the docker container name sprintf('%s-%s-%s', $pgname, $tag, $oid)
.
image_name
$image_name
=
$server
->image_name()
Return the docker image name.
dsn
$dsn
=
$server
->dsn(
%opt
)
port
$port
=
$server
->port()
Return a PostgreSQL server port.
dbh
$dbh
=
$server
->dbh()
psql_args
$psql_args
=
$server
->psql_args()
$psql_args
=
$server
->psql_args(
$args
)
Arguments to psql
in run_psql
and run_psql_scripts
. Default is sprintf('-h %s -p %s -U %s -d %s', $self-
{host}, 5432, $self->{dbowner}, $self->{dbname})>.
run_psql
$server
=
$server
->run_psql(
@args
)
$server
->run_psql(
'-c'
,
q|INSERT INTO foo (bar) VALUES ('baz')|
);
run_psql_scripts
$server
=
$server
->run_psql_scripts(
$path
)
docker_is_running
$server
=
$server
->docker_is_running()
Return true if docker container is running.
docker_daemon_is_accessible
$server
=
$server
->docker_daemon_is_accessible()
Return true if docker daemon is accessible.
REQUIREMENT
LICENSE
Copyright (C) Satoshi Azuma.
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.
AUTHOR
Satoshi Azuma <ytnobody@gmail.com>