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