erpc_analysis::db_trait::mock

Struct MockDatabase

source
pub struct MockDatabase {
    pub projections: RwLock<HashMap<String, MockProjection>>,
    pub should_fail_on: Option<String>,
    pub call_count: RwLock<HashMap<String, usize>>,
}
Expand description

Simple in-memory mock database for testing

Fields§

§projections: RwLock<HashMap<String, MockProjection>>§should_fail_on: Option<String>§call_count: RwLock<HashMap<String, usize>>

Implementations§

source§

impl MockDatabase

source

pub fn new() -> Self

source

pub fn with_projection(self, name: &str, nodes: Vec<NodeMetrics>) -> Self

Add a test projection with predefined data

source

pub fn fail_on(self, operation: &str) -> Self

Configure the mock to fail on a specific operation

source

pub fn get_call_count(&self, method: &str) -> usize

Get the number of times a method was called

Trait Implementations§

source§

impl AnalysisDatabase for MockDatabase

source§

fn create_graph_projection<'life0, 'life1, 'async_trait>( &'life0 self, params: &'life1 GraphProjectionParams, ) -> Pin<Box<dyn Future<Output = Result<(), AnalysisError>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Creates or recreates a GDS graph projection. If a projection with the same name exists, it should ideally be dropped and recreated.
source§

fn delete_graph_projection<'life0, 'life1, 'async_trait>( &'life0 self, projection_name: &'life1 str, ) -> Pin<Box<dyn Future<Output = Result<(), AnalysisError>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Deletes an existing GDS graph projection if it exists. Should succeed even if the projection does not exist (making it idempotent).
source§

fn check_graph_projection_exists<'life0, 'life1, 'async_trait>( &'life0 self, projection_name: &'life1 str, ) -> Pin<Box<dyn Future<Output = Result<bool, AnalysisError>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Checks if a GDS graph projection with the given name exists.
source§

fn calculate_node_degrees<'life0, 'life1, 'async_trait>( &'life0 self, projection_name: &'life1 str, ) -> Pin<Box<dyn Future<Output = Result<Vec<NodeMetrics>, AnalysisError>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Calculates node-level degree metrics for all nodes in a given GDS projection. Returns a vector of NodeMetrics containing in-degree, out-degree, and total degree for each node in the graph.
source§

fn calculate_graph_metrics<'life0, 'life1, 'async_trait>( &'life0 self, projection_name: &'life1 str, ) -> Pin<Box<dyn Future<Output = Result<GraphMetrics, AnalysisError>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Calculates comprehensive graph metrics for a given GDS projection including basic counts, degree distribution, and degree statistics.
source§

fn calculate_weakly_connected_components<'life0, 'life1, 'async_trait>( &'life0 self, projection_name: &'life1 str, ) -> Pin<Box<dyn Future<Output = Result<ComponentAnalysisResult, AnalysisError>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Calculates weakly connected components using Neo4j GDS WCC algorithm. Returns analysis results containing components, sizes, and statistics.
source§

fn calculate_strongly_connected_components<'life0, 'life1, 'async_trait>( &'life0 self, projection_name: &'life1 str, ) -> Pin<Box<dyn Future<Output = Result<ComponentAnalysisResult, AnalysisError>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Calculates strongly connected components using Neo4j GDS SCC algorithm. Returns analysis results containing components, sizes, and statistics.
source§

fn calculate_louvain_communities<'life0, 'life1, 'life2, 'async_trait>( &'life0 self, projection_name: &'life1 str, _params: &'life2 LouvainConfig, ) -> Pin<Box<dyn Future<Output = Result<ComponentAnalysisResult, AnalysisError>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait, 'life2: 'async_trait,

Calculates communities using Neo4j GDS Louvain algorithm. Returns analysis results containing communities, sizes, and statistics.
source§

fn calculate_label_propagation_communities<'life0, 'life1, 'life2, 'async_trait>( &'life0 self, projection_name: &'life1 str, _params: &'life2 LabelPropagationConfig, ) -> Pin<Box<dyn Future<Output = Result<ComponentAnalysisResult, AnalysisError>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait, 'life2: 'async_trait,

Calculates communities using Neo4j GDS Label Propagation algorithm. Returns analysis results containing communities, sizes, and statistics.
source§

fn calculate_modularity<'life0, 'life1, 'life2, 'async_trait>( &'life0 self, projection_name: &'life1 str, _community_property: &'life2 str, ) -> Pin<Box<dyn Future<Output = Result<f64, AnalysisError>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait, 'life2: 'async_trait,

Calculates modularity score for a given community assignment. Higher modularity indicates better community structure.
source§

fn classify_components_by_geography<'life0, 'life1, 'async_trait>( &'life0 self, components: &'life1 [ConnectedComponent], ) -> Pin<Box<dyn Future<Output = Result<PartitionClassificationResult, AnalysisError>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Classifies connected components by geographic location (country). Groups relays by country and analyzes their distribution across components.
source§

fn classify_components_by_asn<'life0, 'life1, 'async_trait>( &'life0 self, components: &'life1 [ConnectedComponent], ) -> Pin<Box<dyn Future<Output = Result<PartitionClassificationResult, AnalysisError>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Classifies connected components by ASN. Groups relays by ASN and analyzes their distribution across components.
source§

fn classify_components_by_family<'life0, 'life1, 'async_trait>( &'life0 self, components: &'life1 [ConnectedComponent], ) -> Pin<Box<dyn Future<Output = Result<PartitionClassificationResult, AnalysisError>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Classifies connected components by relay family relationships. Groups relays by family membership and analyzes their distribution across components.
source§

fn calculate_betweenness_centrality<'life0, 'life1, 'async_trait>( &'life0 self, projection_name: &'life1 str, sampling_size: Option<usize>, sampling_seed: Option<u64>, ) -> Pin<Box<dyn Future<Output = Result<CentralityAnalysisResult, AnalysisError>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Calculates betweenness centrality for nodes in a GDS projection. Uses Neo4j GDS betweenness centrality algorithm to identify nodes that act as bridges between other nodes.
source§

fn calculate_closeness_centrality<'life0, 'life1, 'async_trait>( &'life0 self, projection_name: &'life1 str, use_wasserman_faust: Option<bool>, ) -> Pin<Box<dyn Future<Output = Result<CentralityAnalysisResult, AnalysisError>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Calculates closeness centrality for nodes in a GDS projection. Uses Neo4j GDS closeness centrality algorithm to identify nodes that are close to all other nodes in the network.
source§

fn calculate_combined_centrality<'life0, 'life1, 'async_trait>( &'life0 self, projection_name: &'life1 str, betweenness_sampling_size: Option<usize>, betweenness_sampling_seed: Option<u64>, use_wasserman_faust: Option<bool>, ) -> Pin<Box<dyn Future<Output = Result<CentralityAnalysisResult, AnalysisError>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Calculates both betweenness and closeness centrality
source§

fn analyze_paths_between_communities<'life0, 'life1, 'life2, 'life3, 'async_trait>( &'life0 self, projection_name: &'life1 str, source_nodes: &'life2 [String], target_nodes: &'life3 [String], ) -> Pin<Box<dyn Future<Output = Result<PathAnalysisResult, AnalysisError>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait, 'life2: 'async_trait, 'life3: 'async_trait,

Analyzes shortest paths between nodes from different communities. Uses Neo4j GDS shortest path algorithms to understand inter-community connectivity.
source§

impl Debug for MockDatabase

source§

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

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

impl Default for MockDatabase

source§

fn default() -> Self

Returns the “default value” for a type. 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.

§

impl<T> Instrument for T

§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided [Span], returning an Instrumented wrapper. Read more
§

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

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

§

fn vzip(self) -> V

§

impl<T> WithSubscriber for T

§

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
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a [WithDispatch] wrapper. Read more