2015-08-29 18:31:44 +02:00
|
|
|
// Test the rectangle element
|
|
|
|
|
|
|
|
describe('Arc element tests', function() {
|
|
|
|
it ('should determine if in range', function() {
|
2019-12-27 23:13:24 +01:00
|
|
|
// Mock out the arc as if the controller put it there
|
2020-10-20 14:18:56 +02:00
|
|
|
var arc = new Chart.elements.ArcElement({
|
2015-08-29 18:31:44 +02:00
|
|
|
startAngle: 0,
|
|
|
|
endAngle: Math.PI / 2,
|
|
|
|
x: 0,
|
|
|
|
y: 0,
|
|
|
|
innerRadius: 5,
|
|
|
|
outerRadius: 10,
|
2019-12-27 23:13:24 +01:00
|
|
|
});
|
2015-08-29 18:31:44 +02:00
|
|
|
|
|
|
|
expect(arc.inRange(2, 2)).toBe(false);
|
|
|
|
expect(arc.inRange(7, 0)).toBe(true);
|
|
|
|
expect(arc.inRange(0, 11)).toBe(false);
|
|
|
|
expect(arc.inRange(Math.sqrt(32), Math.sqrt(32))).toBe(true);
|
|
|
|
expect(arc.inRange(-1.0 * Math.sqrt(7), Math.sqrt(7))).toBe(false);
|
|
|
|
});
|
|
|
|
|
2020-02-25 20:35:32 +01:00
|
|
|
it ('should determine if in range, when full circle', function() {
|
|
|
|
// Mock out the arc as if the controller put it there
|
2020-10-20 14:18:56 +02:00
|
|
|
var arc = new Chart.elements.ArcElement({
|
2020-02-25 20:35:32 +01:00
|
|
|
startAngle: -Math.PI,
|
|
|
|
endAngle: Math.PI * 1.5,
|
|
|
|
x: 0,
|
|
|
|
y: 0,
|
|
|
|
innerRadius: 0,
|
|
|
|
outerRadius: 10,
|
|
|
|
circumference: Math.PI * 2
|
|
|
|
});
|
|
|
|
|
|
|
|
expect(arc.inRange(7, 7)).toBe(true);
|
|
|
|
});
|
|
|
|
|
2015-08-29 18:31:44 +02:00
|
|
|
it ('should get the tooltip position', function() {
|
2019-12-27 23:13:24 +01:00
|
|
|
// Mock out the arc as if the controller put it there
|
2020-10-20 14:18:56 +02:00
|
|
|
var arc = new Chart.elements.ArcElement({
|
2015-08-29 18:31:44 +02:00
|
|
|
startAngle: 0,
|
|
|
|
endAngle: Math.PI / 2,
|
|
|
|
x: 0,
|
|
|
|
y: 0,
|
|
|
|
innerRadius: 0,
|
|
|
|
outerRadius: Math.sqrt(2),
|
2019-12-27 23:13:24 +01:00
|
|
|
});
|
2015-08-29 18:31:44 +02:00
|
|
|
|
|
|
|
var pos = arc.tooltipPosition();
|
|
|
|
expect(pos.x).toBeCloseTo(0.5);
|
|
|
|
expect(pos.y).toBeCloseTo(0.5);
|
|
|
|
});
|
|
|
|
|
2016-10-03 22:05:21 +02:00
|
|
|
it ('should get the center', function() {
|
2019-12-27 23:13:24 +01:00
|
|
|
// Mock out the arc as if the controller put it there
|
2020-10-20 14:18:56 +02:00
|
|
|
var arc = new Chart.elements.ArcElement({
|
2016-10-03 22:05:21 +02:00
|
|
|
startAngle: 0,
|
|
|
|
endAngle: Math.PI / 2,
|
|
|
|
x: 0,
|
|
|
|
y: 0,
|
|
|
|
innerRadius: 0,
|
|
|
|
outerRadius: Math.sqrt(2),
|
2019-12-27 23:13:24 +01:00
|
|
|
});
|
2016-10-03 22:05:21 +02:00
|
|
|
|
|
|
|
var center = arc.getCenterPoint();
|
|
|
|
expect(center.x).toBeCloseTo(0.5, 6);
|
|
|
|
expect(center.y).toBeCloseTo(0.5, 6);
|
|
|
|
});
|
2020-12-14 23:13:03 +01:00
|
|
|
|
|
|
|
it('should not draw when radius < 0', function() {
|
|
|
|
var ctx = window.createMockContext();
|
|
|
|
|
|
|
|
var arc = new Chart.elements.ArcElement({
|
|
|
|
startAngle: 0,
|
|
|
|
endAngle: Math.PI / 2,
|
|
|
|
x: 0,
|
|
|
|
y: 0,
|
|
|
|
innerRadius: -0.1,
|
|
|
|
outerRadius: Math.sqrt(2),
|
|
|
|
options: {}
|
|
|
|
});
|
|
|
|
|
|
|
|
arc.draw(ctx);
|
|
|
|
|
|
|
|
expect(ctx.getCalls().length).toBe(0);
|
|
|
|
|
|
|
|
arc = new Chart.elements.ArcElement({
|
|
|
|
startAngle: 0,
|
|
|
|
endAngle: Math.PI / 2,
|
|
|
|
x: 0,
|
|
|
|
y: 0,
|
|
|
|
innerRadius: 0,
|
|
|
|
outerRadius: -1,
|
|
|
|
options: {}
|
|
|
|
});
|
|
|
|
|
|
|
|
arc.draw(ctx);
|
|
|
|
|
|
|
|
expect(ctx.getCalls().length).toBe(0);
|
|
|
|
});
|
2016-10-16 23:34:59 +02:00
|
|
|
});
|