mithril_common/certificate_chain/
fake_certificate_retriever.rsuse anyhow::anyhow;
use async_trait::async_trait;
use std::collections::HashMap;
use tokio::sync::RwLock;
use crate::entities::Certificate;
use super::{CertificateRetriever, CertificateRetrieverError};
pub struct FakeCertificaterRetriever {
certificates_map: RwLock<HashMap<String, Certificate>>,
}
impl FakeCertificaterRetriever {
pub fn from_certificates(certificates: &[Certificate]) -> Self {
let certificates_map = certificates
.iter()
.map(|certificate| (certificate.hash.clone(), certificate.clone()))
.collect::<HashMap<_, _>>();
let certificates_map = RwLock::new(certificates_map);
Self { certificates_map }
}
}
#[async_trait]
impl CertificateRetriever for FakeCertificaterRetriever {
async fn get_certificate_details(
&self,
certificate_hash: &str,
) -> Result<Certificate, CertificateRetrieverError> {
let certificates_map = self.certificates_map.read().await;
certificates_map
.get(certificate_hash)
.cloned()
.ok_or_else(|| CertificateRetrieverError(anyhow!("Certificate not found")))
}
}
#[cfg(test)]
mod tests {
use crate::test_utils::fake_data;
use super::*;
#[tokio::test]
async fn fake_certificate_retriever_retrieves_existing_certificate() {
let certificate = fake_data::certificate("certificate-hash-123".to_string());
let certificate_hash = certificate.hash.clone();
let certificate_retriever =
FakeCertificaterRetriever::from_certificates(&[certificate.clone()]);
let retrieved_certificate = certificate_retriever
.get_certificate_details(&certificate_hash)
.await
.expect("Should retrieve certificate");
assert_eq!(retrieved_certificate, certificate);
}
#[tokio::test]
async fn test_fake_certificate_fails_retrieving_unknown_certificate() {
let certificate = fake_data::certificate("certificate-hash-123".to_string());
let certificate_retriever = FakeCertificaterRetriever::from_certificates(&[certificate]);
let retrieved_certificate = certificate_retriever
.get_certificate_details("certificate-hash-not-found")
.await;
retrieved_certificate.expect_err("get_certificate_details should fail");
}
}