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
#[cfg(test)]
mod tests {
use crate::prelude::*;
use crate::MemoryInputStream;
use glib::Bytes;
#[test]
fn new() {
let strm = MemoryInputStream::new();
let ret = strm.skip(1, ::NONE_CANCELLABLE);
assert!(!ret.is_err());
assert_eq!(ret.unwrap(), 0);
let mut buf = vec![0; 10];
let ret = strm.read(&mut buf, ::NONE_CANCELLABLE).unwrap();
assert_eq!(ret, 0);
}
#[test]
fn new_from_bytes() {
let b = Bytes::from_owned(vec![1, 2, 3]);
let strm = MemoryInputStream::new_from_bytes(&b);
let mut buf = vec![0; 10];
let ret = strm.read(&mut buf, ::NONE_CANCELLABLE).unwrap();
assert_eq!(ret, 3);
assert_eq!(buf[0], 1);
assert_eq!(buf[1], 2);
assert_eq!(buf[2], 3);
let ret = strm.skip(10, ::NONE_CANCELLABLE).unwrap();
assert_eq!(ret, 0);
}
#[test]
fn add_bytes() {
let strm = MemoryInputStream::new();
let b = Bytes::from_owned(vec![1, 2, 3]);
strm.add_bytes(&b);
let mut buf = vec![0; 10];
let ret = strm.read(&mut buf, ::NONE_CANCELLABLE).unwrap();
assert_eq!(ret, 3);
assert_eq!(buf[0], 1);
assert_eq!(buf[1], 2);
assert_eq!(buf[2], 3);
let ret = strm.skip(10, ::NONE_CANCELLABLE).unwrap();
assert_eq!(ret, 0);
}
#[test]
fn read_async_future() {
use futures_util::future::TryFutureExt;
let c = glib::MainContext::new();
let buf = vec![0; 10];
let b = glib::Bytes::from_owned(vec![1, 2, 3]);
let strm = MemoryInputStream::new_from_bytes(&b);
let res = c
.block_on(
strm.read_async_future(buf, glib::PRIORITY_DEFAULT)
.map_err(|(_buf, err)| err)
.map_ok(move |(mut buf, len)| {
buf.truncate(len);
buf
}),
)
.unwrap();
assert_eq!(res, vec![1, 2, 3]);
}
}