Skip to main content

FuzzPlan

Struct FuzzPlan 

Source
pub struct FuzzPlan {
    pub iterations: u64,
    pub mode: GenMode,
    pub master_seed: u64,
    pub include: Vec<String>,
    pub exclude: Vec<String>,
    pub max_tools: Option<usize>,
    pub timeout: Duration,
    pub transport_name: String,
    pub detector: DestructiveDetector,
    pub severity: SeverityConfig,
    pub fuzz_corpus: Option<FuzzCorpus>,
    pub mutate_ratio: f64,
}
Expand description

A reproducible fuzz plan.

Fields§

§iterations: u64

Number of payloads generated per tool.

§mode: GenMode

Generation mode (Conform / Adversarial / Mixed).

§master_seed: u64

Master seed used to derive per-iteration seeds. The same seed reproduces the same sequence of payloads.

§include: Vec<String>

Glob patterns: empty = match every tool name.

§exclude: Vec<String>

Glob patterns excluded from the fuzz set. Always honored.

§max_tools: Option<usize>

Cap on the number of tools after filtering. None = unlimited.

§timeout: Duration

Timeout applied to each call_tool.

§transport_name: String

Transport label persisted in the ReproInfo. Plans don’t open the transport themselves, so we receive a stable name (stdio / http) from the caller.

§detector: DestructiveDetector

Compiled destructive-tool detector built from [destructive] + [allow_destructive] config.

§severity: SeverityConfig

[severity] overrides from wallfacer.toml. Applied to every produced finding before it lands on disk.

§fuzz_corpus: Option<FuzzCorpus>

Phase R — optional persistent fuzz corpus. When set, the loop pulls inputs that triggered findings or new response fingerprints from prior runs and mutates from them mutate_ratio fraction of the time. Pure schema-driven generation handles the remainder so the fuzzer keeps exploring beyond the corpus’s basin.

§mutate_ratio: f64

Phase R — fraction of iterations that mutate from the corpus instead of generating fresh schema-driven payloads. Default 0.9 matches AFL/libFuzzer convention. Ignored when Self::fuzz_corpus is None or the corpus is empty.

Implementations§

Source§

impl FuzzPlan

Source

pub async fn dry_run<C: McpExec + ?Sized>( &self, client: &C, ) -> Result<Vec<String>>

Returns the tool names that would be fuzzed, for --dry-run.

Source

pub async fn execute<C: McpExec + ?Sized>( self, client: &mut C, corpus: &Corpus, reporter: &mut dyn Reporter, ) -> Result<FuzzReport>

Drives the full fuzz loop, persisting findings to corpus and notifying reporter along the way.

Trait Implementations§

Source§

impl Debug for FuzzPlan

Source§

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

Formats the value using the given formatter. 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> 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