mirror of
https://github.com/chartjs/Chart.js.git
synced 2024-10-07 04:39:06 +02:00
c216c0af76
`karma.conf.ci.js` has been merged into `karma.conf.js` for local testing consistency: `gulp unittestWatch` has been replaced by `gulp unittest --watch` and thus use exactly the same config file. Upgrade to latest jasmine and karma packages and remove deprecated `gulp-karma` dependency (directly use `karma.Server` in gulp). Split `test/mockContext.js` into smaller `test/jasmine.*` modules to make easier unit tests maintenance and finally, move all `*.test.js` files under the `test/specs` folder.
273 lines
5.4 KiB
JavaScript
273 lines
5.4 KiB
JavaScript
// Test the rectangle element
|
|
|
|
describe('Title block tests', function() {
|
|
it('Should be constructed', function() {
|
|
var title = new Chart.Title({});
|
|
expect(title).not.toBe(undefined);
|
|
});
|
|
|
|
it('Should have the correct default config', function() {
|
|
expect(Chart.defaults.global.title).toEqual({
|
|
display: false,
|
|
position: 'top',
|
|
fullWidth: true,
|
|
fontStyle: 'bold',
|
|
padding: 10,
|
|
text: ''
|
|
});
|
|
});
|
|
|
|
it('should update correctly', function() {
|
|
var chart = {};
|
|
|
|
var options = Chart.helpers.clone(Chart.defaults.global.title);
|
|
options.text = 'My title';
|
|
|
|
var title = new Chart.Title({
|
|
chart: chart,
|
|
options: options
|
|
});
|
|
|
|
var minSize = title.update(400, 200);
|
|
|
|
expect(minSize).toEqual({
|
|
width: 400,
|
|
height: 0
|
|
});
|
|
|
|
// Now we have a height since we display
|
|
title.options.display = true;
|
|
|
|
minSize = title.update(400, 200);
|
|
|
|
expect(minSize).toEqual({
|
|
width: 400,
|
|
height: 32
|
|
});
|
|
});
|
|
|
|
it('should update correctly when vertical', function() {
|
|
var chart = {};
|
|
|
|
var options = Chart.helpers.clone(Chart.defaults.global.title);
|
|
options.text = 'My title';
|
|
options.position = 'left';
|
|
|
|
var title = new Chart.Title({
|
|
chart: chart,
|
|
options: options
|
|
});
|
|
|
|
var minSize = title.update(200, 400);
|
|
|
|
expect(minSize).toEqual({
|
|
width: 0,
|
|
height: 400
|
|
});
|
|
|
|
// Now we have a height since we display
|
|
title.options.display = true;
|
|
|
|
minSize = title.update(200, 400);
|
|
|
|
expect(minSize).toEqual({
|
|
width: 32,
|
|
height: 400
|
|
});
|
|
});
|
|
|
|
it('should draw correctly horizontally', function() {
|
|
var chart = {};
|
|
var context = window.createMockContext();
|
|
|
|
var options = Chart.helpers.clone(Chart.defaults.global.title);
|
|
options.text = 'My title';
|
|
|
|
var title = new Chart.Title({
|
|
chart: chart,
|
|
options: options,
|
|
ctx: context
|
|
});
|
|
|
|
title.update(400, 200);
|
|
title.draw();
|
|
|
|
expect(context.getCalls()).toEqual([]);
|
|
|
|
// Now we have a height since we display
|
|
title.options.display = true;
|
|
|
|
var minSize = title.update(400, 200);
|
|
title.top = 50;
|
|
title.left = 100;
|
|
title.bottom = title.top + minSize.height;
|
|
title.right = title.left + minSize.width;
|
|
title.draw();
|
|
|
|
expect(context.getCalls()).toEqual([{
|
|
name: 'setFillStyle',
|
|
args: ['#666']
|
|
}, {
|
|
name: 'save',
|
|
args: []
|
|
}, {
|
|
name: 'translate',
|
|
args: [300, 66]
|
|
}, {
|
|
name: 'rotate',
|
|
args: [0]
|
|
}, {
|
|
name: 'fillText',
|
|
args: ['My title', 0, 0, 400]
|
|
}, {
|
|
name: 'restore',
|
|
args: []
|
|
}]);
|
|
});
|
|
|
|
it ('should draw correctly vertically', function() {
|
|
var chart = {};
|
|
var context = window.createMockContext();
|
|
|
|
var options = Chart.helpers.clone(Chart.defaults.global.title);
|
|
options.text = 'My title';
|
|
options.position = 'left';
|
|
|
|
var title = new Chart.Title({
|
|
chart: chart,
|
|
options: options,
|
|
ctx: context
|
|
});
|
|
|
|
title.update(200, 400);
|
|
title.draw();
|
|
|
|
expect(context.getCalls()).toEqual([]);
|
|
|
|
// Now we have a height since we display
|
|
title.options.display = true;
|
|
|
|
var minSize = title.update(200, 400);
|
|
title.top = 50;
|
|
title.left = 100;
|
|
title.bottom = title.top + minSize.height;
|
|
title.right = title.left + minSize.width;
|
|
title.draw();
|
|
|
|
expect(context.getCalls()).toEqual([{
|
|
name: 'setFillStyle',
|
|
args: ['#666']
|
|
}, {
|
|
name: 'save',
|
|
args: []
|
|
}, {
|
|
name: 'translate',
|
|
args: [106, 250]
|
|
}, {
|
|
name: 'rotate',
|
|
args: [-0.5 * Math.PI]
|
|
}, {
|
|
name: 'fillText',
|
|
args: ['My title', 0, 0, 400]
|
|
}, {
|
|
name: 'restore',
|
|
args: []
|
|
}]);
|
|
|
|
// Rotation is other way on right side
|
|
title.options.position = 'right';
|
|
|
|
// Reset call tracker
|
|
context.resetCalls();
|
|
|
|
minSize = title.update(200, 400);
|
|
title.top = 50;
|
|
title.left = 100;
|
|
title.bottom = title.top + minSize.height;
|
|
title.right = title.left + minSize.width;
|
|
title.draw();
|
|
|
|
expect(context.getCalls()).toEqual([{
|
|
name: 'setFillStyle',
|
|
args: ['#666']
|
|
}, {
|
|
name: 'save',
|
|
args: []
|
|
}, {
|
|
name: 'translate',
|
|
args: [126, 250]
|
|
}, {
|
|
name: 'rotate',
|
|
args: [0.5 * Math.PI]
|
|
}, {
|
|
name: 'fillText',
|
|
args: ['My title', 0, 0, 400]
|
|
}, {
|
|
name: 'restore',
|
|
args: []
|
|
}]);
|
|
});
|
|
|
|
describe('config update', function() {
|
|
it ('should update the options', function() {
|
|
var chart = acquireChart({
|
|
type: 'line',
|
|
data: {
|
|
labels: ['A', 'B', 'C', 'D'],
|
|
datasets: [{
|
|
data: [10, 20, 30, 100]
|
|
}]
|
|
},
|
|
options: {
|
|
title: {
|
|
display: true
|
|
}
|
|
}
|
|
});
|
|
expect(chart.titleBlock.options.display).toBe(true);
|
|
|
|
chart.options.title.display = false;
|
|
chart.update();
|
|
expect(chart.titleBlock.options.display).toBe(false);
|
|
});
|
|
|
|
it ('should remove the title if the new options are false', function() {
|
|
var chart = acquireChart({
|
|
type: 'line',
|
|
data: {
|
|
labels: ['A', 'B', 'C', 'D'],
|
|
datasets: [{
|
|
data: [10, 20, 30, 100]
|
|
}]
|
|
}
|
|
});
|
|
expect(chart.titleBlock).not.toBe(undefined);
|
|
|
|
chart.options.title = false;
|
|
chart.update();
|
|
expect(chart.titleBlock).toBe(undefined);
|
|
});
|
|
|
|
it ('should create the title if the title options are changed to exist', function() {
|
|
var chart = acquireChart({
|
|
type: 'line',
|
|
data: {
|
|
labels: ['A', 'B', 'C', 'D'],
|
|
datasets: [{
|
|
data: [10, 20, 30, 100]
|
|
}]
|
|
},
|
|
options: {
|
|
title: false
|
|
}
|
|
});
|
|
expect(chart.titleBlock).toBe(undefined);
|
|
|
|
chart.options.title = {};
|
|
chart.update();
|
|
expect(chart.titleBlock).not.toBe(undefined);
|
|
expect(chart.titleBlock.options).toEqual(jasmine.objectContaining(Chart.defaults.global.title));
|
|
});
|
|
});
|
|
});
|