-
-
Notifications
You must be signed in to change notification settings - Fork 11
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Testcontainer based integration tests (#1244)
* implemented the basic infrastructure for integration-testing via testcontainers * made sure that `setup_logging` can accept multiple initialisations
- Loading branch information
1 parent
16a6eca
commit 21fc5a2
Showing
8 changed files
with
473 additions
and
44 deletions.
There are no files selected for viewing
Large diffs are not rendered by default.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
1 change: 0 additions & 1 deletion
1
server/main-api/migrations/20240505224430_fix-calendar-id-not-extracted.up.sql
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -3,3 +3,5 @@ pub mod database; | |
|
||
#[cfg(not(feature = "skip_ms_setup"))] | ||
pub mod meilisearch; | ||
#[cfg(test)] | ||
pub mod tests; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,89 @@ | ||
use meilisearch_sdk::client::Client; | ||
use sqlx::postgres::PgPoolOptions; | ||
use sqlx::{Pool, Postgres}; | ||
use testcontainers::core::{ContainerPort, WaitFor}; | ||
use testcontainers::{ContainerAsync, GenericImage, ImageExt}; | ||
use testcontainers_modules::{postgres, testcontainers::runners::AsyncRunner}; | ||
|
||
#[cfg(not(feature = "skip_db_setup"))] | ||
pub struct PostgresTestContainer { | ||
_container: ContainerAsync<postgres::Postgres>, | ||
pub pool: Pool<Postgres>, | ||
} | ||
|
||
#[cfg(not(feature = "skip_db_setup"))] | ||
impl PostgresTestContainer { | ||
/// Create a postgres instance for testing against | ||
pub async fn new() -> Self { | ||
let container = postgres::Postgres::default() | ||
.with_tag("16") | ||
.start() | ||
.await | ||
.unwrap(); | ||
let connection_string = format!( | ||
"postgres://postgres:postgres@{host}:{port}/postgres", | ||
host = container.get_host().await.unwrap(), | ||
port = container.get_host_port_ipv4(5432).await.unwrap(), | ||
); | ||
let pool = PgPoolOptions::new() | ||
.connect(&connection_string) | ||
.await | ||
.unwrap(); | ||
crate::setup::database::setup(&pool).await.unwrap(); | ||
Self { | ||
_container: container, | ||
pool, | ||
} | ||
} | ||
} | ||
|
||
#[cfg(not(feature = "skip_ms_setup"))] | ||
pub struct MeiliSearchTestContainer { | ||
_container: ContainerAsync<GenericImage>, | ||
pub client: Client, | ||
} | ||
|
||
#[cfg(not(feature = "skip_ms_setup"))] | ||
impl MeiliSearchTestContainer { | ||
/// Create a meilisearch instance for testing against | ||
pub async fn new() -> Self { | ||
let container = GenericImage::new("getmeili/meilisearch", "v1.8.0") | ||
.with_exposed_port(ContainerPort::Tcp(7700)) | ||
.with_wait_for(WaitFor::message_on_stderr( | ||
"Actix runtime found; starting in Actix runtime", | ||
)) | ||
.start() | ||
.await | ||
.unwrap(); | ||
let meili_url = format!( | ||
"http://{host}:{port}", | ||
host = container.get_host().await.unwrap(), | ||
port = container.get_host_port_ipv4(7700).await.unwrap(), | ||
); | ||
|
||
let client = Client::new(meili_url.clone(), None::<String>).unwrap(); | ||
super::meilisearch::setup(&client).await.unwrap(); | ||
Self { | ||
_container: container, | ||
client, | ||
} | ||
} | ||
} | ||
|
||
#[tokio::test] | ||
#[cfg(not(feature = "skip_db_setup"))] | ||
async fn test_db_setup() { | ||
crate::setup_logging(); | ||
let pg = PostgresTestContainer::new().await; | ||
crate::setup::database::load_data(&pg.pool).await.unwrap(); | ||
} | ||
|
||
#[tokio::test] | ||
#[cfg(not(feature = "skip_ms_setup"))] | ||
async fn test_meilisearch_setup() { | ||
crate::setup_logging(); | ||
let ms = MeiliSearchTestContainer::new().await; | ||
crate::setup::meilisearch::load_data(&ms.client) | ||
.await | ||
.unwrap(); | ||
} |