35 releases (10 breaking)

0.14.0-beta.1 Jun 19, 2023
0.11.5 Jan 7, 2025
0.11.4 Nov 12, 2024
0.9.0 Jul 30, 2024
0.1.0-beta.1 Jun 28, 2023

#22 in Testing

Download history 15395/week @ 2024-09-20 18385/week @ 2024-09-27 14247/week @ 2024-10-04 15701/week @ 2024-10-11 18624/week @ 2024-10-18 17218/week @ 2024-10-25 17700/week @ 2024-11-01 17283/week @ 2024-11-08 17586/week @ 2024-11-15 18483/week @ 2024-11-22 17231/week @ 2024-11-29 17976/week @ 2024-12-06 18227/week @ 2024-12-13 9161/week @ 2024-12-20 8985/week @ 2024-12-27 17058/week @ 2025-01-03

57,073 downloads per month
Used in 49 crates (46 directly)

MIT license

280KB
5.5K SLoC

testcontainers-modules

Continuous Integration Crates.io Docs.rs

Community maintained modules for testcontainers

Provides modules to use for testing components in accordance with testcontainers-rs. Every module is treated as a feature inside this crate.

Usage

  1. Depend on testcontainers-modules with necessary features (e.g postgres, minio and etc)
    • Enable blocking feature if you want to use modules within synchronous tests (feature-gate for SyncRunner)
  2. Then start using the modules inside your tests with either AsyncRunner or SyncRunner

Simple example of using postgres module with SyncRunner (blocking and postgres features enabled):

use testcontainers_modules::{postgres, testcontainers::runners::SyncRunner};

#[test]
fn test_with_postgres() {
    let container = postgres::Postgres::default().start().unwrap();
    let host_ip = container.get_host().unwrap();
    let host_port = container.get_host_port_ipv4(5432).unwrap();
}

Note: you don't need to explicitly depend on testcontainers as it's re-exported dependency of testcontainers-modules with aligned version between these crates. For example:

use testcontainers_modules::testcontainers::ImageExt;

You can also see examples for more details.

How to override module defaults (version, tag, ENV-variables)

Just use RunnableImage:

use testcontainers_modules::{
    redis::Redis,
    testcontainers::{ContainerRequest, ImageExt}
};


/// Create a Redis module with `6.2-alpine` tag and custom password
fn create_redis() -> ContainerRequest<Redis> {
    Redis::default()
        .with_tag("6.2-alpine")
        .with_env_var("REDIS_PASSWORD", "my_secret_password")
}

License

Dependencies

~23–40MB
~747K SLoC