iai_callgrind_runner::runner::summary

Struct BenchmarkSummary

source
pub struct BenchmarkSummary {
Show 13 fields pub version: String, pub kind: BenchmarkKind, pub summary_output: Option<SummaryOutput>, pub project_root: PathBuf, pub package_dir: PathBuf, pub benchmark_file: PathBuf, pub benchmark_exe: PathBuf, pub function_name: String, pub module_path: String, pub id: Option<String>, pub details: Option<String>, pub callgrind_summary: Option<CallgrindSummary>, pub tool_summaries: Vec<ToolSummary>,
}
Available on crate feature runner only.
Expand description

The BenchmarkSummary containing all the information of a single benchmark run

This includes produced files, recorded callgrind events, performance regressions …

Fields§

§version: String

The version of this format. Only backwards incompatible changes cause an increase of the version

§kind: BenchmarkKind

Whether this summary describes a library or binary benchmark

§summary_output: Option<SummaryOutput>

The destination and kind of the summary file

§project_root: PathBuf

The project’s root directory

§package_dir: PathBuf

The directory of the package

§benchmark_file: PathBuf

The path to the benchmark file

§benchmark_exe: PathBuf

The path to the binary which is executed by valgrind. In case of a library benchmark this is the compiled benchmark file. In case of a binary benchmark this is the path to the command.

§function_name: String

The name of the function under test

§module_path: String

The rust path in the form bench_file::group::bench

§id: Option<String>

The user provided id of this benchmark

§details: Option<String>

More details describing this benchmark run

§callgrind_summary: Option<CallgrindSummary>

The summary of the callgrind run

§tool_summaries: Vec<ToolSummary>

The summary of other valgrind tool runs

Implementations§

source§

impl BenchmarkSummary

source

pub fn new( kind: BenchmarkKind, project_root: PathBuf, package_dir: PathBuf, benchmark_file: PathBuf, benchmark_exe: PathBuf, module_path: &ModulePath, function_name: &str, id: Option<String>, details: Option<String>, output: Option<SummaryOutput>, ) -> Self

Create a new BenchmarkSummary

Relative paths are made absolute with the project_root as base directory.

source

pub fn print_and_save(&self, output_format: &OutputFormatKind) -> Result<()>

source

pub fn check_regression( &self, is_regressed: &mut bool, fail_fast: bool, ) -> Result<()>

Check if this BenchmarkSummary has recorded any performance regressions

If the regressions are configured to be not fail_fast and there is a regressions, then the is_regressed variable is updated to true.

§Errors

If the regressions are configured to be fail_fast an error is returned

source

pub fn compare_and_print( &self, id: &str, other: &Self, output_format: &OutputFormat, ) -> Result<()>

Trait Implementations§

source§

impl Debug for BenchmarkSummary

source§

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

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

impl<'de> Deserialize<'de> for BenchmarkSummary

source§

fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
source§

impl JsonSchema for BenchmarkSummary

source§

fn schema_name() -> String

The name of the generated JSON Schema. Read more
source§

fn schema_id() -> Cow<'static, str>

Returns a string that uniquely identifies the schema produced by this type. Read more
source§

fn json_schema(gen: &mut SchemaGenerator) -> Schema

Generates a JSON Schema for this type. Read more
source§

fn is_referenceable() -> bool

Whether JSON Schemas generated for this type should be re-used where possible using the $ref keyword. Read more
source§

impl PartialEq for BenchmarkSummary

source§

fn eq(&self, other: &BenchmarkSummary) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl Serialize for BenchmarkSummary

source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more
source§

impl StructuralPartialEq for BenchmarkSummary

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> 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, 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> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,