1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
#![cfg(target_os = "linux")]
#![warn(missing_docs, unused_import_braces, unused_extern_crates)]
mod def;
pub use def::*;
#[cfg(not(feature = "testmock"))]
mod linux;
#[cfg(not(feature = "testmock"))]
pub use linux::*;
#[cfg(not(feature = "testmock"))]
mod common {
use crate::Vm;
use futures::executor::{ThreadPool, ThreadPoolBuilder};
use lazy_static::lazy_static;
use myutil::{err::*, *};
use std::path::PathBuf;
pub(crate) const CLONE_MARK: &str = "clone_";
lazy_static! {
pub(crate) static ref POOL: ThreadPool =
pnk!(ThreadPoolBuilder::new().pool_size(1).create());
}
pub(crate) async fn asleep(sec: u64) {
futures_timer::Delay::new(std::time::Duration::from_secs(sec)).await;
}
#[cfg(feature = "zfs")]
lazy_static! {
pub(crate) static ref ZFS_ROOT: &'static str =
pnk!(imgroot_register(None));
}
#[cfg(feature = "zfs")]
pub(crate) fn imgroot_register(
imgpath: Option<&str>,
) -> Option<&'static str> {
static mut ROOT: Option<String> = None;
if let Some(path) = imgpath {
unsafe {
ROOT.replace(
path.trim_start_matches("/dev/zvol/")
.trim_end_matches('/')
.to_owned(),
);
}
}
unsafe { ROOT.as_deref() }
}
#[inline(always)]
pub(crate) fn vmimg_path(vm: &Vm) -> PathBuf {
let mut vmimg_path = vm.image_path.clone();
let vmimg_name = format!("{}{}", CLONE_MARK, vm.id);
vmimg_path.set_file_name(vmimg_name);
vmimg_path
}
}
#[cfg(not(feature = "testmock"))]
pub(crate) use common::*;
mod test;
#[cfg(feature = "testmock")]
mod mocker;
#[cfg(feature = "testmock")]
pub use mocker::*;