Skip to main content

BenchmarkChannel

Struct BenchmarkChannel 

Source
pub struct BenchmarkChannel { /* private fields */ }
Expand description

Headless channel that feeds pre-loaded prompts and captures agent responses.

Used by the bench runner to drive the agent loop without a real terminal or network connection. recv drains the prompt queue; send and flush_chunks accumulate responses into an internal list. Tool outputs are captured separately via tool_outputs().

§Usage

use zeph_bench::BenchmarkChannel;

let prompts = vec!["What year did WWII end?".into()];
let channel = BenchmarkChannel::new(prompts);
assert_eq!(channel.total(), 1);

After the agent loop completes, call into_responses to consume the channel and retrieve all captured responses:

let channel = BenchmarkChannel::new(vec!["question".into()]);
// ... run agent loop ...
let responses = channel.into_responses();

Implementations§

Source§

impl BenchmarkChannel

Source

pub fn new(prompts: Vec<String>) -> Self

Create a new channel pre-loaded with prompts.

Prompts are fed to the agent one at a time in order via recv. The channel returns Ok(None) once all prompts have been drained.

§Examples
use zeph_bench::BenchmarkChannel;

let ch = BenchmarkChannel::new(vec!["hello".into(), "world".into()]);
assert_eq!(ch.total(), 2);
Source

pub fn from_turns(turns: Vec<Turn>) -> Self

Create a channel from a multi-turn scenario history.

User turns are fed to the agent in order via recv. Assistant turns are pre-seeded into responses so that evaluators and Phase 2 scoring have access to the captured prior context.

§Note

If turns contains no crate::scenario::Role::User turns, total returns 0 and the channel cannot serve as a prompt source. The bench runner rejects this with BenchError::InvalidFormat — callers must ensure at least one user turn is present.

§Examples
use zeph_bench::BenchmarkChannel;
use zeph_bench::scenario::{Role, Turn};

let turns = vec![
    Turn { role: Role::User, content: "Hello".into() },
    Turn { role: Role::Assistant, content: "Hi there".into() },
    Turn { role: Role::User, content: "What year?".into() },
];
let ch = BenchmarkChannel::from_turns(turns);
assert_eq!(ch.total(), 2); // two user turns
assert_eq!(ch.responses().len(), 1); // one seeded assistant turn
Source

pub fn total(&self) -> usize

Total number of prompts this channel was initialised with.

§Examples
use zeph_bench::BenchmarkChannel;

let ch = BenchmarkChannel::new(vec!["a".into(), "b".into(), "c".into()]);
assert_eq!(ch.total(), 3);
Source

pub fn into_responses(self) -> Vec<CapturedResponse>

Consume the channel and return all CapturedResponses collected so far.

Call this after the agent loop exits to retrieve every response in prompt order.

§Examples
use zeph_bench::BenchmarkChannel;

let ch = BenchmarkChannel::new(vec!["question".into()]);
// ... run agent ...
let responses = ch.into_responses();
Source

pub fn responses(&self) -> &[CapturedResponse]

Borrow the captured responses without consuming the channel.

§Examples
use zeph_bench::BenchmarkChannel;

let ch = BenchmarkChannel::new(vec![]);
assert!(ch.responses().is_empty());
Source

pub fn tool_outputs(&self) -> &[ToolOutputEvent]

Borrow the tool output events captured during the agent run.

Events are appended by send_tool_output and are available for Phase 2 evaluation (#4234) after the agent loop exits.

§Examples
use zeph_bench::BenchmarkChannel;

let ch = BenchmarkChannel::new(vec![]);
assert!(ch.tool_outputs().is_empty());

Trait Implementations§

Source§

impl Channel for BenchmarkChannel

Source§

async fn recv(&mut self) -> Result<Option<ChannelMessage>, ChannelError>

Receive the next message. Returns None on EOF or shutdown. Read more
Source§

fn supports_exit(&self) -> bool

Whether /exit and /quit commands should terminate the agent loop. Read more
Source§

async fn send(&mut self, text: &str) -> Result<(), ChannelError>

Send a text response. Read more
Source§

async fn send_chunk(&mut self, chunk: &str) -> Result<(), ChannelError>

Send a partial chunk of streaming response. Read more
Source§

async fn flush_chunks(&mut self) -> Result<(), ChannelError>

Flush any buffered chunks. Read more
Source§

async fn send_usage( &mut self, input_tokens: u64, output_tokens: u64, context_window: u64, ) -> Result<(), ChannelError>

Send token usage after an LLM call. No-op by default. Read more
Source§

async fn send_tool_output( &mut self, event: ToolOutputEvent, ) -> Result<(), ChannelError>

Send a complete tool output with optional diff and filter stats atomically. Read more
Source§

fn try_recv(&mut self) -> Option<ChannelMessage>

Non-blocking receive. Returns None if no message is immediately available.
Source§

fn send_typing( &mut self, ) -> impl Future<Output = Result<(), ChannelError>> + Send

Send a typing indicator. No-op by default. Read more
Source§

fn send_status( &mut self, _text: &str, ) -> impl Future<Output = Result<(), ChannelError>> + Send

Send a status label (shown as spinner text in TUI). No-op by default. Read more
Source§

fn send_thinking_chunk( &mut self, _chunk: &str, ) -> impl Future<Output = Result<(), ChannelError>> + Send

Send a thinking/reasoning token chunk. No-op by default. Read more
Source§

fn send_queue_count( &mut self, _count: usize, ) -> impl Future<Output = Result<(), ChannelError>> + Send

Notify channel of queued message count. No-op by default. Read more
Source§

fn send_context_estimate( &mut self, _tokens: usize, ) -> impl Future<Output = Result<(), ChannelError>> + Send

Send the projected context token count to the channel after context assembly. Read more
Source§

fn send_diff( &mut self, _diff: DiffData, _tool_call_id: &str, ) -> impl Future<Output = Result<(), ChannelError>> + Send

Send diff data for a tool result. No-op by default (TUI overrides). Read more
Source§

fn send_tool_start( &mut self, _event: ToolStartEvent, ) -> impl Future<Output = Result<(), ChannelError>> + Send

Announce that a tool call is starting. Read more
Source§

fn confirm( &mut self, _prompt: &str, ) -> impl Future<Output = Result<bool, ChannelError>> + Send

Request user confirmation for a destructive action. Returns true if confirmed. Default: auto-confirm (for headless/test scenarios). Read more
Source§

fn elicit( &mut self, _request: ElicitationRequest, ) -> impl Future<Output = Result<ElicitationResponse, ChannelError>> + Send

Request structured input from the user for an MCP elicitation. Read more
Source§

fn send_stop_hint( &mut self, _hint: StopHint, ) -> impl Future<Output = Result<(), ChannelError>> + Send

Signal the non-default stop reason to the consumer before flushing. Read more
Source§

fn notify_foreground_subagent_started( &mut self, _id: &str, _name: &str, ) -> impl Future<Output = Result<(), ChannelError>> + Send

Notify channel that a foreground subagent has started. No-op by default. Read more
Source§

fn notify_foreground_subagent_completed( &mut self, _id: &str, _name: &str, _success: bool, ) -> impl Future<Output = Result<(), ChannelError>> + Send

Notify channel that a foreground subagent has completed. No-op by default. Read more

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

impl<T> IntoRequest<T> for T

Source§

fn into_request(self) -> Request<T>

Wrap the input message T in a tonic::Request
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T> PolicyExt for T
where T: ?Sized,

Source§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow only if self and other return Action::Follow. Read more
Source§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow if either self or other returns Action::Follow. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more