Skip to content

Commit

Permalink
Other discussion: nodejs/node#30030
Browse files Browse the repository at this point in the history
Signed-off-by: Kevin Leimkuhler <kevin@kleimkuhler.com>
  • Loading branch information
kleimkuhler committed Mar 27, 2020
1 parent 92b03bb commit ebd7085
Showing 1 changed file with 37 additions and 0 deletions.
37 changes: 37 additions & 0 deletions tests/udp_socket.rs
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,43 @@ const ID1: Token = Token(2);
const ID2: Token = Token(3);
const ID3: Token = Token(4);

#[test]
fn empty_datagram() {
const EMPTY: &[u8] = b"";

let (mut poll, mut events) = init_with_poll();
let mut s1 = UdpSocket::bind(any_local_address()).unwrap();
let mut s2 = UdpSocket::bind(any_local_address()).unwrap();

poll.registry()
.register(&mut s1, ID1, Interest::WRITABLE)
.unwrap();
poll.registry()
.register(&mut s2, ID2, Interest::READABLE)
.unwrap();

expect_events(
&mut poll,
&mut events,
vec![ExpectEvent::new(ID1, Interest::WRITABLE)],
);

checked_write!(s1.send_to(EMPTY, s2.local_addr().unwrap()));

let mut buf = [0; 10];

// Fails on MacOS because of unexpected (bug?) kqueue behavior.
//
// Other discussion: https://github.com/nodejs/node/issues/30030
expect_events(
&mut poll,
&mut events,
vec![ExpectEvent::new(ID2, Interest::READABLE)],
);
// This also fails.
expect_read!(s2.recv_from(&mut buf), EMPTY, s1.local_addr().unwrap());
}

#[test]
fn is_send_and_sync() {
assert_send::<UdpSocket>();
Expand Down

0 comments on commit ebd7085

Please sign in to comment.