summaryrefslogtreecommitdiff
path: root/src/event/handlers/stream/test/channel.rs
diff options
context:
space:
mode:
authorOwen Jacobson <owen@grimoire.ca>2025-06-30 22:00:57 -0400
committerOwen Jacobson <owen@grimoire.ca>2025-07-03 22:43:42 -0400
commita15e3d580124f561864c6a39f1e035eb1b3aab13 (patch)
treeef80f725e7b02547a23b5c29a482fbf3fd188c0d /src/event/handlers/stream/test/channel.rs
parent5af4aea1e2f143499529b70f9cf191c6994265c6 (diff)
Rename "channel" to "conversation" within the server.
I've split this from the schema and API changes because, frankly, it's huge. Annoyingly so. There are no semantic changes in this, it's all symbol changes, but there are a _lot_ of them because the term "channel" leaks all over everything in a service whose primary role is managing messages sent to channels (now, conversations). I found a buggy test while working on this! It's not fixed in this commit, because it felt mean to hide a real change in the middle of this much chaff.
Diffstat (limited to 'src/event/handlers/stream/test/channel.rs')
-rw-r--r--src/event/handlers/stream/test/channel.rs273
1 files changed, 0 insertions, 273 deletions
diff --git a/src/event/handlers/stream/test/channel.rs b/src/event/handlers/stream/test/channel.rs
deleted file mode 100644
index 2b87ce2..0000000
--- a/src/event/handlers/stream/test/channel.rs
+++ /dev/null
@@ -1,273 +0,0 @@
-use axum::extract::State;
-use axum_extra::extract::Query;
-use futures::{future, stream::StreamExt as _};
-
-use crate::test::fixtures::{self, future::Expect as _};
-
-#[tokio::test]
-async fn creating() {
- // Set up the environment
-
- let app = fixtures::scratch_app().await;
- let resume_point = fixtures::boot::resume_point(&app).await;
-
- // Subscribe
-
- let subscriber = fixtures::identity::create(&app, &fixtures::now()).await;
- let super::Response(events) = super::handler(
- State(app.clone()),
- subscriber,
- None,
- Query(super::QueryParams { resume_point }),
- )
- .await
- .expect("subscribe never fails");
-
- // Create a channel
-
- let name = fixtures::channel::propose();
- let channel = app
- .channels()
- .create(&name, &fixtures::now())
- .await
- .expect("creating a channel succeeds");
-
- // Verify channel created event
-
- events
- .filter_map(fixtures::event::stream::channel)
- .filter_map(fixtures::event::stream::channel::created)
- .filter(|event| future::ready(event.channel == channel))
- .next()
- .expect_some("channel created event is delivered")
- .await;
-}
-
-#[tokio::test]
-async fn previously_created() {
- // Set up the environment
-
- let app = fixtures::scratch_app().await;
- let resume_point = fixtures::boot::resume_point(&app).await;
-
- // Create a channel
-
- let name = fixtures::channel::propose();
- let channel = app
- .channels()
- .create(&name, &fixtures::now())
- .await
- .expect("creating a channel succeeds");
-
- // Subscribe
-
- let subscriber = fixtures::identity::create(&app, &fixtures::now()).await;
- let super::Response(events) = super::handler(
- State(app.clone()),
- subscriber,
- None,
- Query(super::QueryParams { resume_point }),
- )
- .await
- .expect("subscribe never fails");
-
- // Verify channel created event
-
- let _ = events
- .filter_map(fixtures::event::stream::channel)
- .filter_map(fixtures::event::stream::channel::created)
- .filter(|event| future::ready(event.channel == channel))
- .next()
- .expect_some("channel created event is delivered")
- .await;
-}
-
-#[tokio::test]
-async fn expiring() {
- // Set up the environment
-
- let app = fixtures::scratch_app().await;
- let channel = fixtures::channel::create(&app, &fixtures::ancient()).await;
- let resume_point = fixtures::boot::resume_point(&app).await;
-
- // Subscribe
-
- let subscriber = fixtures::identity::create(&app, &fixtures::now()).await;
- let super::Response(events) = super::handler(
- State(app.clone()),
- subscriber,
- None,
- Query(super::QueryParams { resume_point }),
- )
- .await
- .expect("subscribe never fails");
-
- // Expire channels
-
- app.channels()
- .expire(&fixtures::now())
- .await
- .expect("expiring channels always succeeds");
-
- // Check for expiry event
- let _ = events
- .filter_map(fixtures::event::stream::channel)
- .filter_map(fixtures::event::stream::channel::deleted)
- .filter(|event| future::ready(event.id == channel.id))
- .next()
- .expect_some("a deleted channel event will be delivered")
- .await;
-}
-
-#[tokio::test]
-async fn previously_expired() {
- // Set up the environment
-
- let app = fixtures::scratch_app().await;
- let channel = fixtures::channel::create(&app, &fixtures::ancient()).await;
- let resume_point = fixtures::boot::resume_point(&app).await;
-
- // Expire channels
-
- app.channels()
- .expire(&fixtures::now())
- .await
- .expect("expiring channels always succeeds");
-
- // Subscribe
-
- let subscriber = fixtures::identity::create(&app, &fixtures::now()).await;
- let super::Response(events) = super::handler(
- State(app.clone()),
- subscriber,
- None,
- Query(super::QueryParams { resume_point }),
- )
- .await
- .expect("subscribe never fails");
-
- // Check for expiry event
- let _ = events
- .filter_map(fixtures::event::stream::channel)
- .filter_map(fixtures::event::stream::channel::deleted)
- .filter(|event| future::ready(event.id == channel.id))
- .next()
- .expect_some("a deleted channel event will be delivered")
- .await;
-}
-
-#[tokio::test]
-async fn deleting() {
- // Set up the environment
-
- let app = fixtures::scratch_app().await;
- let channel = fixtures::channel::create(&app, &fixtures::now()).await;
- let resume_point = fixtures::boot::resume_point(&app).await;
-
- // Subscribe
-
- let subscriber = fixtures::identity::create(&app, &fixtures::now()).await;
- let super::Response(events) = super::handler(
- State(app.clone()),
- subscriber,
- None,
- Query(super::QueryParams { resume_point }),
- )
- .await
- .expect("subscribe never fails");
-
- // Delete the channel
-
- app.channels()
- .delete(&channel.id, &fixtures::now())
- .await
- .expect("deleting a valid channel succeeds");
-
- // Check for delete event
- let _ = events
- .filter_map(fixtures::event::stream::channel)
- .filter_map(fixtures::event::stream::channel::deleted)
- .filter(|event| future::ready(event.id == channel.id))
- .next()
- .expect_some("a deleted channel event will be delivered")
- .await;
-}
-
-#[tokio::test]
-async fn previously_deleted() {
- // Set up the environment
-
- let app = fixtures::scratch_app().await;
- let channel = fixtures::channel::create(&app, &fixtures::now()).await;
- let resume_point = fixtures::boot::resume_point(&app).await;
-
- // Delete the channel
-
- app.channels()
- .delete(&channel.id, &fixtures::now())
- .await
- .expect("deleting a valid channel succeeds");
-
- // Subscribe
-
- let subscriber = fixtures::identity::create(&app, &fixtures::now()).await;
- let super::Response(events) = super::handler(
- State(app.clone()),
- subscriber,
- None,
- Query(super::QueryParams { resume_point }),
- )
- .await
- .expect("subscribe never fails");
-
- // Check for expiry event
- let _ = events
- .filter_map(fixtures::event::stream::channel)
- .filter_map(fixtures::event::stream::channel::deleted)
- .filter(|event| future::ready(event.id == channel.id))
- .next()
- .expect_some("a deleted channel event will be delivered")
- .await;
-}
-
-#[tokio::test]
-async fn previously_purged() {
- // Set up the environment
-
- let app = fixtures::scratch_app().await;
- let channel = fixtures::channel::create(&app, &fixtures::ancient()).await;
- let resume_point = fixtures::boot::resume_point(&app).await;
-
- // Delete and purge the channel
-
- app.channels()
- .delete(&channel.id, &fixtures::ancient())
- .await
- .expect("deleting a valid channel succeeds");
-
- app.channels()
- .purge(&fixtures::now())
- .await
- .expect("purging channels always succeeds");
-
- // Subscribe
-
- let subscriber = fixtures::identity::create(&app, &fixtures::now()).await;
- let super::Response(events) = super::handler(
- State(app.clone()),
- subscriber,
- None,
- Query(super::QueryParams { resume_point }),
- )
- .await
- .expect("subscribe never fails");
-
- // Check for expiry event
- events
- .filter_map(fixtures::event::stream::channel)
- .filter_map(fixtures::event::stream::channel::deleted)
- .filter(|event| future::ready(event.id == channel.id))
- .next()
- .expect_wait("deleted channel events not delivered")
- .await;
-}