Commit 0132dc4a authored by Quang-Minh Nguyen's avatar Quang-Minh Nguyen

Add more information into the frontend resources in performance bar

Issue https://gitlab.com/groups/gitlab-org/-/epics/5590
parent 1e26f1e4
...@@ -54,11 +54,17 @@ export default { ...@@ -54,11 +54,17 @@ export default {
return this.currentRequest.details[this.metric]; return this.currentRequest.details[this.metric];
}, },
metricDetailsSummary() { metricDetailsSummary() {
return { const summary = {}
[s__('Total')]: this.metricDetails.calls,
[s__('PerformanceBar|Total duration')]: this.metricDetails.duration, if (!this.metricDetails.summaryOptions || !this.metricDetails.summaryOptions.hideTotal) {
...(this.metricDetails.summary || {}), summary[s__('Total')] = this.metricDetails.calls
}; }
if (!this.metricDetails.summaryOptions || !this.metricDetails.summaryOptions.hideDuration) {
summary[s__('PerformanceBar|Total duration')] = this.metricDetails.duration
}
return {...summary, ...(this.metricDetails.summary || {})}
}, },
metricDetailsLabel() { metricDetailsLabel() {
if (this.metricDetails.duration && this.metricDetails.calls) { if (this.metricDetails.duration && this.metricDetails.calls) {
......
...@@ -75,37 +75,51 @@ const initPerformanceBar = (el) => { ...@@ -75,37 +75,51 @@ const initPerformanceBar = (el) => {
const resourceEntries = performance.getEntriesByType('resource'); const resourceEntries = performance.getEntriesByType('resource');
let durationString = ''; let durationString = '';
let summary = {};
if (navigationEntries.length > 0) { if (navigationEntries.length > 0) {
durationString = `${Math.round(navigationEntries[0].responseEnd)} | `; const backend = Math.round(navigationEntries[0].responseEnd);
durationString += `${Math.round(paintEntries[1].startTime)} | `; const firstContentfulPaint = Math.round(paintEntries[1].startTime);
durationString += ` ${Math.round(navigationEntries[0].domContentLoadedEventEnd)}`; const domContentLoaded = Math.round(navigationEntries[0].domContentLoadedEventEnd);
summary = {
Backend: backend,
'First contentful paint': firstContentfulPaint,
'Dom content loaded': domContentLoaded,
};
durationString = `${backend} | ${firstContentfulPaint} | ${domContentLoaded}`;
} }
let newEntries = resourceEntries.map(this.transformResourceEntry); let newEntries = resourceEntries.map(this.transformResourceEntry);
this.updateFrontendPerformanceMetrics(durationString, newEntries); this.updateFrontendPerformanceMetrics(durationString, summary, newEntries);
if ('PerformanceObserver' in window) { if ('PerformanceObserver' in window) {
// We start observing for more incoming timings // We start observing for more incoming timings
const observer = new PerformanceObserver((list) => { const observer = new PerformanceObserver((list) => {
newEntries = newEntries.concat(list.getEntries().map(this.transformResourceEntry)); newEntries = newEntries.concat(list.getEntries().map(this.transformResourceEntry));
this.updateFrontendPerformanceMetrics(durationString, newEntries); this.updateFrontendPerformanceMetrics(durationString, summary, newEntries);
}); });
observer.observe({ entryTypes: ['resource'] }); observer.observe({ entryTypes: ['resource'] });
} }
} }
}, },
updateFrontendPerformanceMetrics(durationString, requestEntries) { updateFrontendPerformanceMetrics(durationString, summary, requestEntries) {
this.store.setRequestDetailsData(this.requestId, 'total', { this.store.setRequestDetailsData(this.requestId, 'total', {
duration: durationString, duration: durationString,
calls: requestEntries.length, calls: requestEntries.length,
details: requestEntries, details: requestEntries,
summaryOptions: {
hideDuration: true,
},
summary,
}); });
}, },
transformResourceEntry(entry) { transformResourceEntry(entry) {
const nf = new Intl.NumberFormat(); const nf = new Intl.NumberFormat();
return { return {
start: entry.startTime,
name: entry.name.replace(document.location.origin, ''), name: entry.name.replace(document.location.origin, ''),
duration: Math.round(entry.duration), duration: Math.round(entry.duration),
size: entry.transferSize ? `${nf.format(entry.transferSize)} bytes` : 'cached', size: entry.transferSize ? `${nf.format(entry.transferSize)} bytes` : 'cached',
......
...@@ -120,6 +120,86 @@ describe('detailedMetric', () => { ...@@ -120,6 +120,86 @@ describe('detailedMetric', () => {
}); });
}); });
describe('when the details have summaryOptions > hideTotal option', () => {
beforeEach(() => {
createComponent({
currentRequest: {
details: {
gitaly: {
duration: '123ms',
calls: 456,
details: requestDetails,
warnings: ['gitaly calls: 456 over 30'],
summaryOptions: {
hideTotal: true
}
},
},
},
});
});
it('displays a summary section', () => {
expect(findAllSummaryItems()).toEqual(['Total duration 123ms']);
});
});
describe('when the details have summaryOptions > hideDuration option', () => {
beforeEach(() => {
createComponent({
currentRequest: {
details: {
gitaly: {
duration: '123ms',
calls: 456,
details: requestDetails,
warnings: ['gitaly calls: 456 over 30'],
summaryOptions: {
hideDuration: true
}
},
},
},
});
});
it('displays a summary section', () => {
expect(findAllSummaryItems()).toEqual(['Total 456']);
});
});
describe('when the details have both summary and summaryOptions field', () => {
beforeEach(() => {
createComponent({
currentRequest: {
details: {
gitaly: {
duration: '123ms',
calls: 456,
details: requestDetails,
warnings: ['gitaly calls: 456 over 30'],
summary: {
'In controllers': 100,
'In middlewares': 20,
},
summaryOptions: {
hideDuration: true,
hideTotal: true
}
},
},
},
});
});
it('displays a summary section', () => {
expect(findAllSummaryItems()).toEqual([
'In controllers 100',
'In middlewares 20',
]);
});
});
describe("when the details don't have a start field", () => { describe("when the details don't have a start field", () => {
beforeEach(() => { beforeEach(() => {
createComponent({ createComponent({
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment