This library provides Java wrappers to run pg_dump
and pg_restore
on platforms that do not have this binary installed.
We build on top of Testcontainers to spin-up a temporary Docker container that executes the command.
Add the following Maven dependency to your project:
<dependency>
<groupId>de.cronn</groupId>
<artifactId>postgres-snapshot-util</artifactId>
<version>1.4</version>
</dependency>
String jdbcUrl = "jdbc:postgresql://localhost/my-db";
String schemaDump = PostgresDump.dumpToString(jdbcUrl, "user", "password",
PostgresDumpOption.NO_COMMENTS,
PostgresDumpOption.SCHEMA_ONLY);
Path dumpFile = Path.of("/path/to/dump.tar");
String jdbcUrl = "jdbc:postgresql://localhost/my-db";
PostgresDump.dumpToFile(dumpFile, jdbcUrl, "user", "pass", PostgresDumpFormat.TAR);
PostgresRestore.restoreFromFile(dumpFile, jdbcUrl, "user", "pass",
PostgresRestoreOption.CLEAN,
PostgresRestoreOption.EXIT_ON_ERROR,
PostgresRestoreOption.SINGLE_TRANSACTION);
PostgresDump
and PostgresRestore
implement a mechanism to connect to a PostgreSQL database that is running in a Docker container by using the network alias.
This allows for seamless interaction without the need to expose ports to the host machine or rewriting the JDBC URL.
Example:
Consider the following simple docker-compose.yml
file:
services:
postgres-db:
image: postgres:17
environment:
POSTGRES_USER: user
POSTGRES_PASSWORD: password
POSTGRES_DB: my-db
In this setup the PostgreSQL service is named postgres-db
.
PostgresDump
and PostgresRestore
can connect to the database by using the Docker network alias postgres-db
:
String jdbcUrl = "jdbc:postgresql://postgres-db/my-db";
String schemaDump = PostgresDump.dumpToString(jdbcUrl, "user", "password");
PostgresDump
was designed to be used in a JUnit (regression) tests to dump and compare the actual database schema
of an application in cases where the schema is managed by a library/framework such as Liquibase.
We recommend to use our validation-file-assertions library to write such a test.
Full example:
@SpringBootTest
@Testcontainers
class SchemaTest implements JUnit5ValidationFileAssertions {
@Container
@ServiceConnection
static PostgreSQLContainer<?> postgres = new PostgreSQLContainer<>("postgres:17.2");
@Test
void schemaExport() {
String schema = PostgresDump.dumpToString(postgres.getJdbcUrl(),
postgres.getUsername(),
postgres.getPassword(),
PostgresDumpOption.SCHEMA_ONLY);
assertWithFile(schema);
}
}
- Java 17+
- Docker