11cb0ef41Sopenharmony_ci'use strict';
21cb0ef41Sopenharmony_ciconst common = require('../common');
31cb0ef41Sopenharmony_ciconst assert = require('assert');
41cb0ef41Sopenharmony_ciconst cp = require('child_process');
51cb0ef41Sopenharmony_ciconst fs = require('fs');
61cb0ef41Sopenharmony_ciconst path = require('path');
71cb0ef41Sopenharmony_ciconst tmpdir = require('../common/tmpdir');
81cb0ef41Sopenharmony_ci
91cb0ef41Sopenharmony_ciconst CODE = `
101cb0ef41Sopenharmony_ci  const net = require('net');
111cb0ef41Sopenharmony_ci  const socket = net.connect('${common.PIPE}');
121cb0ef41Sopenharmony_ci  socket.on('error', () => {});
131cb0ef41Sopenharmony_ci  const server = net.createServer((socket) => {
141cb0ef41Sopenharmony_ci    socket.destroy();
151cb0ef41Sopenharmony_ci    server.close();
161cb0ef41Sopenharmony_ci  }).listen(0, () => {
171cb0ef41Sopenharmony_ci    net.connect(server.address().port);
181cb0ef41Sopenharmony_ci  });
191cb0ef41Sopenharmony_ci`;
201cb0ef41Sopenharmony_ci
211cb0ef41Sopenharmony_citmpdir.refresh();
221cb0ef41Sopenharmony_ciconst FILE_NAME = path.join(tmpdir.path, 'node_trace.1.log');
231cb0ef41Sopenharmony_ci
241cb0ef41Sopenharmony_ciconst proc = cp.spawn(process.execPath,
251cb0ef41Sopenharmony_ci                      [ '--trace-events-enabled',
261cb0ef41Sopenharmony_ci                        '--trace-event-categories', 'node.net.native',
271cb0ef41Sopenharmony_ci                        '-e', CODE ],
281cb0ef41Sopenharmony_ci                      { cwd: tmpdir.path });
291cb0ef41Sopenharmony_ci
301cb0ef41Sopenharmony_ciproc.once('exit', common.mustCall(() => {
311cb0ef41Sopenharmony_ci  assert(fs.existsSync(FILE_NAME));
321cb0ef41Sopenharmony_ci  fs.readFile(FILE_NAME, common.mustCall((err, data) => {
331cb0ef41Sopenharmony_ci    const traces = JSON.parse(data.toString()).traceEvents;
341cb0ef41Sopenharmony_ci    assert(traces.length > 0);
351cb0ef41Sopenharmony_ci    let count = 0;
361cb0ef41Sopenharmony_ci    traces.forEach((trace) => {
371cb0ef41Sopenharmony_ci      if (trace.cat === 'node,node.net,node.net.native' &&
381cb0ef41Sopenharmony_ci          trace.name === 'connect') {
391cb0ef41Sopenharmony_ci        count++;
401cb0ef41Sopenharmony_ci      }
411cb0ef41Sopenharmony_ci    });
421cb0ef41Sopenharmony_ci    // Two begin, two end
431cb0ef41Sopenharmony_ci    assert.strictEqual(count, 4);
441cb0ef41Sopenharmony_ci  }));
451cb0ef41Sopenharmony_ci}));
46