Skip to content

Postgres Module

Testcontainers module for PostgresSQL

Usage example

You can start a PostgreSQL container instance from any Java application by using:

PostgreSQLContainer postgres = new PostgreSQLContainer("postgres:9.6.12")

See Database containers for documentation and usage that is common to all relational database container types.

Testcontainers JDBC URL

  • PostgreSQL: jdbc:tc:postgresql:9.6.8:///databasename
  • PostGIS: jdbc:tc:postgis:9.6-2.5:///databasename
  • TimescaleDB: jdbc:tc:timescaledb:2.1.0-pg13:///databasename
  • PGvector: jdbc:tc:pgvector:pg16:///databasename

See JDBC for documentation.

Compatible images

PostgreSQLContainer can also be used with the following images:

PostgreSQLContainer pgvector = new PostgreSQLContainer("pgvector/pgvector:pg16")
PostgreSQLContainer postgis = new PostgreSQLContainer(
    DockerImageName.parse("postgis/postgis:16-3.4-alpine").asCompatibleSubstituteFor("postgres")
)
PostgreSQLContainer timescaledb = new PostgreSQLContainer(
    DockerImageName.parse("timescale/timescaledb:2.14.2-pg16").asCompatibleSubstituteFor("postgres")
)

Adding this module to your project dependencies

Add the following dependency to your pom.xml/build.gradle file:

testImplementation "org.testcontainers:testcontainers-postgresql:2.0.0"
<dependency>
    <groupId>org.testcontainers</groupId>
    <artifactId>testcontainers-postgresql</artifactId>
    <version>2.0.0</version>
    <scope>test</scope>
</dependency>

Hint

Adding this Testcontainers library JAR will not automatically add a database driver JAR to your project. You should ensure that your project also has a suitable database driver as a dependency.