11cb0ef41Sopenharmony_ci// Copyright Joyent, Inc. and other Node contributors.
21cb0ef41Sopenharmony_ci//
31cb0ef41Sopenharmony_ci// Permission is hereby granted, free of charge, to any person obtaining a
41cb0ef41Sopenharmony_ci// copy of this software and associated documentation files (the
51cb0ef41Sopenharmony_ci// "Software"), to deal in the Software without restriction, including
61cb0ef41Sopenharmony_ci// without limitation the rights to use, copy, modify, merge, publish,
71cb0ef41Sopenharmony_ci// distribute, sublicense, and/or sell copies of the Software, and to permit
81cb0ef41Sopenharmony_ci// persons to whom the Software is furnished to do so, subject to the
91cb0ef41Sopenharmony_ci// following conditions:
101cb0ef41Sopenharmony_ci//
111cb0ef41Sopenharmony_ci// The above copyright notice and this permission notice shall be included
121cb0ef41Sopenharmony_ci// in all copies or substantial portions of the Software.
131cb0ef41Sopenharmony_ci//
141cb0ef41Sopenharmony_ci// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
151cb0ef41Sopenharmony_ci// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
161cb0ef41Sopenharmony_ci// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
171cb0ef41Sopenharmony_ci// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
181cb0ef41Sopenharmony_ci// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
191cb0ef41Sopenharmony_ci// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
201cb0ef41Sopenharmony_ci// USE OR OTHER DEALINGS IN THE SOFTWARE.
211cb0ef41Sopenharmony_ci
221cb0ef41Sopenharmony_ci'use strict';
231cb0ef41Sopenharmony_cirequire('../common');
241cb0ef41Sopenharmony_ciconst assert = require('assert');
251cb0ef41Sopenharmony_ciconst net = require('net');
261cb0ef41Sopenharmony_ci
271cb0ef41Sopenharmony_cilet exchanges = 0;
281cb0ef41Sopenharmony_cilet starttime = null;
291cb0ef41Sopenharmony_cilet timeouttime = null;
301cb0ef41Sopenharmony_ciconst timeout = 1000;
311cb0ef41Sopenharmony_ci
321cb0ef41Sopenharmony_ciconst echo_server = net.createServer((socket) => {
331cb0ef41Sopenharmony_ci  socket.setTimeout(timeout);
341cb0ef41Sopenharmony_ci
351cb0ef41Sopenharmony_ci  socket.on('timeout', () => {
361cb0ef41Sopenharmony_ci    console.log('server timeout');
371cb0ef41Sopenharmony_ci    timeouttime = new Date();
381cb0ef41Sopenharmony_ci    console.dir(timeouttime);
391cb0ef41Sopenharmony_ci    socket.destroy();
401cb0ef41Sopenharmony_ci  });
411cb0ef41Sopenharmony_ci
421cb0ef41Sopenharmony_ci  socket.on('error', (e) => {
431cb0ef41Sopenharmony_ci    throw new Error(
441cb0ef41Sopenharmony_ci      'Server side socket should not get error. We disconnect willingly.');
451cb0ef41Sopenharmony_ci  });
461cb0ef41Sopenharmony_ci
471cb0ef41Sopenharmony_ci  socket.on('data', (d) => {
481cb0ef41Sopenharmony_ci    socket.write(d);
491cb0ef41Sopenharmony_ci  });
501cb0ef41Sopenharmony_ci
511cb0ef41Sopenharmony_ci  socket.on('end', () => {
521cb0ef41Sopenharmony_ci    socket.end();
531cb0ef41Sopenharmony_ci  });
541cb0ef41Sopenharmony_ci});
551cb0ef41Sopenharmony_ci
561cb0ef41Sopenharmony_ciecho_server.listen(0, () => {
571cb0ef41Sopenharmony_ci  const port = echo_server.address().port;
581cb0ef41Sopenharmony_ci  console.log(`server listening at ${port}`);
591cb0ef41Sopenharmony_ci
601cb0ef41Sopenharmony_ci  const client = net.createConnection(port);
611cb0ef41Sopenharmony_ci  client.setEncoding('UTF8');
621cb0ef41Sopenharmony_ci  client.setTimeout(0); // Disable the timeout for client
631cb0ef41Sopenharmony_ci  client.on('connect', () => {
641cb0ef41Sopenharmony_ci    console.log('client connected.');
651cb0ef41Sopenharmony_ci    client.write('hello\r\n');
661cb0ef41Sopenharmony_ci  });
671cb0ef41Sopenharmony_ci
681cb0ef41Sopenharmony_ci  client.on('data', (chunk) => {
691cb0ef41Sopenharmony_ci    assert.strictEqual(chunk, 'hello\r\n');
701cb0ef41Sopenharmony_ci    if (exchanges++ < 5) {
711cb0ef41Sopenharmony_ci      setTimeout(() => {
721cb0ef41Sopenharmony_ci        console.log('client write "hello"');
731cb0ef41Sopenharmony_ci        client.write('hello\r\n');
741cb0ef41Sopenharmony_ci      }, 500);
751cb0ef41Sopenharmony_ci
761cb0ef41Sopenharmony_ci      if (exchanges === 5) {
771cb0ef41Sopenharmony_ci        console.log(`wait for timeout - should come in ${timeout} ms`);
781cb0ef41Sopenharmony_ci        starttime = new Date();
791cb0ef41Sopenharmony_ci        console.dir(starttime);
801cb0ef41Sopenharmony_ci      }
811cb0ef41Sopenharmony_ci    }
821cb0ef41Sopenharmony_ci  });
831cb0ef41Sopenharmony_ci
841cb0ef41Sopenharmony_ci  client.on('timeout', () => {
851cb0ef41Sopenharmony_ci    throw new Error("client timeout - this shouldn't happen");
861cb0ef41Sopenharmony_ci  });
871cb0ef41Sopenharmony_ci
881cb0ef41Sopenharmony_ci  client.on('end', () => {
891cb0ef41Sopenharmony_ci    console.log('client end');
901cb0ef41Sopenharmony_ci    client.end();
911cb0ef41Sopenharmony_ci  });
921cb0ef41Sopenharmony_ci
931cb0ef41Sopenharmony_ci  client.on('close', () => {
941cb0ef41Sopenharmony_ci    console.log('client disconnect');
951cb0ef41Sopenharmony_ci    echo_server.close();
961cb0ef41Sopenharmony_ci  });
971cb0ef41Sopenharmony_ci});
981cb0ef41Sopenharmony_ci
991cb0ef41Sopenharmony_ciprocess.on('exit', () => {
1001cb0ef41Sopenharmony_ci  assert.ok(starttime != null);
1011cb0ef41Sopenharmony_ci  assert.ok(timeouttime != null);
1021cb0ef41Sopenharmony_ci
1031cb0ef41Sopenharmony_ci  const diff = timeouttime - starttime;
1041cb0ef41Sopenharmony_ci  console.log(`diff = ${diff}`);
1051cb0ef41Sopenharmony_ci
1061cb0ef41Sopenharmony_ci  assert.ok(timeout < diff);
1071cb0ef41Sopenharmony_ci});
108