-
Notifications
You must be signed in to change notification settings - Fork 11
/
core-007-con-get-duplicate-response.js
129 lines (107 loc) · 4.29 KB
/
core-007-con-get-duplicate-response.js
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
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
/*
Handle a duplicate separate response to a confirmable GET request:
1. Client sends a request:
==============================================================================
Version | Type | Token Length | Code | Message ID
0 1 | 0 0 | 0 0 0 0 | 0 0 0 0 0 0 0 1 | 0x0001
1 | CON | 0 bytes | GET | 1
------------------------------------------------------------------------------
Remote Endpoint: 127.0.0.1
------------------------------------------------------------------------------
Uri-Path: temperature
==============================================================================
2. Server acknowledges the #1 request:
==============================================================================
Version | Type | Token Length | Code | Message ID
0 1 | 1 0 | 0 0 0 0 | 0 0 0 0 0 0 0 0 | 0x0001
1 | ACK | 0 bytes | Empty | 1
------------------------------------------------------------------------------
Remote Endpoint: 127.0.0.1
==============================================================================
3. Client receives the #2 acknowledgement. Request emits the `acknowledged`
event.
4. After 5s, server sends a separate confirmable response to the #1 request:
==============================================================================
Version | Type | Token Length | Code | Message ID
0 1 | 0 0 | 0 0 0 0 | 0 1 0 0 0 1 0 1 | 0x4321
1 | CON | 0 bytes | 2.05 Content | 17185
------------------------------------------------------------------------------
Remote Endpoint: 127.0.0.1
------------------------------------------------------------------------------
Payload (6 bytes)
22.3 C
==============================================================================
5. The #4 response is delayed...
6. Server retransmits the #4 response.
7. Client receives the #4 response and acknowledges it:
==============================================================================
Version | Type | Token Length | Code | Message ID
0 1 | 1 0 | 0 0 0 0 | 0 0 0 0 0 0 0 0 | 0x4321
1 | ACK | 0 bytes | Empty | 44411
------------------------------------------------------------------------------
Remote Endpoint: 127.0.0.1
==============================================================================
8. Request emits the `response` event.
9. Client receives the #6 response and resends the #7 ACK (no `response` event
is emitted).
*/
'use strict';
require('should');
var sinon = require('sinon');
var helpers = require('../helpers');
var Message = require(helpers.LIB_DIR).Message;
helpers.test(__filename, function(ctx)
{
var expectedRequest = {
type: Message.Type.CON,
code: Message.Code.GET,
id: 0x0001,
token: new Buffer([]),
uri: '/temperature'
};
var expectedAckResponse = {
type: Message.Type.ACK,
code: Message.Code.EMPTY,
id: expectedRequest.id
};
var expectedResponse = {
type: Message.Type.CON,
code: Message.Code.CONTENT,
id: 0x4321,
token: expectedRequest.token,
payload: new Buffer('22.3 C')
};
var expectedAckRequest = {
type: Message.Type.ACK,
code: Message.Code.EMPTY,
id: expectedResponse.id
};
ctx.socket.expectRequest(expectedRequest);
ctx.socket.scheduleResponse(50, expectedAckResponse);
ctx.socket.scheduleResponse(5000, expectedResponse);
ctx.socket.expectRequest(expectedAckRequest);
ctx.socket.scheduleResponse(8000, expectedResponse);
ctx.socket.expectRequest(expectedAckRequest);
var req = ctx.client.request(Message.fromObject(expectedRequest));
var eventSpy = sinon.spy(req, 'emit');
ctx.clock.tick(3600000);
return function assert()
{
ctx.socket.assert();
sinon.assert.callCount(eventSpy, 2);
sinon.assert.calledWith(
eventSpy, 'acknowledged', sinon.match.instanceOf(Message)
);
sinon.assert.calledWith(
eventSpy, 'response', sinon.match.instanceOf(Message)
);
eventSpy.args[0][0].should.be.equal('acknowledged');
sinon.assert.coapMessage(
eventSpy.args[0][1], expectedAckResponse, "Invalid ACK."
);
eventSpy.args[1][0].should.be.equal('response');
sinon.assert.coapMessage(
eventSpy.args[1][1], expectedResponse, "Invalid `response`."
);
};
});