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
use std::io;
use std::marker::Unpin;
use futures_executor::block_on;
use futures_io::AsyncRead;
use futures_util::io::{copy, AllowStdIo};
use super::ExternalStorage;
#[derive(Clone, Default)]
pub struct NoopStorage {}
impl NoopStorage {}
fn url_for() -> url::Url {
url::Url::parse("noop:///").unwrap()
}
const STORAGE_NAME: &str = "noop";
impl ExternalStorage for NoopStorage {
fn name(&self) -> &'static str {
&STORAGE_NAME
}
fn url(&self) -> io::Result<url::Url> {
Ok(url_for())
}
fn write(
&self,
_name: &str,
reader: Box<dyn AsyncRead + Send + Unpin>,
_content_length: u64,
) -> io::Result<()> {
block_on(copy(reader, &mut AllowStdIo::new(io::sink()))).map(drop)
}
fn read(&self, _name: &str) -> Box<dyn AsyncRead + Unpin> {
Box::new(AllowStdIo::new(io::empty()))
}
}
#[cfg(test)]
mod tests {
use super::*;
use futures_util::io::AsyncReadExt;
#[test]
fn test_noop_storage() {
let noop = NoopStorage::default();
let magic_contents: &[u8] = b"5678";
noop.write(
"a.log",
Box::new(magic_contents),
magic_contents.len() as u64,
)
.unwrap();
let mut reader = noop.read("a.log");
let mut buf = vec![];
block_on(reader.read_to_end(&mut buf)).unwrap();
assert!(buf.is_empty());
}
#[test]
fn test_url_of_backend() {
assert_eq!(url_for().to_string(), "noop:///");
}
}