opendal/raw/tests/
utils.rs1use std::collections::HashMap;
19use std::env;
20use std::str::FromStr;
21
22use std::sync::LazyLock;
23
24use crate::*;
25
26pub static TEST_RUNTIME: LazyLock<tokio::runtime::Runtime> = LazyLock::new(|| {
28 tokio::runtime::Builder::new_multi_thread()
29 .enable_all()
30 .build()
31 .unwrap()
32});
33
34pub fn init_test_service() -> Result<Option<Operator>> {
40 let _ = dotenvy::dotenv();
41
42 let scheme = if let Ok(v) = env::var("OPENDAL_TEST") {
43 v
44 } else {
45 return Ok(None);
46 };
47 let scheme = Scheme::from_str(&scheme).unwrap();
48
49 let prefix = format!("opendal_{scheme}_");
50
51 let mut cfg = env::vars()
52 .filter_map(|(k, v)| {
53 k.to_lowercase()
54 .strip_prefix(&prefix)
55 .map(|k| (k.to_string(), v))
56 })
57 .collect::<HashMap<String, String>>();
58
59 let disable_random_root = env::var("OPENDAL_DISABLE_RANDOM_ROOT").unwrap_or_default() == "true";
61 if !disable_random_root {
62 let root = format!(
63 "{}{}/",
64 cfg.get("root").cloned().unwrap_or_else(|| "/".to_string()),
65 uuid::Uuid::new_v4()
66 );
67 cfg.insert("root".to_string(), root);
68 }
69
70 let op = Operator::via_iter(scheme, cfg).expect("must succeed");
71
72 #[cfg(feature = "layers-chaos")]
73 let op = { op.layer(layers::ChaosLayer::new(0.1)) };
74
75 let mut op = op
76 .layer(layers::LoggingLayer::default())
77 .layer(layers::TimeoutLayer::new())
78 .layer(layers::RetryLayer::new().with_max_times(4));
79
80 if !op.info().full_capability().blocking {
82 if op.info().scheme() != Scheme::Compfs {
84 let _guard = TEST_RUNTIME.enter();
85 op = op.layer(layers::BlockingLayer::create().expect("blocking layer must be created"));
86 }
87 }
88
89 Ok(Some(op))
90}