mirror of
https://github.com/KevinMidboe/vue-chartjs.git
synced 2025-10-29 18:00:20 +00:00
106 lines
2.4 KiB
JavaScript
106 lines
2.4 KiB
JavaScript
import Vue from 'vue'
|
|
import PieChart from '@/examples/PieExample'
|
|
|
|
describe('PieChart', () => {
|
|
let el
|
|
|
|
beforeEach(() => {
|
|
el = document.createElement('div')
|
|
})
|
|
|
|
it('should render a canvas', () => {
|
|
const vm = new Vue({
|
|
render: function (createElement) {
|
|
return createElement(
|
|
PieChart
|
|
)
|
|
},
|
|
components: { PieChart }
|
|
}).$mount(el)
|
|
|
|
expect(vm.$el.querySelector('#pie-chart')).not.to.be.an('undefined')
|
|
expect(vm.$el.querySelector('canvas')).not.to.be.an('undefined')
|
|
expect(vm.$el.querySelector('canvas')).not.to.be.an('null')
|
|
expect(vm.$el.querySelector('canvas')).to.exist
|
|
})
|
|
|
|
it('should change id based on prop', () => {
|
|
const vm = new Vue({
|
|
render: function (createElement) {
|
|
return createElement(
|
|
PieChart, {
|
|
props: {
|
|
chartId: 'piechartprop'
|
|
}
|
|
}
|
|
)
|
|
},
|
|
components: { PieChart }
|
|
}).$mount(el)
|
|
|
|
expect(vm.$el.querySelector('#piechartprop')).not.to.be.an('undefined')
|
|
})
|
|
it('should destroy chart instance', (done) => {
|
|
const vm = new Vue({
|
|
render: function (createElement) {
|
|
return createElement(
|
|
PieChart
|
|
)
|
|
},
|
|
components: { PieChart }
|
|
}).$mount(el)
|
|
|
|
expect(vm.$children[0].$data._chart.chart.ctx).not.to.be.null
|
|
|
|
vm.$destroy()
|
|
|
|
vm.$nextTick(() => {
|
|
vm.$forceUpdate()
|
|
expect(vm.$children[0].$data._chart.chart.ctx).to.be.null
|
|
done()
|
|
})
|
|
})
|
|
|
|
it('should add an inline plugin to the array', () => {
|
|
const testPlugin = {
|
|
id: 'test'
|
|
}
|
|
|
|
const vm = new Vue({
|
|
render: function (createElement) {
|
|
return createElement(
|
|
PieChart
|
|
)
|
|
},
|
|
components: { PieChart }
|
|
}).$mount(el)
|
|
|
|
expect(vm.$children[0].$data._plugins).to.exist
|
|
vm.$children[0].addPlugin(testPlugin)
|
|
|
|
expect(vm.$children[0].$data._plugins.length).to.equal(1)
|
|
})
|
|
|
|
it('should add inline plugins based on prop', () => {
|
|
const testPlugin = {
|
|
id: 'test'
|
|
}
|
|
|
|
const vm = new Vue({
|
|
render: function (createElement) {
|
|
return createElement(
|
|
PieChart, {
|
|
props: {
|
|
plugins: [testPlugin]
|
|
}
|
|
}
|
|
)
|
|
},
|
|
components: { PieChart }
|
|
}).$mount(el)
|
|
|
|
expect(vm.$children[0].$data._plugins).to.exist
|
|
expect(vm.$children[0].$data._plugins.length).to.equal(1)
|
|
})
|
|
})
|