diff --git a/crates/services/gas_price_service/src/v0/service.rs b/crates/services/gas_price_service/src/v0/service.rs index 00df5bb8a68..04254f67cb5 100644 --- a/crates/services/gas_price_service/src/v0/service.rs +++ b/crates/services/gas_price_service/src/v0/service.rs @@ -10,7 +10,6 @@ use crate::{ use anyhow::anyhow; use async_trait::async_trait; use fuel_core_services::{ - RunnableService, RunnableTask, StateWatcher, }; @@ -116,32 +115,6 @@ where } } -#[async_trait] -impl RunnableService for GasPriceServiceV0 -where - L2: L2BlockSource, - Metadata: MetadataStorage, -{ - const NAME: &'static str = "GasPriceServiceV0"; - type SharedData = SharedV0Algorithm; - type Task = Self; - type TaskParams = (); - - fn shared_data(&self) -> Self::SharedData { - self.shared_algo.clone() - } - - async fn into_task( - mut self, - _state_watcher: &StateWatcher, - _params: Self::TaskParams, - ) -> anyhow::Result { - let algorithm = self.algorithm_updater.algorithm(); - self.shared_algo.update(algorithm).await; - Ok(self) - } -} - #[async_trait] impl RunnableTask for GasPriceServiceV0 where @@ -194,17 +167,48 @@ mod tests { v0::{ metadata::V0Metadata, service::GasPriceServiceV0, - uninitialized_task::initialize_algorithm, + uninitialized_task::{ + initialize_algorithm, + SharedV0Algorithm, + }, }, }; use fuel_core_services::{ + RunnableService, Service, ServiceRunner, + StateWatcher, }; use fuel_core_types::fuel_types::BlockHeight; use std::sync::Arc; use tokio::sync::mpsc; + #[async_trait::async_trait] + impl RunnableService for GasPriceServiceV0 + where + L2: L2BlockSource, + Metadata: MetadataStorage, + { + const NAME: &'static str = "GasPriceServiceV0"; + type SharedData = SharedV0Algorithm; + type Task = Self; + type TaskParams = (); + + fn shared_data(&self) -> Self::SharedData { + self.shared_algo.clone() + } + + async fn into_task( + mut self, + _state_watcher: &StateWatcher, + _params: Self::TaskParams, + ) -> anyhow::Result { + let algorithm = self.algorithm_updater.algorithm(); + self.shared_algo.update(algorithm).await; + Ok(self) + } + } + struct FakeL2BlockSource { l2_block: mpsc::Receiver, } diff --git a/crates/services/gas_price_service/src/v0/uninitialized_task.rs b/crates/services/gas_price_service/src/v0/uninitialized_task.rs index b21c82635a9..bd58db174c7 100644 --- a/crates/services/gas_price_service/src/v0/uninitialized_task.rs +++ b/crates/services/gas_price_service/src/v0/uninitialized_task.rs @@ -190,7 +190,7 @@ where GasPriceData + Modifiable + KeyValueInspect + Clone, SettingsProvider: GasPriceSettingsProvider, { - const NAME: &'static str = "UninitializedGasPriceServiceV0"; + const NAME: &'static str = "GasPriceServiceV0"; type SharedData = SharedV0Algorithm; type Task = GasPriceServiceV0< FuelL2BlockSource, @@ -360,7 +360,8 @@ where GasPriceData + Modifiable + KeyValueInspect + Clone, SettingsProvider: GasPriceSettingsProvider, { - let gas_price_init = UninitializedTask::new( + // lazy initialization of gas price service, delegate to parent + let gas_price_uninit = UninitializedTask::new( config, genesis_block_height, settings, @@ -368,5 +369,5 @@ where gas_price_db, on_chain_db, )?; - Ok(ServiceRunner::new(gas_price_init)) + Ok(ServiceRunner::new(gas_price_uninit)) }