More tests

This commit is contained in:
arkpar 2016-02-17 14:07:26 +01:00
parent c9f3f5e544
commit 0cfc4cbb34
2 changed files with 55 additions and 11 deletions

View File

@ -18,21 +18,42 @@ use io::IoError;
use crypto::CryptoError; use crypto::CryptoError;
use rlp::*; use rlp::*;
#[derive(Debug, Copy, Clone)] #[derive(Debug, Copy, Clone, PartialEq, Eq)]
pub enum DisconnectReason pub enum DisconnectReason
{ {
DisconnectRequested, DisconnectRequested,
_TCPError, TCPError,
_BadProtocol, BadProtocol,
UselessPeer, UselessPeer,
_TooManyPeers, TooManyPeers,
_DuplicatePeer, DuplicatePeer,
_IncompatibleProtocol, IncompatibleProtocol,
_NullIdentity, NullIdentity,
_ClientQuit, ClientQuit,
_UnexpectedIdentity, UnexpectedIdentity,
_LocalIdentity, LocalIdentity,
PingTimeout, PingTimeout,
Unknown,
}
impl DisconnectReason {
pub fn from_u8(n: u8) -> DisconnectReason {
match n {
0 => DisconnectReason::DisconnectRequested,
1 => DisconnectReason::TCPError,
2 => DisconnectReason::BadProtocol,
3 => DisconnectReason::UselessPeer,
4 => DisconnectReason::TooManyPeers,
5 => DisconnectReason::DuplicatePeer,
6 => DisconnectReason::IncompatibleProtocol,
7 => DisconnectReason::NullIdentity,
8 => DisconnectReason::ClientQuit,
9 => DisconnectReason::UnexpectedIdentity,
10 => DisconnectReason::LocalIdentity,
11 => DisconnectReason::PingTimeout,
_ => DisconnectReason::Unknown,
}
}
} }
#[derive(Debug)] #[derive(Debug)]
@ -70,3 +91,22 @@ impl From<CryptoError> for NetworkError {
} }
} }
#[test]
fn test_errors() {
assert_eq!(DisconnectReason::ClientQuit, DisconnectReason::from_u8(8));
let mut r = DisconnectReason::DisconnectRequested;
for i in 0 .. 20 {
r = DisconnectReason::from_u8(i);
}
assert_eq!(DisconnectReason::Unknown, r);
match <NetworkError as From<DecoderError>>::from(DecoderError::RlpIsTooBig) {
NetworkError::Auth => {},
_ => panic!("Unexpeceted error"),
}
match <NetworkError as From<CryptoError>>::from(CryptoError::InvalidSecret) {
NetworkError::Auth => {},
_ => panic!("Unexpeceted error"),
}
}

View File

@ -231,7 +231,11 @@ impl Session {
try!(self.read_hello(&rlp, host)); try!(self.read_hello(&rlp, host));
Ok(SessionData::Ready) Ok(SessionData::Ready)
}, },
PACKET_DISCONNECT => Err(From::from(NetworkError::Disconnect(DisconnectReason::DisconnectRequested))), PACKET_DISCONNECT => {
let rlp = UntrustedRlp::new(&packet.data[1..]);
let reason: u8 = try!(rlp.val_at(0));
Err(From::from(NetworkError::Disconnect(DisconnectReason::from_u8(reason))))
}
PACKET_PING => { PACKET_PING => {
try!(self.send_pong()); try!(self.send_pong());
Ok(SessionData::None) Ok(SessionData::None)