|
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471 |
-
-
- describe('Point element tests', function() {
- it ('Should be constructed', function() {
- var point = new Chart.elements.Point({
- _datasetIndex: 2,
- _index: 1
- });
-
- expect(point).not.toBe(undefined);
- expect(point._datasetIndex).toBe(2);
- expect(point._index).toBe(1);
- });
-
- it ('Should correctly identify as in range', function() {
- var point = new Chart.elements.Point({
- _datasetIndex: 2,
- _index: 1
- });
-
-
- expect(point.inRange(5)).toBe(false);
- expect(point.inLabelRange(5)).toBe(false);
-
-
- point._view = {
- radius: 2,
- hitRadius: 3,
- x: 10,
- y: 15
- };
-
- expect(point.inRange(10, 15)).toBe(true);
- expect(point.inRange(10, 10)).toBe(false);
- expect(point.inRange(10, 5)).toBe(false);
- expect(point.inRange(5, 5)).toBe(false);
-
- expect(point.inLabelRange(5)).toBe(false);
- expect(point.inLabelRange(7)).toBe(true);
- expect(point.inLabelRange(10)).toBe(true);
- expect(point.inLabelRange(12)).toBe(true);
- expect(point.inLabelRange(15)).toBe(false);
- expect(point.inLabelRange(20)).toBe(false);
- });
-
- it ('should get the correct tooltip position', function() {
- var point = new Chart.elements.Point({
- _datasetIndex: 2,
- _index: 1
- });
-
-
- point._view = {
- radius: 2,
- borderWidth: 6,
- x: 10,
- y: 15
- };
-
- expect(point.tooltipPosition()).toEqual({
- x: 10,
- y: 15,
- padding: 8
- });
- });
-
- it ('should draw correctly', function() {
- var mockContext = window.createMockContext();
- var point = new Chart.elements.Point({
- _datasetIndex: 2,
- _index: 1,
- _chart: {
- ctx: mockContext,
- }
- });
-
-
- point._view = {
- radius: 2,
- pointStyle: 'circle',
- hitRadius: 3,
- borderColor: 'rgba(1, 2, 3, 1)',
- borderWidth: 6,
- backgroundColor: 'rgba(0, 255, 0)',
- x: 10,
- y: 15,
- ctx: mockContext
- };
-
- point.draw();
-
- expect(mockContext.getCalls()).toEqual([{
- name: 'setStrokeStyle',
- args: ['rgba(1, 2, 3, 1)']
- }, {
- name: 'setLineWidth',
- args: [6]
- }, {
- name: 'setFillStyle',
- args: ['rgba(0, 255, 0)']
- }, {
- name: 'beginPath',
- args: []
- }, {
- name: 'arc',
- args: [10, 15, 2, 0, 2 * Math.PI]
- }, {
- name: 'closePath',
- args: [],
- }, {
- name: 'fill',
- args: [],
- }, {
- name: 'stroke',
- args: []
- }]);
-
- mockContext.resetCalls();
- point._view.pointStyle = 'triangle';
- point.draw();
-
- expect(mockContext.getCalls()).toEqual([{
- name: 'setStrokeStyle',
- args: ['rgba(1, 2, 3, 1)']
- }, {
- name: 'setLineWidth',
- args: [6]
- }, {
- name: 'setFillStyle',
- args: ['rgba(0, 255, 0)']
- }, {
- name: 'beginPath',
- args: []
- }, {
- name: 'moveTo',
- args: [10 - 3 * 2 / Math.sqrt(3) / 2, 15 + 3 * 2 / Math.sqrt(3) * Math.sqrt(3) / 2 / 3]
- }, {
- name: 'lineTo',
- args: [10 + 3 * 2 / Math.sqrt(3) / 2, 15 + 3 * 2 / Math.sqrt(3) * Math.sqrt(3) / 2 / 3],
- }, {
- name: 'lineTo',
- args: [10, 15 - 2 * 3 * 2 / Math.sqrt(3) * Math.sqrt(3) / 2 / 3],
- }, {
- name: 'closePath',
- args: [],
- }, {
- name: 'fill',
- args: [],
- }, {
- name: 'stroke',
- args: []
- }]);
-
- mockContext.resetCalls();
- point._view.pointStyle = 'rect';
- point.draw();
-
- expect(mockContext.getCalls()).toEqual([{
- name: 'setStrokeStyle',
- args: ['rgba(1, 2, 3, 1)']
- }, {
- name: 'setLineWidth',
- args: [6]
- }, {
- name: 'setFillStyle',
- args: ['rgba(0, 255, 0)']
- }, {
- name: 'fillRect',
- args: [10 - 1 / Math.SQRT2 * 2, 15 - 1 / Math.SQRT2 * 2, 2 / Math.SQRT2 * 2, 2 / Math.SQRT2 * 2]
- }, {
- name: 'strokeRect',
- args: [10 - 1 / Math.SQRT2 * 2, 15 - 1 / Math.SQRT2 * 2, 2 / Math.SQRT2 * 2, 2 / Math.SQRT2 * 2]
- }, {
- name: 'stroke',
- args: []
- }]);
-
- mockContext.resetCalls();
- point._view.pointStyle = 'rectRot';
- point.draw();
-
- expect(mockContext.getCalls()).toEqual([{
- name: 'setStrokeStyle',
- args: ['rgba(1, 2, 3, 1)']
- }, {
- name: 'setLineWidth',
- args: [6]
- }, {
- name: 'setFillStyle',
- args: ['rgba(0, 255, 0)']
- }, {
- name: 'beginPath',
- args: []
- }, {
- name: 'moveTo',
- args: [10 - 1 / Math.SQRT2 * 2, 15]
- }, {
- name: 'lineTo',
- args: [10, 15 + 1 / Math.SQRT2 * 2]
- }, {
- name: 'lineTo',
- args: [10 + 1 / Math.SQRT2 * 2, 15],
- }, {
- name: 'lineTo',
- args: [10, 15 - 1 / Math.SQRT2 * 2],
- }, {
- name: 'closePath',
- args: []
- }, {
- name: 'fill',
- args: [],
- }, {
- name: 'stroke',
- args: []
- }]);
-
- mockContext.resetCalls();
- point._view.pointStyle = 'cross';
- point.draw();
-
- expect(mockContext.getCalls()).toEqual([{
- name: 'setStrokeStyle',
- args: ['rgba(1, 2, 3, 1)']
- }, {
- name: 'setLineWidth',
- args: [6]
- }, {
- name: 'setFillStyle',
- args: ['rgba(0, 255, 0)']
- }, {
- name: 'beginPath',
- args: []
- }, {
- name: 'moveTo',
- args: [10, 17]
- }, {
- name: 'lineTo',
- args: [10, 13],
- }, {
- name: 'moveTo',
- args: [8, 15],
- }, {
- name: 'lineTo',
- args: [12, 15],
- },{
- name: 'closePath',
- args: [],
- }, {
- name: 'stroke',
- args: []
- }]);
-
- mockContext.resetCalls();
- point._view.pointStyle = 'crossRot';
- point.draw();
-
- expect(mockContext.getCalls()).toEqual([{
- name: 'setStrokeStyle',
- args: ['rgba(1, 2, 3, 1)']
- }, {
- name: 'setLineWidth',
- args: [6]
- }, {
- name: 'setFillStyle',
- args: ['rgba(0, 255, 0)']
- }, {
- name: 'beginPath',
- args: []
- }, {
- name: 'moveTo',
- args: [10 - Math.cos(Math.PI / 4) * 2, 15 - Math.sin(Math.PI / 4) * 2]
- }, {
- name: 'lineTo',
- args: [10 + Math.cos(Math.PI / 4) * 2, 15 + Math.sin(Math.PI / 4) * 2],
- }, {
- name: 'moveTo',
- args: [10 - Math.cos(Math.PI / 4) * 2, 15 + Math.sin(Math.PI / 4) * 2],
- }, {
- name: 'lineTo',
- args: [10 + Math.cos(Math.PI / 4) * 2, 15 - Math.sin(Math.PI / 4) * 2],
- }, {
- name: 'closePath',
- args: [],
- }, {
- name: 'stroke',
- args: []
- }]);
-
- mockContext.resetCalls();
- point._view.pointStyle = 'star';
- point.draw();
-
- expect(mockContext.getCalls()).toEqual([{
- name: 'setStrokeStyle',
- args: ['rgba(1, 2, 3, 1)']
- }, {
- name: 'setLineWidth',
- args: [6]
- }, {
- name: 'setFillStyle',
- args: ['rgba(0, 255, 0)']
- }, {
- name: 'beginPath',
- args: []
- }, {
- name: 'moveTo',
- args: [10, 17]
- }, {
- name: 'lineTo',
- args: [10, 13],
- }, {
- name: 'moveTo',
- args: [8, 15],
- }, {
- name: 'lineTo',
- args: [12, 15],
- },{
- name: 'moveTo',
- args: [10 - Math.cos(Math.PI / 4) * 2, 15 - Math.sin(Math.PI / 4) * 2]
- }, {
- name: 'lineTo',
- args: [10 + Math.cos(Math.PI / 4) * 2, 15 + Math.sin(Math.PI / 4) * 2],
- }, {
- name: 'moveTo',
- args: [10 - Math.cos(Math.PI / 4) * 2, 15 + Math.sin(Math.PI / 4) * 2],
- }, {
- name: 'lineTo',
- args: [10 + Math.cos(Math.PI / 4) * 2, 15 - Math.sin(Math.PI / 4) * 2],
- }, {
- name: 'closePath',
- args: [],
- }, {
- name: 'stroke',
- args: []
- }]);
-
- mockContext.resetCalls();
- point._view.pointStyle = 'line';
- point.draw();
-
- expect(mockContext.getCalls()).toEqual([{
- name: 'setStrokeStyle',
- args: ['rgba(1, 2, 3, 1)']
- }, {
- name: 'setLineWidth',
- args: [6]
- }, {
- name: 'setFillStyle',
- args: ['rgba(0, 255, 0)']
- }, {
- name: 'beginPath',
- args: []
- }, {
- name: 'moveTo',
- args: [8, 15]
- }, {
- name: 'lineTo',
- args: [12, 15],
- }, {
- name: 'closePath',
- args: [],
- }, {
- name: 'stroke',
- args: []
- }]);
-
- mockContext.resetCalls();
- point._view.pointStyle = 'dash';
- point.draw();
-
- expect(mockContext.getCalls()).toEqual([{
- name: 'setStrokeStyle',
- args: ['rgba(1, 2, 3, 1)']
- }, {
- name: 'setLineWidth',
- args: [6]
- }, {
- name: 'setFillStyle',
- args: ['rgba(0, 255, 0)']
- }, {
- name: 'beginPath',
- args: []
- }, {
- name: 'moveTo',
- args: [10, 15]
- }, {
- name: 'lineTo',
- args: [12, 15],
- }, {
- name: 'closePath',
- args: [],
- }, {
- name: 'stroke',
- args: []
- }]);
-
- });
-
- it ('should draw correctly with default settings if necessary', function() {
- var mockContext = window.createMockContext();
- var point = new Chart.elements.Point({
- _datasetIndex: 2,
- _index: 1,
- _chart: {
- ctx: mockContext,
- }
- });
-
-
- point._view = {
- radius: 2,
- hitRadius: 3,
- x: 10,
- y: 15,
- ctx: mockContext
- };
-
- point.draw();
-
- expect(mockContext.getCalls()).toEqual([{
- name: 'setStrokeStyle',
- args: ['rgba(0,0,0,0.1)']
- }, {
- name: 'setLineWidth',
- args: [1]
- }, {
- name: 'setFillStyle',
- args: ['rgba(0,0,0,0.1)']
- }, {
- name: 'beginPath',
- args: []
- }, {
- name: 'arc',
- args: [10, 15, 2, 0, 2 * Math.PI]
- }, {
- name: 'closePath',
- args: [],
- }, {
- name: 'fill',
- args: [],
- }, {
- name: 'stroke',
- args: []
- }]);
- });
-
- it ('should not draw if skipped', function() {
- var mockContext = window.createMockContext();
- var point = new Chart.elements.Point({
- _datasetIndex: 2,
- _index: 1,
- _chart: {
- ctx: mockContext,
- }
- });
-
-
- point._view = {
- radius: 2,
- hitRadius: 3,
- x: 10,
- y: 15,
- ctx: mockContext,
- skip: true
- };
-
- point.draw();
-
- expect(mockContext.getCalls()).toEqual([]);
- });
- });
|