From 7c0eb5e080b535782b10137e3c055818556fd094 Mon Sep 17 00:00:00 2001 From: lilia Date: Tue, 28 Jul 2015 14:59:16 -0700 Subject: [PATCH] Add keepalive reset test --- .../test/websocket-resources_test.js | 22 +++++++++++++++++++ 1 file changed, 22 insertions(+) diff --git a/libtextsecure/test/websocket-resources_test.js b/libtextsecure/test/websocket-resources_test.js index 3616a4e5..20b9fe95 100644 --- a/libtextsecure/test/websocket-resources_test.js +++ b/libtextsecure/test/websocket-resources_test.js @@ -162,6 +162,28 @@ keepalive: { disconnect: true } }); }); + + it('allows resetting the keepalive timer', function(done) { + this.timeout(65000); + var mockServer = new MockServer('ws://localhost:8081'); + var socket = new WebSocket('ws://localhost:8081'); + var startTime = Date.now(); + mockServer.on('connection', function(server) { + server.on('message', function(data) { + var message = textsecure.protobuf.WebSocketMessage.decode(data); + assert.strictEqual(message.type, textsecure.protobuf.WebSocketMessage.Type.REQUEST); + assert.strictEqual(message.request.verb, 'GET'); + assert.strictEqual(message.request.path, '/'); + assert(Date.now() > startTime + 60000, 'keepalive time should be longer than a minute'); + server.close(); + done(); + }); + }); + var resource = new WebSocketResource(socket, { keepalive: true }); + setTimeout(function() { + resource.resetKeepAliveTimer() + }, 5000); + }); }); }); }());