Skip to content

Commit

Permalink
Decimation: Prevent buffer overflow (#9367)
Browse files Browse the repository at this point in the history
  • Loading branch information
kurkle committed Jul 7, 2021
1 parent 8405996 commit 066130b
Show file tree
Hide file tree
Showing 2 changed files with 37 additions and 1 deletion.
2 changes: 1 addition & 1 deletion src/plugins/plugin.decimation.js
Expand Up @@ -46,7 +46,7 @@ function lttbDecimation(data, start, count, availableWidth, options) {

// Adding offset
const rangeOffs = Math.floor(i * bucketWidth) + 1 + start;
const rangeTo = Math.floor((i + 1) * bucketWidth) + 1 + start;
const rangeTo = Math.min(Math.floor((i + 1) * bucketWidth) + 1, count) + start;
const {x: pointAx, y: pointAy} = data[a];

// Note that this is changed from the original algorithm which initializes these
Expand Down
36 changes: 36 additions & 0 deletions test/specs/plugin.decimation.tests.js
Expand Up @@ -179,5 +179,41 @@ describe('Plugin.decimation', function() {
expect(chart.data.datasets[0].data[3].x).toBe(originalData[5].x);
expect(chart.data.datasets[0].data[4].x).toBe(originalData[6].x);
});

it('should not crash with uneven points', function() {
const data = [];
for (let i = 0; i < 15552; i++) {
data.push({x: i, y: i});
}

function createChart() {
return window.acquireChart({
type: 'line',
data: {
datasets: [{
data
}]
},
options: {
devicePixelRatio: 1.25,
parsing: false,
scales: {
x: {
type: 'linear'
}
},
plugins: {
decimation: {
enabled: true,
algorithm: 'lttb'
}
}
}
}, {
canvas: {width: 511, height: 511},
});
}
expect(createChart).not.toThrow();
});
});
});

0 comments on commit 066130b

Please sign in to comment.