use {MultiFileDirectAccessor, InMemoryFileSystem};
use bip_disk::{DiskManagerBuilder, IDiskMessage};
use bip_metainfo::{MetainfoBuilder, PieceLength, Metainfo};
use tokio_core::reactor::{Core};
use futures::future::{Future};
use futures::stream::Stream;
use futures::sink::Sink;
use futures::{future, AsyncSink};
#[test]
fn positive_disk_manager_send_backpressure() {
let data_a = (::random_buffer(50), "/path/to/file/a".into());
let data_b = (::random_buffer(2000), "/path/to/file/b".into());
let data_c = (::random_buffer(0), "/path/to/file/c".into());
let files_accessor = MultiFileDirectAccessor::new("/my/downloads/".into(),
vec![data_a.clone(), data_b.clone(), data_c.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 info_hash = metainfo_file.info().info_hash();
let filesystem = InMemoryFileSystem::new();
let (m_send, m_recv) = DiskManagerBuilder::new()
.with_sink_buffer_capacity(1)
.build(filesystem.clone())
.split();
let mut core = Core::new().unwrap();
let mut m_send = core.run(m_send.send(IDiskMessage::AddTorrent(metainfo_file))).unwrap();
let (result, m_send) = core.run(future::lazy(|| future::ok::<_, ()>((m_send.start_send(IDiskMessage::RemoveTorrent(info_hash)), m_send)))).unwrap();
match result {
Ok(AsyncSink::NotReady(_)) => (),
_ => panic!("Unexpected Result From Backpressure Test")
};
let m_recv = core.run(m_recv.into_future().map(|(_, recv)| recv).map_err(|_| ())).unwrap();
let _ = core.run(m_send.send(IDiskMessage::RemoveTorrent(info_hash))).unwrap();
let _ = core.run(m_recv.into_future().map(|(_, recv)| recv).map_err(|_| ())).unwrap();
}