use crate::io::*;
use crate::testing::temp;
use std::fs;
use std::io::{self, Read};
#[test]
fn test_read_at_most() {
crate::init().unwrap();
let testdata = b"Hello, world!";
for buffer_size in &[testdata.len() - 1, testdata.len(), testdata.len() + 1] {
let tf = temp::File::new_file().unwrap();
fs::write(tf.path(), testdata).unwrap();
let mut f = fs::File::open(tf.path()).unwrap();
let result = read_at_most(&mut f, *buffer_size);
if *buffer_size < testdata.len() {
assert!(result.is_err());
} else {
let data = result.unwrap();
assert_eq!(testdata, data.as_slice());
}
}
}
struct InterruptedReader<R: Read> {
inner: R,
remaining_interrupts: usize,
}
impl<R: Read> Read for InterruptedReader<R> {
fn read(&mut self, buf: &mut [u8]) -> io::Result<usize> {
if self.remaining_interrupts > 0 {
self.remaining_interrupts -= 1;
return Err(io::Error::new(io::ErrorKind::Interrupted, "interrupt"));
}
self.inner.read(buf)
}
}
#[test]
fn test_read_at_most_interrupted_retry() {
crate::init().unwrap();
let data: &[u8] = b"hello world";
let mut reader = InterruptedReader {
inner: data,
remaining_interrupts: 3,
};
let result = read_at_most(&mut reader, data.len()).unwrap();
assert_eq!(data, result.as_slice());
}
#[test]
fn test_read_at_most_zero_buffer_with_data() {
crate::init().unwrap();
let data: &[u8] = b"not empty";
let mut reader = data;
assert!(read_at_most(&mut reader, 0).is_err());
}
#[test]
fn test_read_at_most_zero_buffer_empty_input() {
crate::init().unwrap();
let data: &[u8] = b"";
let mut reader = data;
let result = read_at_most(&mut reader, 0).unwrap();
assert!(result.is_empty());
}