Skip to content

Commit

Permalink
integration_tests_sv2 docs cleanup..
Browse files Browse the repository at this point in the history
- improves wording on `Sniffer` docs, as it implied that messages from upstream are always a response, which is not true
- adds some brief docs to `InterceptMessage` struct
- removes links to private items (which generate warnings on `cargo doc`)

Co-authored-by: Gabriele Vernetti <[email protected]>
  • Loading branch information
plebhash and GitGab19 committed Jan 21, 2025
1 parent 7a39869 commit ed2930c
Show file tree
Hide file tree
Showing 2 changed files with 19 additions and 12 deletions.
29 changes: 18 additions & 11 deletions roles/tests-integration/lib/sniffer.rs
Original file line number Diff line number Diff line change
Expand Up @@ -35,21 +35,22 @@ enum SnifferError {

/// Allows to intercept messages sent between two roles.
///
/// Can be useful for testing purposes, as it allows to assert that the roles have sent specific
/// messages in a specific order and to inspect the messages details.
///
/// The downstream (or client) role connects to the [`Sniffer`] `listening_address` and the
/// [`Sniffer`] connects to the `upstream` server. This way, the Sniffer can intercept messages sent
/// between the downstream and upstream roles. The downstream will send its messages to the
/// [`Sniffer`] which will save those in the `messages_from_downstream` aggregator and forward them
/// to the upstream role. When a response is received it is saved in `messages_from_upstream` and
/// forwarded to the downstream role. Both `messages_from_downstream` and `messages_from_upstream`
/// can be accessed as FIFO queues.
/// between the downstream and upstream roles.
///
/// In order to alter the messages sent between the roles, the [`Sniffer::intercept_messages`]
/// field can be used. It will look for the [`InterceptMessage::expected_message_type`] in the
/// specified [`InterceptMessage::direction`] and replace it with
/// [`InterceptMessage::replacement_message`].
/// Messages received from downstream are stored in the `messages_from_downstream` aggregator and
/// forwarded to the upstream role. Alternatively, messages received from upstream are stored in
/// the `messages_from_upstream` and forwarded to the downstream role. Both
/// `messages_from_downstream` and `messages_from_upstream` aggregators can be accessed as FIFO
/// queues via [`Sniffer::next_message_from_downstream`] and
/// [`Sniffer::next_message_from_upstream`], respectively.
///
/// Can be useful for testing purposes, as it allows to assert that the roles have sent specific
/// messages in a specific order and to inspect the messages details.
/// In order to replace the messages sent between the roles, a set of [`InterceptMessage`] can be
/// used in [`Sniffer::new`].
#[derive(Debug, Clone)]
pub struct Sniffer {
identifier: String,
Expand All @@ -61,6 +62,7 @@ pub struct Sniffer {
intercept_messages: Vec<InterceptMessage>,
}

/// Allows [`Sniffer`] to replace some intercepted message before forwarding it.
#[derive(Debug, Clone)]
pub struct InterceptMessage {
direction: MessageDirection,
Expand All @@ -70,6 +72,11 @@ pub struct InterceptMessage {
}

impl InterceptMessage {
/// Constructor of `InterceptMessage`
/// - `direction`: direction of message to be intercepted and replaced
/// - `expected_message_type`: type of message to be intercepted and replaced
/// - `replacement_message`: message to replace the intercepted one
/// - `replacement_message_type`: type of message to replace the intercepted one
pub fn new(
direction: MessageDirection,
expected_message_type: MsgType,
Expand Down
2 changes: 1 addition & 1 deletion roles/tests-integration/tests/sniffer_integration.rs
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ use roles_logic_sv2::{
use sniffer::{InterceptMessage, MessageDirection};
use std::convert::TryInto;

// this test aims to assert that Sniffer is able to intercept and replace some message
// This test aims to assert that Sniffer is able to intercept and replace some messages.
// sniffer_a replaces a SetupConnectionSuccess from TP with a SetupConnectionError directed at Pool
// sniffer_b asserts that Pool is about to receive a SetupConnectionError
// TP -> sniffer_a -> sniffer_b -> Pool
Expand Down

0 comments on commit ed2930c

Please sign in to comment.