use {MultiFileDirectAccessor, InMemoryFileSystem};
use bip_disk::{DiskManagerBuilder, IDiskMessage, ODiskMessage, FileSystem, BlockMetadata, Block};
use bip_metainfo::{MetainfoBuilder, PieceLength, Metainfo};
use bytes::BytesMut;
use tokio_core::reactor::{Core};
use futures::future::{Loop};
use futures::stream::Stream;
use futures::sink::Sink;
#[test]
fn positive_process_block() {
let data_a = (::random_buffer(1023), "/path/to/file/a".into());
let data_b = (::random_buffer(2000), "/path/to/file/b".into());
let files_accessor = MultiFileDirectAccessor::new("/my/downloads/".into(),
vec![data_a.clone(), data_b.clone()]);
let metainfo_bytes = MetainfoBuilder::new()
.set_piece_length(PieceLength::Custom(1024))
.build(1, files_accessor, |_| ()).unwrap();
let metainfo_file = Metainfo::from_bytes(metainfo_bytes).unwrap();
let filesystem = InMemoryFileSystem::new();
let disk_manager = DiskManagerBuilder::new()
.build(filesystem.clone());
let mut process_bytes = BytesMut::new();
process_bytes.extend_from_slice(&data_b.0[1..(50 + 1)]);
let process_block = Block::new(BlockMetadata::new(metainfo_file.info().info_hash(), 1, 0, 50), process_bytes.freeze());
let (send, recv) = disk_manager.split();
let mut blocking_send = send.wait();
blocking_send.send(IDiskMessage::AddTorrent(metainfo_file)).unwrap();
let mut core = Core::new().unwrap();
::core_loop_with_timeout(&mut core, 500, ((blocking_send, Some(process_block)), recv),
|(mut blocking_send, opt_pblock), recv, msg| {
match msg {
ODiskMessage::TorrentAdded(_) => {
blocking_send.send(IDiskMessage::ProcessBlock(opt_pblock.unwrap())).unwrap();
Loop::Continue(((blocking_send, None), recv))
},
ODiskMessage::BlockProcessed(_) => Loop::Break(()),
unexpected @ _ => panic!("Unexpected Message: {:?}", unexpected)
}
}
);
let mut received_file_b = filesystem.open_file(data_b.1).unwrap();
assert_eq!(2000, filesystem.file_size(&received_file_b).unwrap());
let mut recevied_file_b_data = vec![0u8; 2000];
assert_eq!(2000, filesystem.read_file(&mut received_file_b, 0, &mut recevied_file_b_data).unwrap());
let mut expected_file_b_data = vec![0u8; 2000];
(&mut expected_file_b_data[1..(1 + 50)]).copy_from_slice(&data_b.0[1..(50 + 1)]);
assert_eq!(expected_file_b_data, recevied_file_b_data);
}