Skip to main content

ScriptedLlm

Struct ScriptedLlm 

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

A deterministic LLM double with pre-scripted responses.

ScriptedLlm implements the real Llm trait and exercises the full runtime pipeline. Only the provider API call is replaced — everything else (session loop, checkpoints, parking, event mapping) runs exactly as it would with a real provider.

This is explicitly NOT a mock. It:

  • Implements the full Llm trait contract
  • Returns complete LlmResponse objects with proper Content and Part types
  • Supports tool calls (function calls) in responses
  • Advances through turns deterministically (FIFO order)
  • Is thread-safe (Send + Sync via AtomicUsize)

§Panics

If more turns are requested than were scripted, the LLM returns an empty response with turn_complete = true rather than panicking.

Implementations§

Source§

impl ScriptedLlm

Source

pub fn new(name: impl Into<String>, turns: Vec<ScriptedTurn>) -> Self

Create a new ScriptedLlm with the given name and pre-scripted turns.

Turns are consumed in FIFO order — each call to generate_content advances to the next turn.

Source

pub fn turns_consumed(&self) -> usize

Returns the number of turns that have been consumed so far.

Source

pub fn total_turns(&self) -> usize

Returns the total number of scripted turns.

Trait Implementations§

Source§

impl Debug for ScriptedLlm

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Llm for ScriptedLlm

Source§

fn name(&self) -> &str

Returns the model identifier (e.g., “gemini-2.5-flash”).
Source§

fn generate_content<'life0, 'async_trait>( &'life0 self, _request: LlmRequest, _stream: bool, ) -> Pin<Box<dyn Future<Output = AdkResult<LlmResponseStream>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Generates content from the given request, optionally streaming.
Source§

fn schema_adapter(&self) -> &dyn SchemaAdapter

Returns the schema adapter for this provider. Read more
Source§

fn uses_interactions_api(&self) -> bool

Returns true if this model is configured to use a server-managed environment (e.g., Gemini Interactions API) where the provider owns the tool-calling loop and filesystem. 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<ST, DT> CastableFrom<ST, Initialized, Initialized> for DT
where ST: ?Sized, DT: ?Sized,

Source§

impl<ST, DT> CastableFrom<ST, Uninit, Uninit> for DT
where ST: ?Sized, DT: ?Sized,

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> Read<Exclusive, BecauseExclusive> for T
where T: ?Sized,

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<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