Skip to main content

BenchError

Enum BenchError 

Source
pub enum BenchError {
    Runner(TimingError),
    UnknownFunction(String, Vec<String>),
    Execution(String),
    Io(Error),
    Serialization(Error),
    Config(String),
    Build(String),
}
Expand description

Error types for mobench-sdk operations.

This enum covers all error conditions that can occur during benchmark registration, execution, and mobile app building.

§Example

use mobench_sdk::{run_benchmark, BenchSpec, BenchError};

let spec = BenchSpec {
    name: "nonexistent".to_string(),
    iterations: 10,
    warmup: 1,
};

match run_benchmark(spec) {
    Ok(report) => println!("Success!"),
    Err(BenchError::UnknownFunction(name)) => {
        eprintln!("Benchmark '{}' not found", name);
    }
    Err(e) => eprintln!("Other error: {}", e),
}

Variants§

§

Runner(TimingError)

Error from the underlying benchmark runner.

This wraps errors from crate::timing::TimingError, such as zero iterations or execution failures.

§

UnknownFunction(String, Vec<String>)

The requested benchmark function was not found in the registry.

This occurs when calling run_benchmark with a function name that hasn’t been registered via #[benchmark].

The error includes a list of available benchmarks to help diagnose the issue.

§

Execution(String)

An error occurred during benchmark execution.

This is a catch-all for execution-time errors that don’t fit other categories.

§

Io(Error)

An I/O error occurred.

Common causes include missing files, permission issues, or disk space problems during build operations.

§

Serialization(Error)

JSON serialization or deserialization failed.

This can occur when reading/writing benchmark specifications or configuration files.

§

Config(String)

A configuration error occurred.

This indicates invalid or missing configuration, such as malformed TOML files or missing required fields.

§

Build(String)

A build error occurred.

This covers failures during mobile app building, including:

  • Missing build tools (cargo-ndk, xcodebuild, etc.)
  • Compilation errors
  • Code signing failures
  • Missing dependencies

Trait Implementations§

Source§

impl Debug for BenchError

Source§

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

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

impl Display for BenchError

Source§

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

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

impl Error for BenchError

Source§

fn source(&self) -> Option<&(dyn Error + 'static)>

Returns the lower-level source of this error, if any. Read more
1.0.0 · Source§

fn description(&self) -> &str

👎Deprecated since 1.42.0:

use the Display impl or to_string()

1.0.0 · Source§

fn cause(&self) -> Option<&dyn Error>

👎Deprecated since 1.33.0:

replaced by Error::source, which can support downcasting

Source§

fn provide<'a>(&'a self, request: &mut Request<'a>)

🔬This is a nightly-only experimental API. (error_generic_member_access)
Provides type-based access to context intended for error reports. Read more
Source§

impl From<BenchError> for BenchErrorFfi

Source§

fn from(err: BenchError) -> Self

Converts to this type from the input type.
Source§

impl From<BenchError> for BenchErrorVariant

Source§

fn from(err: BenchError) -> Self

Converts to this type from the input type.
Source§

impl From<Error> for BenchError

Source§

fn from(source: Error) -> Self

Converts to this type from the input type.
Source§

impl From<Error> for BenchError

Source§

fn from(source: Error) -> Self

Converts to this type from the input type.
Source§

impl From<TimingError> for BenchError

Source§

fn from(source: TimingError) -> Self

Converts to this type from the input type.

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, U> FromFfi<U> for T
where T: From<U>,

Source§

fn from_ffi(ffi: U) -> T

Convert from FFI representation to SDK type.
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, U> IntoFfi<U> for T
where U: From<T>,

Source§

fn into_ffi(self) -> U

Convert self into the FFI representation.
Source§

impl<T> ToString for T
where T: Display + ?Sized,

Source§

fn to_string(&self) -> String

Converts the given value to a String. Read more
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.