Struct ArchiveReader

Source
pub struct ArchiveReader<T> { /* private fields */ }
Expand description

Utility for reading inspect data of a running component using the injected Archive Reader service.

Implementations§

Source§

impl<T: DiagnosticsDataType> ArchiveReader<T>

Source

pub fn with_archive(&mut self, archive: ArchiveAccessorProxy) -> &mut Self

Initializes the ArchiveReader with a custom connection to an ArchiveAccessor. By default, the connection will be initialized by connecting to fuchsia.diagnostics.ArchiveAccessor

Source

pub fn with_minimum_schema_count( &mut self, minimum_schema_count: usize, ) -> &mut Self

Sets the minimum number of schemas expected in a result in order for the result to be considered a success.

Source

pub fn retry(&mut self, config: RetryConfig) -> &mut Self

Sets a custom retry configuration. By default we always retry.

Source

pub fn with_timeout(&mut self, duration: MonotonicDuration) -> &mut Self

Sets the maximum time to wait for a response from the Archive. Do not use in tests unless timeout is the expected behavior.

Source

pub fn select_all_for_component( &mut self, component: impl ToComponentSelectorArguments, ) -> &mut Self

Filters logs for a specific component or component selector. If string input, the string may be either a component selector string or a moniker, or a ComponentSelector may be passed directly.

Source§

impl ArchiveReader<Logs>

Source

pub fn logs() -> Self

Creates an ArchiveReader for reading logs

Source

pub async fn snapshot(&self) -> Result<Vec<Data<Logs>>, Error>

Connects to the ArchiveAccessor and returns data matching provided selectors.

Source

pub fn snapshot_then_subscribe(&self) -> Result<Subscription, Error>

Connects to the ArchiveAccessor and returns a stream of data containing a snapshot of the current buffer in the Archivist as well as new data that arrives.

Source§

impl ArchiveReader<Inspect>

Source

pub fn inspect() -> Self

Creates an ArchiveReader for reading Inspect data.

Source

pub fn with_batch_retrieval_timeout_seconds( &mut self, timeout: i64, ) -> &mut Self

Set the maximum time to wait for a wait for a single component to have its diagnostics data “pumped”.

Source

pub fn with_aggregated_result_bytes_limit( &mut self, limit_bytes: u64, ) -> &mut Self

Sets the total number of bytes allowed in a single VMO read.

Source

pub async fn snapshot_raw<T>(&self) -> Result<T, Error>
where T: for<'a> Deserialize<'a> + SerializableValue + From<Vec<T>> + CheckResponse + 'static + Send,

Connects to the ArchiveAccessor and returns inspect data matching provided selectors. Returns the raw json for each hierarchy fetched. This is used for CTF compatibility tests (which test various implementation details of the JSON format), and use beyond such tests is discouraged.

Source

pub fn add_selectors<T, S>(&mut self, selectors: T) -> &mut Self
where T: Iterator<Item = S>, S: ToSelectorArguments,

Adds selectors used for performing filtering inspect hierarchies. This may be called multiple times to add additional selectors.

Source

pub fn add_selector(&mut self, selector: impl ToSelectorArguments) -> &mut Self

Requests a single component tree (or sub-tree).

Source

pub async fn snapshot(&self) -> Result<Vec<Data<Inspect>>, Error>

Connects to the ArchiveAccessor and returns data matching provided selectors.

Auto Trait Implementations§

§

impl<T> Freeze for ArchiveReader<T>

§

impl<T> !RefUnwindSafe for ArchiveReader<T>

§

impl<T> Send for ArchiveReader<T>
where T: Send,

§

impl<T> Sync for ArchiveReader<T>
where T: Sync,

§

impl<T> Unpin for ArchiveReader<T>
where T: Unpin,

§

impl<T> !UnwindSafe for ArchiveReader<T>

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
§

impl<T, D> Encode<Ambiguous1, D> for T
where D: ResourceDialect,

§

unsafe fn encode( self, _encoder: &mut Encoder<'_, D>, _offset: usize, _depth: Depth, ) -> Result<(), Error>

Encodes the object into the encoder’s buffers. Any handles stored in the object are swapped for Handle::INVALID. Read more
§

impl<T, D> Encode<Ambiguous2, D> for T
where D: ResourceDialect,

§

unsafe fn encode( self, _encoder: &mut Encoder<'_, D>, _offset: usize, _depth: Depth, ) -> Result<(), Error>

Encodes the object into the encoder’s buffers. Any handles stored in the object are swapped for Handle::INVALID. 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.

§

impl<T> IntoAny for T
where T: 'static + Send + Sync,

§

fn into_any(self: Arc<T>) -> Arc<dyn Any + Sync + Send>

Cast the given object into a dyn std::any::Any.
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
§

impl<T> Pointable for T

§

const ALIGN: usize

The alignment of pointer.
§

type Init = T

The type for initializers.
§

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

Initializes a with the given initializer. Read more
§

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

Dereferences the given pointer. Read more
§

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

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. 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.
§

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

§

fn vzip(self) -> V