|
|
|
import * as chai from 'chai';
|
|
|
|
import chaiColors from 'chai-colors';
|
|
|
|
import * as d3 from 'd3';
|
|
|
|
|
|
|
|
import { initChart } from './c3-helper';
|
|
|
|
|
|
|
|
chai.use(chaiColors);
|
|
|
|
const expect = chai.expect;
|
|
|
|
|
|
|
|
describe('c3 api data', function () {
|
|
|
|
var chart;
|
|
|
|
|
|
|
|
var args = {
|
|
|
|
data: {
|
|
|
|
columns: [
|
|
|
|
['data1', 30, 200, 100, 400, 150, 250],
|
|
|
|
['data2', 5000, 2000, 1000, 4000, 1500, 2500]
|
|
|
|
],
|
|
|
|
names: {
|
|
|
|
data1: 'Data Name 1',
|
|
|
|
data2: 'Data Name 2'
|
|
|
|
},
|
|
|
|
colors: {
|
|
|
|
data1: '#FF0000',
|
|
|
|
data2: '#00FF00'
|
|
|
|
},
|
|
|
|
axes: {
|
|
|
|
data1: 'y',
|
|
|
|
data2: 'y2'
|
|
|
|
}
|
|
|
|
},
|
|
|
|
axis: {
|
|
|
|
y2: {
|
|
|
|
show: true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
beforeEach(function (done) {
|
|
|
|
chart = initChart(chart, args, done);
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('data()', function () {
|
|
|
|
it('should return all of data if no argument given', function () {
|
|
|
|
var results = chart.data(),
|
|
|
|
expected = ['data1', 'data2'];
|
|
|
|
results.forEach(function (result, i) {
|
|
|
|
expect(result.id).to.equal(expected[i]);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should return specifid data if string argument given', function () {
|
|
|
|
var results = chart.data('data1');
|
|
|
|
expect(results.length).to.equal(1);
|
|
|
|
expect(results[0].id).to.equal('data1');
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should return specifid data if array argument given', function () {
|
|
|
|
var results = chart.data(['data1', 'data2']);
|
|
|
|
expect(results.length).to.equal(2);
|
|
|
|
expect(results[0].id).to.equal('data1');
|
|
|
|
expect(results[1].id).to.equal('data2');
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('data.shown()', function () {
|
|
|
|
it('should return only shown targets', function () {
|
|
|
|
var results;
|
|
|
|
chart.hide('data1');
|
|
|
|
results = chart.data.shown();
|
|
|
|
expect(results.length).to.equal(1);
|
|
|
|
expect(results[0].id).to.equal('data2');
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('data.values()', function () {
|
|
|
|
it('should return values for specified target', function () {
|
|
|
|
var values = chart.data.values('data1'),
|
|
|
|
expectedValues = [30, 200, 100, 400, 150, 250];
|
|
|
|
expect(values.length).to.equal(6);
|
|
|
|
values.forEach(function (v, i) {
|
|
|
|
expect(v).to.equal(expectedValues[i]);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should return null when no args', function () {
|
|
|
|
var values = chart.data.values();
|
|
|
|
expect(values).to.be.null;
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('data.names()', function () {
|
|
|
|
it('should return data.names specified as argument', function () {
|
|
|
|
var results = chart.data.names();
|
|
|
|
expect(results.data1).to.equal('Data Name 1');
|
|
|
|
expect(results.data2).to.equal('Data Name 2');
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should return data.names specified as api', function () {
|
|
|
|
var results = chart.data.names({
|
|
|
|
data1: 'New Data Name 1',
|
|
|
|
data2: 'New Data Name 2'
|
|
|
|
});
|
|
|
|
expect(results.data1).to.equal('New Data Name 1');
|
|
|
|
expect(results.data2).to.equal('New Data Name 2');
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should set data.names specified as api', function () {
|
|
|
|
expect(d3.select('.c3-legend-item-data1 text').text()).to.equal('New Data Name 1');
|
|
|
|
expect(d3.select('.c3-legend-item-data2 text').text()).to.equal('New Data Name 2');
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('data.colors()', function () {
|
|
|
|
it('should return data.colors specified as argument', function () {
|
|
|
|
var results = chart.data.colors();
|
|
|
|
expect(results.data1).to.be.color('#FF0000');
|
|
|
|
expect(results.data2).to.be.color('#00FF00');
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should return data.colors specified as api', function () {
|
|
|
|
var results = chart.data.colors({
|
|
|
|
data1: '#00FF00',
|
|
|
|
data2: '#FF0000'
|
|
|
|
});
|
|
|
|
expect(results.data1).to.be.color('#00FF00');
|
|
|
|
expect(results.data2).to.be.color('#FF0000');
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should set data.colors specified as api', function () {
|
|
|
|
expect(d3.select('.c3-line-data1').style('stroke')).to.be.color('#00ff00');
|
|
|
|
expect(d3.select('.c3-line-data2').style('stroke')).to.be.color('#ff0000');
|
|
|
|
expect(d3.select('.c3-legend-item-data1 .c3-legend-item-tile').style('stroke')).to.be.color('#00ff00');
|
|
|
|
expect(d3.select('.c3-legend-item-data2 .c3-legend-item-tile').style('stroke')).to.be.color('#ff0000');
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('data.axes()', function () {
|
|
|
|
it('should return data.axes specified as argument', function () {
|
|
|
|
var results = chart.data.axes();
|
|
|
|
expect(results.data1).to.equal('y');
|
|
|
|
expect(results.data2).to.equal('y2');
|
|
|
|
expect(d3.select('.c3-axis-y g.tick text').text()).to.equal('0');
|
|
|
|
expect(d3.select('.c3-axis-y2 g.tick text').text()).to.equal('1000');
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should return data.axes specified as api', function () {
|
|
|
|
var results = chart.data.axes({
|
|
|
|
data1: 'y2',
|
|
|
|
data2: 'y'
|
|
|
|
});
|
|
|
|
expect(results.data1).to.equal('y2');
|
|
|
|
expect(results.data2).to.equal('y');
|
|
|
|
expect(d3.select('.c3-axis-y g.tick text').text()).to.equal('1000');
|
|
|
|
expect(d3.select('.c3-axis-y2 g.tick text').text()).to.equal('0');
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|