// Copyright 2016 The Grin Developers // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. extern crate grin_core as core; extern crate grin_p2p as p2p; extern crate env_logger; extern crate futures; extern crate tokio_core; use std::net::SocketAddr; use std::time; use futures::future::Future; use tokio_core::net::TcpStream; use tokio_core::reactor::{self, Core}; use core::ser; use p2p::Peer; // Starts a server and connects a client peer to it to check handshake, followed by a ping/pong exchange to make sure the connection is live. #[test] fn peer_handshake() { env_logger::init().unwrap(); let mut evtlp = Core::new().unwrap(); let handle = evtlp.handle(); let p2p_conf = p2p::P2PConfig::default(); let server = p2p::Server::new(p2p_conf); let run_server = server.start(handle.clone()); let phandle = handle.clone(); let rhandle = handle.clone(); let timeout = reactor::Timeout::new(time::Duration::new(1, 0), &handle).unwrap(); let timeout_send = reactor::Timeout::new(time::Duration::new(2, 0), &handle).unwrap(); handle.spawn(timeout.map_err(|e| ser::Error::IOErr(e)).and_then(move |_| { let p2p_conf = p2p::P2PConfig::default(); let addr = SocketAddr::new(p2p_conf.host, p2p_conf.port); let socket = TcpStream::connect(&addr, &phandle).map_err(|e| ser::Error::IOErr(e)); socket.and_then(move |socket| { Peer::connect(socket, &p2p::handshake::Handshake::new()) }).and_then(move |(socket, peer)| { rhandle.spawn(peer.run(socket, &p2p::DummyAdapter {}).map_err(|e| { panic!("Client run failed: {}", e); })); peer.send_ping().unwrap(); timeout_send.map_err(|e| ser::Error::IOErr(e)).map(|_| peer) }).and_then(|peer| { let (sent, recv) = peer.transmitted_bytes(); assert!(sent > 0); assert!(recv > 0); Ok(()) }).and_then(|_| { assert!(server.peers_count() > 0); server.stop(); Ok(()) }) }).map_err(|e| { panic!("Client connection failed: {}", e); })); evtlp.run(run_server).unwrap(); }