2022-10-16 07:30:11 -04:00
|
|
|
use std::sync::Arc;
|
2022-10-16 03:29:55 -04:00
|
|
|
|
2022-10-16 09:16:44 -04:00
|
|
|
use tokio::sync::RwLock;
|
2022-10-16 07:30:11 -04:00
|
|
|
|
|
|
|
|
use tendermint_machine::{ext::*, Message, TendermintMachine, TendermintHandle};
|
|
|
|
|
|
|
|
|
|
type TestValidatorId = u16;
|
|
|
|
|
type TestBlockId = u32;
|
|
|
|
|
|
|
|
|
|
#[derive(Clone, PartialEq, Debug)]
|
2022-10-16 03:29:55 -04:00
|
|
|
struct TestBlock {
|
2022-10-16 07:30:11 -04:00
|
|
|
id: TestBlockId,
|
2022-10-16 03:29:55 -04:00
|
|
|
valid: Result<(), BlockError>,
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
impl Block for TestBlock {
|
2022-10-16 07:30:11 -04:00
|
|
|
type Id = TestBlockId;
|
2022-10-16 03:29:55 -04:00
|
|
|
|
2022-10-16 07:30:11 -04:00
|
|
|
fn id(&self) -> TestBlockId {
|
2022-10-16 03:29:55 -04:00
|
|
|
self.id
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2022-10-16 07:30:11 -04:00
|
|
|
struct TestWeights;
|
|
|
|
|
impl Weights for TestWeights {
|
|
|
|
|
type ValidatorId = TestValidatorId;
|
2022-10-16 03:55:39 -04:00
|
|
|
|
2022-10-16 03:29:55 -04:00
|
|
|
fn total_weight(&self) -> u64 {
|
2022-10-16 09:09:05 -04:00
|
|
|
4
|
2022-10-16 03:29:55 -04:00
|
|
|
}
|
2022-10-16 07:30:11 -04:00
|
|
|
fn weight(&self, id: TestValidatorId) -> u64 {
|
2022-10-16 09:09:05 -04:00
|
|
|
[1; 4][usize::try_from(id).unwrap()]
|
2022-10-16 03:29:55 -04:00
|
|
|
}
|
|
|
|
|
|
2022-10-16 07:30:11 -04:00
|
|
|
fn proposer(&self, number: BlockNumber, round: Round) -> TestValidatorId {
|
2022-10-16 09:09:05 -04:00
|
|
|
TestValidatorId::try_from((number.0 + u32::from(round.0)) % 4).unwrap()
|
2022-10-16 07:30:11 -04:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
struct TestNetwork(Arc<RwLock<Vec<TendermintHandle<Self>>>>);
|
|
|
|
|
|
|
|
|
|
#[async_trait::async_trait]
|
|
|
|
|
impl Network for TestNetwork {
|
|
|
|
|
type ValidatorId = TestValidatorId;
|
|
|
|
|
type Weights = TestWeights;
|
|
|
|
|
type Block = TestBlock;
|
|
|
|
|
|
2022-10-16 07:54:07 -04:00
|
|
|
const BLOCK_TIME: u32 = 1;
|
|
|
|
|
|
2022-10-16 07:30:11 -04:00
|
|
|
fn weights(&self) -> Arc<TestWeights> {
|
|
|
|
|
Arc::new(TestWeights)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
async fn broadcast(&mut self, msg: Message<TestValidatorId, Self::Block>) {
|
|
|
|
|
for handle in self.0.write().await.iter_mut() {
|
|
|
|
|
handle.messages.send(msg.clone()).await.unwrap();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
async fn slash(&mut self, validator: TestValidatorId) {
|
|
|
|
|
dbg!("Slash");
|
|
|
|
|
todo!()
|
2022-10-16 03:55:39 -04:00
|
|
|
}
|
|
|
|
|
|
2022-10-16 07:30:11 -04:00
|
|
|
fn validate(&mut self, block: &TestBlock) -> Result<(), BlockError> {
|
2022-10-16 03:29:55 -04:00
|
|
|
block.valid
|
|
|
|
|
}
|
2022-10-16 07:30:11 -04:00
|
|
|
|
|
|
|
|
fn add_block(&mut self, block: TestBlock) -> TestBlock {
|
|
|
|
|
dbg!("Adding ", &block);
|
|
|
|
|
assert!(block.valid.is_ok());
|
|
|
|
|
TestBlock { id: block.id + 1, valid: Ok(()) }
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
impl TestNetwork {
|
|
|
|
|
async fn new(validators: usize) -> Arc<RwLock<Vec<TendermintHandle<Self>>>> {
|
|
|
|
|
let arc = Arc::new(RwLock::new(vec![]));
|
|
|
|
|
{
|
|
|
|
|
let mut write = arc.write().await;
|
|
|
|
|
for i in 0 .. validators {
|
|
|
|
|
write.push(TendermintMachine::new(
|
|
|
|
|
TestNetwork(arc.clone()),
|
|
|
|
|
u16::try_from(i).unwrap(),
|
|
|
|
|
BlockNumber(1),
|
|
|
|
|
TestBlock { id: 1, valid: Ok(()) },
|
|
|
|
|
));
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
arc
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#[tokio::test]
|
|
|
|
|
async fn test() {
|
|
|
|
|
TestNetwork::new(4).await;
|
|
|
|
|
loop {
|
|
|
|
|
tokio::task::yield_now().await;
|
|
|
|
|
}
|
2022-10-16 03:29:55 -04:00
|
|
|
}
|