| 'use strict'; |
| const common = require('../common'); |
| const assert = require('assert'); |
| const cp = require('child_process'); |
| const fs = require('fs'); |
| |
| const CODE = ` |
| const { internalBinding } = require('internal/test/binding'); |
| const { trace } = internalBinding('trace_events'); |
| trace('b'.charCodeAt(0), 'custom', |
| 'type-value', 10, {'extra-value': 20 }); |
| trace('b'.charCodeAt(0), 'custom', |
| 'type-value', 20, {'first-value': 20, 'second-value': 30 }); |
| trace('b'.charCodeAt(0), 'custom', 'type-value', 30); |
| trace('b'.charCodeAt(0), 'missing', |
| 'type-value', 10, {'extra-value': 20 }); |
| `; |
| |
| const tmpdir = require('../common/tmpdir'); |
| tmpdir.refresh(); |
| const FILE_NAME = tmpdir.resolve('node_trace.1.log'); |
| |
| const proc = cp.spawn(process.execPath, |
| [ '--trace-event-categories', 'custom', |
| '--no-warnings', |
| '--expose-internals', |
| '-e', CODE ], |
| { cwd: tmpdir.path }); |
| |
| proc.once('exit', common.mustCall(() => { |
| assert(fs.existsSync(FILE_NAME)); |
| fs.readFile(FILE_NAME, common.mustCall((err, data) => { |
| const traces = JSON.parse(data.toString()).traceEvents |
| .filter((trace) => trace.cat !== '__metadata'); |
| assert.strictEqual(traces.length, 3); |
| |
| assert.strictEqual(traces[0].pid, proc.pid); |
| assert.strictEqual(traces[0].ph, 'b'); |
| assert.strictEqual(traces[0].cat, 'custom'); |
| assert.strictEqual(traces[0].name, 'type-value'); |
| assert.strictEqual(traces[0].id, '0xa'); |
| assert.deepStrictEqual(traces[0].args.data, { 'extra-value': 20 }); |
| |
| assert.strictEqual(traces[1].pid, proc.pid); |
| assert.strictEqual(traces[1].ph, 'b'); |
| assert.strictEqual(traces[1].cat, 'custom'); |
| assert.strictEqual(traces[1].name, 'type-value'); |
| assert.strictEqual(traces[1].id, '0x14'); |
| assert.deepStrictEqual(traces[1].args.data, { |
| 'first-value': 20, |
| 'second-value': 30 |
| }); |
| |
| assert.strictEqual(traces[2].pid, proc.pid); |
| assert.strictEqual(traces[2].ph, 'b'); |
| assert.strictEqual(traces[2].cat, 'custom'); |
| assert.strictEqual(traces[2].name, 'type-value'); |
| assert.strictEqual(traces[2].id, '0x1e'); |
| assert.deepStrictEqual(traces[2].args, { }); |
| })); |
| })); |