1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
use crate::*;
use bytes::{Buf, BufMut, Bytes, BytesMut};
#[derive(Debug, Clone, PartialEq)]
pub struct PubAck {
pub pkid: u16,
}
impl PubAck {
pub fn new(pkid: u16) -> PubAck {
PubAck { pkid }
}
pub(crate) fn assemble(fixed_header: FixedHeader, mut bytes: Bytes) -> Result<Self, Error> {
if fixed_header.remaining_len != 2 {
return Err(Error::PayloadSizeIncorrect);
}
let variable_header_index = fixed_header.fixed_len;
bytes.advance(variable_header_index);
let pkid = bytes.get_u16();
let puback = PubAck { pkid };
Ok(puback)
}
pub fn write(&self, buffer: &mut BytesMut) -> Result<usize, Error> {
let o: &[u8] = &[0x40, 0x02];
buffer.put_slice(o);
buffer.put_u16(self.pkid);
Ok(4)
}
}
#[cfg(test)]
mod test {
use super::*;
use bytes::BytesMut;
use pretty_assertions::assert_eq;
#[test]
fn puback_stitching_works_correctly() {
let stream = &[
0b0100_0000,
0x02,
0x00,
0x0A,
0xDE,
0xAD,
0xBE,
0xEF,
];
let mut stream = BytesMut::from(&stream[..]);
let packet = mqtt_read(&mut stream, 100).unwrap();
let packet = match packet {
Packet::PubAck(packet) => packet,
packet => panic!("Invalid packet = {:?}", packet),
};
assert_eq!(packet, PubAck { pkid: 10 });
}
}