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.
121 lines
4.0 KiB
121 lines
4.0 KiB
var expect = require('chai').expect; |
|
|
|
describe('c3 api grid', function () { |
|
|
|
|
|
var chart, args; |
|
|
|
beforeEach(function (done) { |
|
chart = window.initChart(chart, args, done); |
|
}); |
|
|
|
describe('ygrid.add and ygrid.remove', function () { |
|
|
|
it('should update args', function () { |
|
args = { |
|
data: { |
|
columns: [ |
|
['data1', 30, 200, 100, 400, 150, 250] |
|
] |
|
} |
|
}; |
|
|
|
}); |
|
|
|
it('should update y grids', function (done) { |
|
var main = chart.internal.main, |
|
expectedGrids = [ |
|
{ |
|
value: 100, |
|
text: 'Pressure Low' |
|
}, |
|
{ |
|
value: 200, |
|
text: 'Pressure High' |
|
} |
|
], |
|
grids; |
|
|
|
// Call ygrids.add |
|
chart.ygrids.add(expectedGrids); |
|
setTimeout(function () { |
|
grids = main.selectAll('.c3-ygrid-line'); |
|
expect(grids.size()).to.equal(expectedGrids.length); |
|
grids.each(function (d, i) { |
|
var y = +d3.select(this).select('line').attr('y1'), |
|
text = d3.select(this).select('text').text(), |
|
expectedY = Math.round(chart.internal.y(expectedGrids[i].value)), |
|
expectedText = expectedGrids[i].text; |
|
expect(y).to.equal(expectedY); |
|
expect(text).to.equal(expectedText); |
|
}); |
|
|
|
// Call ygrids.remove |
|
chart.ygrids.remove(expectedGrids); |
|
setTimeout(function () { |
|
grids = main.selectAll('.c3-ygrid-line'); |
|
expect(grids.size()).to.equal(0); |
|
}, 500); |
|
|
|
}, 500); |
|
|
|
setTimeout(function () { |
|
done(); |
|
}, 1200); |
|
}); |
|
|
|
it("should update x ygrids even if it's zoomed", function (done) { |
|
var main = chart.internal.main, |
|
expectedGrids = [ |
|
{ |
|
value: 0, |
|
text: 'Pressure Low' |
|
}, |
|
{ |
|
value: 1, |
|
text: 'Pressure High' |
|
} |
|
], |
|
grids, domain; |
|
|
|
chart.zoom([0, 2]); |
|
setTimeout(function () { |
|
|
|
// Call xgrids |
|
chart.xgrids(expectedGrids); |
|
setTimeout(function () { |
|
grids = main.selectAll('.c3-xgrid-line'); |
|
expect(grids.size()).to.equal(expectedGrids.length); |
|
grids.each(function (d, i) { |
|
var x = +d3.select(this).select('line').attr('x1'), |
|
text = d3.select(this).select('text').text(), |
|
expectedX = Math.round(chart.internal.x(expectedGrids[i].value)), |
|
expectedText = expectedGrids[i].text; |
|
expect(x).to.equal(expectedX); |
|
expect(text).to.equal(expectedText); |
|
}); |
|
|
|
// check if it was not rescaled |
|
domain = chart.internal.y.domain(); |
|
expect(domain[0]).to.be.below(0); |
|
expect(domain[1]).to.be.above(400); |
|
|
|
// Call xgrids.remove |
|
chart.xgrids.remove(expectedGrids); |
|
setTimeout(function () { |
|
grids = main.selectAll('.c3-xgrid-line'); |
|
expect(grids.size()).to.equal(0); |
|
}, 500); // for xgrids.remove() |
|
|
|
}, 500); // for xgrids() |
|
|
|
}, 500); // for zoom |
|
|
|
setTimeout(function () { |
|
done(); |
|
}, 1700); |
|
}); |
|
|
|
}); |
|
|
|
});
|
|
|