mirror of https://github.com/masayuki0812/c3.git
Quite good looking graph derived from d3.js
http://c3js.org
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
160 lines
4.4 KiB
160 lines
4.4 KiB
var expect = require('chai').expect; |
|
|
|
describe('c3 chart', function () { |
|
|
|
|
|
var chart; |
|
|
|
var args = { |
|
svg: { |
|
classname: 'customclass' |
|
}, |
|
data: { |
|
columns: [ |
|
['data1', 30, 200, 100, 400, 150, 250], |
|
['data2', 50, 20, 10, 40, 15, 25], |
|
['data3', 150, 120, 110, 140, 115, 125] |
|
] |
|
} |
|
}; |
|
|
|
beforeEach(function (done) { |
|
chart = window.initChart(chart, args, done); |
|
}); |
|
|
|
describe('init', function () { |
|
|
|
it('should be created', function () { |
|
var svg = d3.select('#chart svg'); |
|
expect(svg).not.to.be.null; |
|
}); |
|
|
|
it('should set 3rd party property to Function', function () { |
|
Function.prototype.$extIsFunction = true; |
|
|
|
}); |
|
|
|
it('should be created even if 3rd party property has been set', function () { |
|
var svg = d3.select('#chart svg'); |
|
expect(svg).not.to.be.null; |
|
}); |
|
|
|
it('should be created with a custom class', function () { |
|
var svg = d3.select('#chart svg'); |
|
expect(svg.attr('class')).not.to.be.null; |
|
expect(svg.attr('class')).to.equal('customclass'); |
|
}); |
|
}); |
|
|
|
describe('size', function () { |
|
|
|
it('should have same width', function () { |
|
var svg = d3.select('#chart svg'); |
|
expect(+svg.attr('width')).to.equal(640); |
|
}); |
|
|
|
it('should have same height', function () { |
|
var svg = d3.select('#chart svg'); |
|
expect(+svg.attr('height')).to.equal(480); |
|
}); |
|
|
|
}); |
|
|
|
describe('bindto', function () { |
|
|
|
describe('selector', function () { |
|
it('update args', function () { |
|
d3.select('#chart').html(''); |
|
args.bindto = '#chart'; |
|
|
|
}); |
|
it('should be created', function () { |
|
var svg = d3.select('#chart svg'); |
|
expect(svg.size()).to.equal(1); |
|
}); |
|
}); |
|
|
|
describe('d3.selection object', function () { |
|
it('update args', function () { |
|
d3.select('#chart').html(''); |
|
args.bindto = d3.select('#chart'); |
|
|
|
}); |
|
it('should be created', function () { |
|
var svg = d3.select('#chart svg'); |
|
expect(svg.size()).to.equal(1); |
|
}); |
|
}); |
|
|
|
describe('null', function () { |
|
it('update args', function () { |
|
d3.select('#chart').html(''); |
|
args.bindto = null; |
|
|
|
}); |
|
it('should not be created', function () { |
|
var svg = d3.select('#chart svg'); |
|
expect(svg.size()).to.equal(0); |
|
}); |
|
}); |
|
|
|
describe('empty string', function () { |
|
it('update args', function () { |
|
d3.select('#chart').html(''); |
|
args.bindto = ''; |
|
|
|
}); |
|
it('should not be created', function () { |
|
var svg = d3.select('#chart svg'); |
|
expect(svg.size()).to.equal(0); |
|
}); |
|
}); |
|
|
|
}); |
|
|
|
describe('empty data', function () { |
|
|
|
it('should upaate args for empty data', function () { |
|
args = { |
|
data: { |
|
columns: [ |
|
['data1'], |
|
['data2'] |
|
] |
|
} |
|
}; |
|
|
|
}); |
|
|
|
it('should generate a chart', function () { |
|
var ticks = chart.internal.main.select('.c3-axis-x').selectAll('g.tick'); |
|
expect(ticks.size()).to.equal(0); |
|
}); |
|
|
|
it('should upaate args for empty data', function () { |
|
args = { |
|
data: { |
|
x: 'x', |
|
columns: [ |
|
['x'], |
|
['data1'], |
|
['data2'] |
|
] |
|
}, |
|
axis: { |
|
x: { |
|
type: 'timeseries' |
|
} |
|
} |
|
}; |
|
|
|
}); |
|
|
|
it('should generate a chart', function () { |
|
var ticks = chart.internal.main.select('.c3-axis-x').selectAll('g.tick'); |
|
expect(ticks.size()).to.equal(0); |
|
}); |
|
|
|
}); |
|
|
|
});
|
|
|