mirror of https://github.com/lukechilds/node.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
140 lines
4.4 KiB
140 lines
4.4 KiB
8 years ago
|
'use strict';
|
||
|
|
||
|
const common = require('../common');
|
||
|
const Countdown = require('../common/countdown');
|
||
|
const assert = require('assert');
|
||
|
const {
|
||
|
observerCounts: counts
|
||
|
} = process.binding('performance');
|
||
|
const {
|
||
|
performance,
|
||
|
PerformanceObserver,
|
||
|
constants
|
||
|
} = require('perf_hooks');
|
||
|
|
||
|
const {
|
||
|
NODE_PERFORMANCE_ENTRY_TYPE_NODE,
|
||
|
NODE_PERFORMANCE_ENTRY_TYPE_MARK,
|
||
|
NODE_PERFORMANCE_ENTRY_TYPE_MEASURE,
|
||
|
NODE_PERFORMANCE_ENTRY_TYPE_GC,
|
||
|
NODE_PERFORMANCE_ENTRY_TYPE_FUNCTION,
|
||
|
} = constants;
|
||
|
|
||
|
assert.strictEqual(counts[NODE_PERFORMANCE_ENTRY_TYPE_NODE], 0);
|
||
|
assert.strictEqual(counts[NODE_PERFORMANCE_ENTRY_TYPE_MARK], 1);
|
||
|
assert.strictEqual(counts[NODE_PERFORMANCE_ENTRY_TYPE_MEASURE], 1);
|
||
|
assert.strictEqual(counts[NODE_PERFORMANCE_ENTRY_TYPE_GC], 0);
|
||
|
assert.strictEqual(counts[NODE_PERFORMANCE_ENTRY_TYPE_FUNCTION], 0);
|
||
|
|
||
|
{
|
||
|
[1, null, undefined, {}, [], Infinity].forEach((i) => {
|
||
|
assert.throws(() => new PerformanceObserver(i),
|
||
|
common.expectsError({
|
||
|
code: 'ERR_INVALID_CALLBACK',
|
||
|
type: TypeError,
|
||
|
message: 'Callback must be a function'
|
||
|
}));
|
||
|
});
|
||
|
const observer = new PerformanceObserver(common.mustNotCall());
|
||
|
|
||
|
[1, null, undefined].forEach((i) => {
|
||
|
//observer.observe(i);
|
||
|
assert.throws(() => observer.observe(i),
|
||
|
common.expectsError({
|
||
|
code: 'ERR_INVALID_ARG_TYPE',
|
||
|
type: TypeError,
|
||
|
message: 'The "options" argument must be of type Object'
|
||
|
}));
|
||
|
});
|
||
|
|
||
|
[1, undefined, null, {}, Infinity].forEach((i) => {
|
||
|
assert.throws(() => observer.observe({ entryTypes: i }),
|
||
|
common.expectsError({
|
||
|
code: 'ERR_INVALID_OPT_VALUE',
|
||
|
type: TypeError,
|
||
|
message: 'The value "[object Object]" is invalid for ' +
|
||
|
'option "entryTypes"'
|
||
|
}));
|
||
|
});
|
||
|
}
|
||
|
|
||
|
// Test Non-Buffered
|
||
|
{
|
||
|
const observer =
|
||
|
new PerformanceObserver(common.mustCall(callback, 3));
|
||
|
|
||
|
const countdown =
|
||
|
new Countdown(3, common.mustCall(() => {
|
||
|
observer.disconnect();
|
||
|
assert.strictEqual(counts[NODE_PERFORMANCE_ENTRY_TYPE_MARK], 1);
|
||
|
}));
|
||
|
|
||
|
function callback(list, obs) {
|
||
|
assert.strictEqual(obs, observer);
|
||
|
const entries = list.getEntries();
|
||
|
assert.strictEqual(entries.length, 1);
|
||
|
countdown.dec();
|
||
|
}
|
||
|
assert.strictEqual(counts[NODE_PERFORMANCE_ENTRY_TYPE_MARK], 1);
|
||
|
assert.doesNotThrow(() => observer.observe({ entryTypes: ['mark'] }));
|
||
|
assert.strictEqual(counts[NODE_PERFORMANCE_ENTRY_TYPE_MARK], 2);
|
||
|
performance.mark('test1');
|
||
|
performance.mark('test2');
|
||
|
performance.mark('test3');
|
||
|
}
|
||
|
|
||
|
|
||
|
// Test Buffered
|
||
|
{
|
||
|
const observer =
|
||
|
new PerformanceObserver(common.mustCall(callback, 1));
|
||
|
assert.strictEqual(counts[NODE_PERFORMANCE_ENTRY_TYPE_MARK], 1);
|
||
|
|
||
|
function callback(list, obs) {
|
||
|
assert.strictEqual(obs, observer);
|
||
|
const entries = list.getEntries();
|
||
|
assert.strictEqual(entries.length, 3);
|
||
|
observer.disconnect();
|
||
|
assert.strictEqual(counts[NODE_PERFORMANCE_ENTRY_TYPE_MARK], 1);
|
||
|
|
||
|
{
|
||
|
const entriesByName = list.getEntriesByName('test1');
|
||
|
assert.strictEqual(entriesByName.length, 1);
|
||
|
assert.strictEqual(entriesByName[0].name, 'test1');
|
||
|
assert.strictEqual(entriesByName[0].entryType, 'mark');
|
||
|
}
|
||
|
|
||
|
{
|
||
|
const entriesByName = list.getEntriesByName('test1', 'mark');
|
||
|
assert.strictEqual(entriesByName.length, 1);
|
||
|
assert.strictEqual(entriesByName[0].name, 'test1');
|
||
|
assert.strictEqual(entriesByName[0].entryType, 'mark');
|
||
|
}
|
||
|
|
||
|
{
|
||
|
const entriesByName = list.getEntriesByName('test1', 'measure');
|
||
|
assert.strictEqual(entriesByName.length, 0);
|
||
|
}
|
||
|
|
||
|
{
|
||
|
const entriesByType = list.getEntriesByType('measure');
|
||
|
assert.strictEqual(entriesByType.length, 1);
|
||
|
assert.strictEqual(entriesByType[0].name, 'test3');
|
||
|
assert.strictEqual(entriesByType[0].entryType, 'measure');
|
||
|
}
|
||
|
}
|
||
|
|
||
|
assert.doesNotThrow(() => {
|
||
|
observer.observe({ entryTypes: ['mark', 'measure'], buffered: true });
|
||
|
});
|
||
|
// Do this twice to make sure it doesn't throw
|
||
|
assert.doesNotThrow(() => {
|
||
|
observer.observe({ entryTypes: ['mark', 'measure'], buffered: true });
|
||
|
});
|
||
|
// Even tho we called twice, count should be 1
|
||
|
assert.strictEqual(counts[NODE_PERFORMANCE_ENTRY_TYPE_MARK], 2);
|
||
|
performance.mark('test1');
|
||
|
performance.mark('test2');
|
||
|
performance.measure('test3', 'test1', 'test2');
|
||
|
}
|