Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Initial bridge backend support #5

Draft
wants to merge 31 commits into
base: main
Choose a base branch
from
Draft
Changes from 1 commit
Commits
Show all changes
31 commits
Select commit Hold shift + click to select a range
5ab0612
bridge_backenend: Add initial which copied from bitcoin.
ceyhunsen Sep 30, 2024
5263145
config: Update bridge backend configuration.
ceyhunsen Sep 30, 2024
bb6ae96
config: bridgeLconfig: Convert get_env to return hash map.
ceyhunsen Sep 30, 2024
1011b7c
bridge_backend: Use get_env and delete unnecessary code.
ceyhunsen Sep 30, 2024
0e561dd
bridge_backend: Rename BridgeBackendNode and add 2 commands for spawn().
ceyhunsen Sep 30, 2024
5d3e7b2
Merge branch 'initial-port' into ceyhun/bridge_backend_support
jfldde Oct 3, 2024
de83e7f
Merge branch 'main' into ceyhun/bridge_backend_support
ceyhunsen Oct 3, 2024
4aa7571
Merge branch 'main' into ceyhun/bridge_backend_support
ceyhunsen Oct 3, 2024
9ef815d
Merge branch 'main' into ceyhun/bridge_backend_support
ceyhunsen Oct 4, 2024
a2830c7
configs: Remove unnecessary =.
ceyhunsen Oct 4, 2024
e4c488a
bridge_backend: Add initial client.
ceyhunsen Oct 4, 2024
fc51959
config: Add with_bridge_backend option to TestCaseConfig.
ceyhunsen Oct 4, 2024
8adfccf
Merge branch 'main' into ceyhun/bridge_backend_support
ceyhunsen Oct 7, 2024
9475152
test_case: Add needed /.
ceyhunsen Oct 7, 2024
8f33f92
bridge_backend_client: Fix unused vars.
ceyhunsen Oct 7, 2024
54a4022
lib: Add bridge backend stuff.
ceyhunsen Oct 7, 2024
098bafa
bridge_backend: Use the new NodeT type.
ceyhunsen Oct 7, 2024
31dc639
node: Add todo.
ceyhunsen Oct 7, 2024
5dde565
Merge branch 'main' into ceyhun/bridge_backend_support
ceyhunsen Oct 7, 2024
79d0f3a
tests: Add initial bridge backend test.
ceyhunsen Oct 7, 2024
61d157b
test_case: Add bridge backend config.
ceyhunsen Oct 7, 2024
3189d49
client: Remove extra bridge backend client.
ceyhunsen Oct 7, 2024
6ceb339
config: Add extra layer for bridge backend.
ceyhunsen Oct 7, 2024
15493d4
config: Delete unnecessary configs.
ceyhunsen Oct 7, 2024
084fca6
config: Seperation of bridge backend config and test config.
ceyhunsen Oct 7, 2024
abfc06c
delete bridge backend client
ceyhunsen Oct 7, 2024
2be6799
docker: Delete backend.
ceyhunsen Oct 7, 2024
d6d7855
test_case: Remove multiple backend nodes.
ceyhunsen Oct 7, 2024
9af3a2b
docker: Apply clippy suggestion.
ceyhunsen Oct 7, 2024
b29cf19
test_case: Add bridge_backend.
ceyhunsen Oct 7, 2024
179684a
Merge branch 'main' into ceyhun/bridge_backend_support
ceyhunsen Oct 7, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
bridge_backend: Rename BridgeBackendNode and add 2 commands for spawn().
ceyhunsen committed Sep 30, 2024
commit 0e561dd73ca3bcdccdfda7eaccf2e43429850da1
66 changes: 30 additions & 36 deletions src/bridge_backend.rs
Original file line number Diff line number Diff line change
@@ -1,12 +1,10 @@
use std::collections::HashSet;
use std::path::PathBuf;
use std::sync::Arc;
use std::time::{Duration, Instant};

use anyhow::{bail, Context};
use futures::TryStreamExt;
use tokio::process::Command;
use tokio::time::sleep;

use super::config::BridgeBackendConfig;
use super::docker::DockerEnv;
@@ -16,13 +14,13 @@ use super::Result;
use crate::node::NodeKind;
use crate::test_client::TestClient;

pub struct BridgeBackend {
pub struct BridgeBackendNode {
spawn_output: SpawnOutput,
pub config: BridgeBackendConfig,
docker_env: Arc<Option<DockerEnv>>,
}

impl BridgeBackend {
impl BridgeBackendNode {
pub async fn new(config: &BridgeBackendConfig, docker: Arc<Option<DockerEnv>>) -> Result<Self> {
let spawn_output = Self::spawn(config, &docker).await?;

@@ -45,20 +43,28 @@ impl BridgeBackend {
}
}

impl Node for BridgeBackend {
impl Node for BridgeBackendNode {
type Config = BridgeBackendConfig;
type Client = TestClient;

fn spawn(config: &Self::Config) -> Result<SpawnOutput> {
let env = config.get_env();
println!("Running bridge backend with environment variables: {env:?}");

Command::new("TODO")
Command::new("npm run server:dev")
.kill_on_drop(true)
.env_clear()
.envs(env.clone())
.spawn()
.context("Failed to spawn bridge backend server process")
.map(SpawnOutput::Child)?;

Command::new("npm run worker:dev")
.kill_on_drop(true)
.env_clear()
.envs(env)
.spawn()
.context("Failed to spawn bridge backend process")
.context("Failed to spawn bridge backend worker process")
.map(SpawnOutput::Child)
}

@@ -112,7 +118,7 @@ impl Node for BridgeBackend {
}
}

impl Restart for BridgeBackend {
impl Restart for BridgeBackendNode {
async fn wait_until_stopped(&mut self) -> Result<()> {
self.client.stop().await?;
self.stop().await?;
@@ -151,9 +157,9 @@ impl Restart for BridgeBackend {
}
}

impl LogProvider for BridgeBackend {
impl LogProvider for BridgeBackendNode {
fn kind(&self) -> NodeKind {
NodeKind::Bitcoin
NodeKind::BridgeBackend
}

fn log_path(&self) -> PathBuf {
@@ -162,7 +168,7 @@ impl LogProvider for BridgeBackend {
}

pub struct BitcoinNodeCluster {
inner: Vec<BridgeBackend>,
inner: Vec<BridgeBackendNode>,
}

impl BitcoinNodeCluster {
@@ -172,7 +178,7 @@ impl BitcoinNodeCluster {
inner: Vec::with_capacity(n_nodes),
};
for config in ctx.config.bitcoin.iter() {
let node = BridgeBackend::new(config, Arc::clone(&ctx.docker)).await?;
let node = BridgeBackendNode::new(config, Arc::clone(&ctx.docker)).await?;
cluster.inner.push(node)
}

@@ -181,7 +187,7 @@ impl BitcoinNodeCluster {

pub async fn stop_all(&mut self) -> Result<()> {
for node in &mut self.inner {
RpcApi::stop(node).await?;
// RpcApi::stop(node).await?;
node.stop().await?;
}
Ok(())
@@ -190,17 +196,17 @@ impl BitcoinNodeCluster {
pub async fn wait_for_sync(&self, timeout: Duration) -> Result<()> {
let start = Instant::now();
while start.elapsed() < timeout {
let mut heights = HashSet::new();
for node in &self.inner {
let height = node.get_block_count().await?;
heights.insert(height);
}
// let mut heights = HashSet::new();
// for node in &self.inner {
// let height = node.get_block_count().await?;
// heights.insert(height);
// }

if heights.len() == 1 {
return Ok(());
}
// if heights.len() == 1 {
return Ok(());
// }

sleep(Duration::from_secs(1)).await;
// sleep(Duration::from_secs(1)).await;
}
bail!("Nodes failed to sync within the specified timeout")
}
@@ -223,24 +229,12 @@ impl BitcoinNodeCluster {
Ok(())
}

pub fn get(&self, index: usize) -> Option<&BridgeBackend> {
pub fn get(&self, index: usize) -> Option<&BridgeBackendNode> {
self.inner.get(index)
}

#[allow(unused)]
pub fn get_mut(&mut self, index: usize) -> Option<&mut BridgeBackend> {
pub fn get_mut(&mut self, index: usize) -> Option<&mut BridgeBackendNode> {
self.inner.get_mut(index)
}
}

async fn wait_for_rpc_ready(client: &Client, timeout: Option<Duration>) -> Result<()> {
let start = Instant::now();
let timeout = timeout.unwrap_or(Duration::from_secs(300));
while start.elapsed() < timeout {
match client.get_blockchain_info().await {
Ok(_) => return Ok(()),
Err(_) => sleep(Duration::from_millis(500)).await,
}
}
Err(anyhow::anyhow!("Timeout waiting for RPC to be ready"))
}