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.
339 lines
9.1 KiB
339 lines
9.1 KiB
1 year ago
|
import { d3, initChart } from './c3-helper'
|
||
|
|
||
|
describe('c3 api data', function() {
|
||
|
'use strict'
|
||
|
|
||
|
var chart
|
||
|
|
||
|
var args: any = {
|
||
|
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) {
|
||
|
jasmine.addMatchers(customMatchers as any)
|
||
|
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).toBe(expected[i])
|
||
|
})
|
||
|
})
|
||
|
|
||
|
it('should return specified data if string argument given', function() {
|
||
|
var results = chart.data('data1')
|
||
|
expect(results.length).toBe(1)
|
||
|
expect(results[0].id).toBe('data1')
|
||
|
})
|
||
|
|
||
|
it('should return specified data if array argument given', function() {
|
||
|
var results = chart.data(['data1', 'data2'])
|
||
|
expect(results.length).toBe(2)
|
||
|
expect(results[0].id).toBe('data1')
|
||
|
expect(results[1].id).toBe('data2')
|
||
|
})
|
||
|
})
|
||
|
|
||
|
describe('data.shown()', function() {
|
||
|
it('should return only shown targets', function() {
|
||
|
var results
|
||
|
chart.hide('data1')
|
||
|
results = chart.data.shown()
|
||
|
expect(results.length).toBe(1)
|
||
|
expect(results[0].id).toBe('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).toBe(6)
|
||
|
values.forEach(function(v, i) {
|
||
|
expect(v).toBe(expectedValues[i])
|
||
|
})
|
||
|
})
|
||
|
|
||
|
it('should return null when no args', function() {
|
||
|
var values = chart.data.values()
|
||
|
expect(values).toBeNull()
|
||
|
})
|
||
|
})
|
||
|
|
||
|
describe('data.names()', function() {
|
||
|
it('should return data.names specified as argument', function() {
|
||
|
var results = chart.data.names()
|
||
|
expect(results.data1).toBe('Data Name 1')
|
||
|
expect(results.data2).toBe('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).toBe('New Data Name 1')
|
||
|
expect(results.data2).toBe('New Data Name 2')
|
||
|
})
|
||
|
|
||
|
it('should set data.names specified as api', function() {
|
||
|
expect(d3.select('.c3-legend-item-data1 text').text()).toBe(
|
||
|
'New Data Name 1'
|
||
|
)
|
||
|
expect(d3.select('.c3-legend-item-data2 text').text()).toBe(
|
||
|
'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) as any).toBeHexOrRGB('#FF0000')
|
||
|
;(expect(results.data2) as any).toBeHexOrRGB('#00FF00')
|
||
|
})
|
||
|
|
||
|
it('should return data.colors specified as api', function() {
|
||
|
var results = chart.data.colors({
|
||
|
data1: '#00FF00',
|
||
|
data2: '#FF0000'
|
||
|
})
|
||
|
;(expect(results.data1) as any).toBeHexOrRGB('#00FF00')
|
||
|
;(expect(results.data2) as any).toBeHexOrRGB('#FF0000')
|
||
|
})
|
||
|
|
||
|
it('should set data.colors specified as api', function() {
|
||
|
;(expect(
|
||
|
d3.select('.c3-line-data1').style('stroke')
|
||
|
) as any).toBeHexOrRGB('#00ff00')
|
||
|
;(expect(
|
||
|
d3.select('.c3-line-data2').style('stroke')
|
||
|
) as any).toBeHexOrRGB('#ff0000')
|
||
|
;(expect(
|
||
|
d3.select('.c3-legend-item-data1 .c3-legend-item-tile').style('stroke')
|
||
|
) as any).toBeHexOrRGB('#00ff00')
|
||
|
;(expect(
|
||
|
d3.select('.c3-legend-item-data2 .c3-legend-item-tile').style('stroke')
|
||
|
) as any).toBeHexOrRGB('#ff0000')
|
||
|
})
|
||
|
})
|
||
|
|
||
|
describe('data.axes()', function() {
|
||
|
it('should return data.axes specified as argument', function() {
|
||
|
var results = chart.data.axes()
|
||
|
expect(results.data1).toBe('y')
|
||
|
expect(results.data2).toBe('y2')
|
||
|
expect(d3.select('.c3-axis-y g.tick text').text()).toBe('0')
|
||
|
expect(d3.select('.c3-axis-y2 g.tick text').text()).toBe('1000')
|
||
|
})
|
||
|
|
||
|
it('should return data.axes specified as api', function() {
|
||
|
var results = chart.data.axes({
|
||
|
data1: 'y2',
|
||
|
data2: 'y'
|
||
|
})
|
||
|
expect(results.data1).toBe('y2')
|
||
|
expect(results.data2).toBe('y')
|
||
|
expect(d3.select('.c3-axis-y g.tick text').text()).toBe('1000')
|
||
|
expect(d3.select('.c3-axis-y2 g.tick text').text()).toBe('0')
|
||
|
})
|
||
|
})
|
||
|
|
||
|
describe('data.stackNormalized()', function() {
|
||
|
beforeEach(function(done) {
|
||
|
args = {
|
||
|
data: {
|
||
|
columns: [
|
||
|
['data1', 30, 200, 100, 400, 150, 250],
|
||
|
['data2', 500, 850, 1000, 200, 350, 100]
|
||
|
],
|
||
|
groups: [['data1', 'data2']],
|
||
|
stack: {
|
||
|
normalize: true
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
chart = initChart(chart, args, done)
|
||
|
})
|
||
|
|
||
|
it('can toggle option', function(done) {
|
||
|
expect(chart.data.stackNormalized()).toBe(true)
|
||
|
expect(chart.internal.y.domain()).toEqual([0, 100])
|
||
|
|
||
|
chart.data.stackNormalized(false)
|
||
|
|
||
|
setTimeout(function() {
|
||
|
expect(chart.data.stackNormalized()).toBe(false)
|
||
|
expect(chart.internal.y.domain()).toEqual([0, 1200])
|
||
|
done()
|
||
|
}, 100)
|
||
|
})
|
||
|
})
|
||
|
})
|
||
|
|
||
|
describe('c3 api data.x', function() {
|
||
|
'use strict'
|
||
|
|
||
|
var chart
|
||
|
|
||
|
var args = {
|
||
|
data: {
|
||
|
x: 'x',
|
||
|
columns: [
|
||
|
['x', 10, 30, 45, 50, 70, 100],
|
||
|
['data1', 30, 200, 100, 400, 150, 250],
|
||
|
['data2', 20, 180, 240, 100, 190]
|
||
|
]
|
||
|
}
|
||
|
}
|
||
|
|
||
|
beforeEach(function(done) {
|
||
|
chart = initChart(chart, args, done)
|
||
|
})
|
||
|
|
||
|
it('should return values for target data1', function() {
|
||
|
var values = chart.data.values('data1'),
|
||
|
expectedValues = [30, 200, 100, 400, 150, 250]
|
||
|
expect(values.length).toBe(6)
|
||
|
values.forEach(function(v, i) {
|
||
|
expect(v).toBe(expectedValues[i])
|
||
|
})
|
||
|
})
|
||
|
|
||
|
it('should return null when no args', function() {
|
||
|
var values = chart.data.values()
|
||
|
expect(values).toBeNull()
|
||
|
})
|
||
|
|
||
|
it('should return data values for data if string argument given', function() {
|
||
|
var results = chart.data('data1')
|
||
|
expect(results.length).toBe(1)
|
||
|
expect(results[0].id).toBe('data1')
|
||
|
})
|
||
|
|
||
|
it('should return specified data if array argument given', function() {
|
||
|
var results = chart.data(['data1', 'data2'])
|
||
|
expect(results.length).toBe(2)
|
||
|
expect(results[0].id).toBe('data1')
|
||
|
expect(results[1].id).toBe('data2')
|
||
|
})
|
||
|
})
|
||
|
|
||
|
describe('c3 api data.xs', function() {
|
||
|
'use strict'
|
||
|
|
||
|
var chart
|
||
|
|
||
|
var args = {
|
||
|
data: {
|
||
|
xs: {
|
||
|
data1: 'x1',
|
||
|
data2: 'x2'
|
||
|
},
|
||
|
columns: [
|
||
|
['x1', 10, 30, 45, 50, 70, 100],
|
||
|
['x2', 30, 50, 75, 100, 120],
|
||
|
['data1', 30, 200, 100, 400, 150, 250],
|
||
|
['data2', 20, 180, 240, 100, 190]
|
||
|
]
|
||
|
}
|
||
|
}
|
||
|
|
||
|
beforeEach(function(done) {
|
||
|
chart = initChart(chart, args, done)
|
||
|
})
|
||
|
|
||
|
it('should return values for target data1', function() {
|
||
|
var values = chart.data.values('data1'),
|
||
|
expectedValues = [30, 200, 100, 400, 150, 250]
|
||
|
expect(values.length).toBe(6)
|
||
|
values.forEach(function(v, i) {
|
||
|
expect(v).toBe(expectedValues[i])
|
||
|
})
|
||
|
})
|
||
|
|
||
|
it('should return null when no args', function() {
|
||
|
var values = chart.data.values()
|
||
|
expect(values).toBeNull()
|
||
|
})
|
||
|
|
||
|
it('should return data values for data if string argument given', function() {
|
||
|
var results = chart.data('data1')
|
||
|
expect(results.length).toBe(1)
|
||
|
expect(results[0].id).toBe('data1')
|
||
|
})
|
||
|
|
||
|
it('should return specified data if array argument given', function() {
|
||
|
var results = chart.data(['data1', 'data2'])
|
||
|
expect(results.length).toBe(2)
|
||
|
expect(results[0].id).toBe('data1')
|
||
|
expect(results[1].id).toBe('data2')
|
||
|
})
|
||
|
})
|
||
|
|
||
|
var customMatchers = {
|
||
|
toBeHexOrRGB: function(util, customEqualityTesters) {
|
||
|
'use strict'
|
||
|
|
||
|
function rgb2hex(rgb) {
|
||
|
rgb = rgb.match(
|
||
|
/^rgba?[\s+]?\([\s+]?(\d+)[\s+]?,[\s+]?(\d+)[\s+]?,[\s+]?(\d+)[\s+]?/i
|
||
|
)
|
||
|
return rgb && rgb.length === 4
|
||
|
? '#' +
|
||
|
('0' + parseInt(rgb[1], 10).toString(16)).slice(-2) +
|
||
|
('0' + parseInt(rgb[2], 10).toString(16)).slice(-2) +
|
||
|
('0' + parseInt(rgb[3], 10).toString(16)).slice(-2)
|
||
|
: ''
|
||
|
}
|
||
|
|
||
|
return {
|
||
|
compare: function(actual, expected) {
|
||
|
if (expected === undefined) {
|
||
|
expected = ''
|
||
|
}
|
||
|
|
||
|
var result: any = {}
|
||
|
actual = actual.match('rgb') ? rgb2hex(actual) : actual
|
||
|
expected = expected.match('rgb') ? rgb2hex(expected) : expected
|
||
|
|
||
|
result.pass = util.equals(actual, expected, customEqualityTesters)
|
||
|
if (result.pass) {
|
||
|
result.message = 'Expected ' + actual + ' not to be quite so goofy'
|
||
|
} else {
|
||
|
result.message =
|
||
|
'Expected ' + actual + ' to be goofy, but it was not very goofy'
|
||
|
}
|
||
|
|
||
|
return result
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|