sitespeed.io/lib/plugins/html/index.js

161 lines
4.5 KiB
JavaScript

'use strict';
const merge = require('lodash.merge');
const HTMLBuilder = require('./htmlBuilder');
const get = require('lodash.get');
const set = require('lodash.set');
const reduce = require('lodash.reduce');
const DataCollector = require('../../support/dataCollector');
// lets keep this in the HTML context, since we need things from the
// regular options object in the output
const defaultConfig = {
html: {
showAllWaterfallSummary: false
}
};
module.exports = {
open(context, options) {
this.make = context.messageMaker('html').make;
this.options = merge({}, defaultConfig, options);
this.HTMLBuilder = new HTMLBuilder(context, this.options);
this.dataCollector = new DataCollector(context);
this.maxAssets = get(options, 'maxAssets', 20);
},
processMessage(message, queue) {
const dataCollector = this.dataCollector;
const make = this.make;
if (
message.type.endsWith('.run') ||
message.type.endsWith('.pageSummary') ||
message.type.endsWith('.har')
) {
dataCollector.addDataForUrl(
message.url,
message.type,
message.data,
message.runIndex
);
} else {
switch (message.type) {
case 'error': {
dataCollector.addErrorForUrl(
message.url,
message.source,
message.data
);
break;
}
case 'aggregateassets.summary': {
if (message.group === 'total') {
const assetList = reduce(
message.data,
(assetList, asset) => {
assetList.push(asset);
return assetList;
},
[]
);
const count = this.maxAssets,
fullCount = Object.keys(assetList).length,
topAssets = assetList
.sort((a, b) => b.requestCount - a.requestCount)
.splice(0, count);
dataCollector.addSummary('assets', {
topAssets,
count,
fullCount
});
}
break;
}
case 'largestassets.summary': {
if (message.group === 'total') {
const assetsBySize = {};
for (const contentType of Object.keys(message.data)) {
assetsBySize[contentType] = message.data[contentType];
dataCollector.addSummary('toplist', {
assetsBySize
});
}
}
break;
}
case 'largestthirdpartyassets.summary': {
if (message.group === 'total') {
dataCollector.addSummary('toplist', {
thirdPartyAssetsBySize: message.data
});
}
break;
}
case 'slowestassets.summary': {
if (message.group === 'total') {
const slowestAssets = message.data;
dataCollector.addSummary('toplist', {
slowestAssets
});
}
break;
}
case 'slowestthirdpartyassets.summary': {
if (message.group === 'total') {
dataCollector.addSummary('toplist', {
thirdPartySlowestAssets: message.data
});
}
break;
}
case 'domains.summary': {
if (message.group === 'total') {
const domainList = reduce(
message.data,
(domainList, domainStats) => {
domainList.push(domainStats);
return domainList;
},
[]
);
const count = 200,
fullCount = domainList.length,
topDomains = domainList
.sort((a, b) => b.requestCount - a.requestCount)
.splice(0, count);
dataCollector.addSummary('domains', {
topDomains,
count,
fullCount
});
}
break;
}
case 'webpagetest.summary':
case 'coach.summary':
case 'pagexray.summary':
case 'browsertime.summary':
case 'gpsi.summary': {
const data = {};
set(data, message.type, message.data);
dataCollector.addSummary('index', data);
dataCollector.addSummary('detailed', data);
break;
}
case 'sitespeedio.render': {
return this.HTMLBuilder.render(dataCollector).then(() => {
queue.postMessage(make('html.finished'));
});
}
}
}
},
config: defaultConfig
};