oe-build-perf-report: Add commit hash link to chart tooltip

Update tooltip to include the commit hash link to the poky repository

(From OE-Core rev: 1187a460c2608369df8de08fe52a5542e4ab6ecd)

Signed-off-by: Ninette Adhikari <ninette@thehoodiefirm.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
This commit is contained in:
Ninette Adhikari 2024-05-22 16:52:52 +02:00 committed by Richard Purdie
parent 5f602c1bd5
commit f66f8fa9f6
2 changed files with 15 additions and 13 deletions

View File

@ -2,7 +2,7 @@
// Get raw data
const rawData = [
{% for sample in measurement.samples %}
[{{ sample.commit_num }}, {{ sample.mean.gv_value() }}, {{ sample.start_time }}],
[{{ sample.commit_num }}, {{ sample.mean.gv_value() }}, {{ sample.start_time }}, '{{sample.commit}}'],
{% endfor %}
];
@ -30,23 +30,23 @@
const option = {
tooltip: {
trigger: 'axis',
valueFormatter: (value) => {
const commitNumber = rawData.filter(([commit, dataValue, time]) => updateValue(dataValue) === value)
enterable: true,
position: function (point, params, dom, rect, size) {
return [point[0]-150, '10%'];
},
formatter: function (param) {
const value = param[0].value[1]
const sample = rawData.filter(([commit, dataValue]) => updateValue(dataValue) === value)
// Add commit hash to the tooltip as a link
const commitLink = `https://git.yoctoproject.org/poky/commit/?id=${sample[0][3]}`
if ('{{ measurement.value_type.quantity }}' == 'time') {
const hours = Math.floor(value/60)
const minutes = Math.floor(value % 60)
const seconds = Math.floor((value * 60) % 60)
return [
hours + ':' + minutes + ':' + seconds + ', ' +
'commit number: ' + commitNumber[0][0]
]
return `<strong>Duration:</strong> ${hours}:${minutes}:${seconds}, <br/> <strong>Commit number:</strong> <a href="${commitLink}" target="_blank" rel="noreferrer noopener">${sample[0][0]}</a>`
}
return [
value.toFixed(2) + ' MB' + ', ' +
'commit number: ' + commitNumber[0][0]
]
},
return `<strong>Size:</strong> ${value.toFixed(2)} MB, <br/> <strong>Commit number:</strong> <a href="${commitLink}" target="_blank" rel="noreferrer noopener">${sample[0][0]}</a>`
;}
},
xAxis: {
type: 'time',

View File

@ -336,10 +336,12 @@ def print_html_report(data, id_comp, buildstats):
test_i = test_data['tests'][test]
meas_i = test_i['measurements'][meas]
commit_num = get_data_item(meta, 'layers.meta.commit_count')
commit = get_data_item(meta, 'layers.meta.commit')
# Add start_time for both test measurement types of sysres and disk usage
start_time = test_i['start_time'][0]
samples.append(measurement_stats(meas_i, '', start_time))
samples[-1]['commit_num'] = commit_num
samples[-1]['commit'] = commit
absdiff = samples[-1]['val_cls'](samples[-1]['mean'] - samples[id_comp]['mean'])
reldiff = absdiff * 100 / samples[id_comp]['mean']