pull/22/head
tjz 2018-05-18 21:10:11 +08:00
commit a965fb1ac0
7 changed files with 189 additions and 0 deletions

View File

@ -0,0 +1,14 @@
import { mount } from '@vue/test-utils'
import Avatar from '..'
describe('Avatar Render', () => {
it('Render long string correctly', () => {
const wrapper = mount(Avatar, {
slots: {
default: 'TestString',
},
})
const children = wrapper.findAll('.ant-avatar-string')
expect(children.length).toBe(1)
})
})

View File

@ -0,0 +1,21 @@
import { mount } from '@vue/test-utils'
import Badge from '../index'
describe('Badge', () => {
test('badge dot not scaling count > 9', () => {
const badge = mount({
render () {
return <Badge count={10} dot />
},
})
expect(badge.findAll('.ant-card-multiple-words').length).toBe(0)
})
test('badge dot not showing count == 0', () => {
const badge = mount({
render () {
return <Badge count={0} dot />
},
})
expect(badge.findAll('.ant-badge-dot').length).toBe(0)
})
})

View File

@ -0,0 +1,3 @@
// Jest Snapshot v1, https://goo.gl/fbAQLP
exports[`Icon should render to a <i class="xxx"></i> 1`] = `<i class="anticon anticon-appstore my-icon-classname"></i>`;

View File

@ -0,0 +1,13 @@
import { mount } from '@vue/test-utils'
import Icon from '..'
describe('Icon', () => {
it('should render to a <i class="xxx"></i>', () => {
const wrapper = mount({
render (h) {
return <Icon type='appstore' class='my-icon-classname' />
},
})
expect(wrapper.html()).toMatchSnapshot()
})
})

View File

@ -0,0 +1,63 @@
import { mount } from '@vue/test-utils'
import Vue from 'vue'
import Modal from '..'
const ModalTester = {
props: ['footer', 'visible'],
methods: {
getContainer () {
return this.$refs.container
},
},
render () {
const modalProps = {
props: {
...this.$props,
getContainer: this.getContainer,
},
}
return (
<div>
<div ref='container' />
<Modal
{...modalProps}
>
Here is content of Modal
</Modal>
</div>
)
},
}
describe('Modal', () => {
it('render correctly', (done) => {
const wrapper = mount(
{
render () {
return <ModalTester visible />
},
}
)
expect(wrapper.html()).toMatchSnapshot()
// https://github.com/vuejs/vue-test-utils/issues/624
const wrapper1 = mount(ModalTester, {
sync: false,
})
wrapper1.setProps({ visible: true })
Vue.nextTick(() => {
expect(wrapper1.html()).toMatchSnapshot()
done()
})
})
it('render without footer', () => {
const wrapper = mount(
{
render () {
return <ModalTester visible footer={null} />
},
}
)
expect(wrapper.html()).toMatchSnapshot()
})
})

View File

@ -0,0 +1,73 @@
// Jest Snapshot v1, https://goo.gl/fbAQLP
exports[`Modal render correctly 1`] = `
<div>
<div>
<div>
<div class="ant-modal-mask"></div>
<div tabindex="-1" role="dialog" class="ant-modal-wrap ">
<div role="document" class="ant-modal" style="width: 520px;">
<div class="ant-modal-content">
<button aria-label="Close" class="ant-modal-close"><span class="ant-modal-close-x"></span></button>
<div class="ant-modal-body">Here is content of Modal</div>
<div class="ant-modal-footer">
<div>
<button type="button" class="ant-btn ant-btn-default"><span>Cancel</span></button>
<button type="button" class="ant-btn ant-btn-primary"><span>OK</span></button>
</div>
</div>
</div>
<div tabindex="0" style="width: 0px; height: 0px; overflow: hidden;">sentinel</div>
</div>
</div>
</div>
</div>
<!---->
</div>
`;
exports[`Modal render correctly 2`] = `
<div>
<div>
<div>
<div class="ant-modal-mask"></div>
<div tabindex="-1" role="dialog" class="ant-modal-wrap ">
<div role="document" class="ant-modal" style="width: 520px;">
<div class="ant-modal-content">
<button aria-label="Close" class="ant-modal-close"><span class="ant-modal-close-x"></span></button>
<div class="ant-modal-body">Here is content of Modal</div>
<div class="ant-modal-footer">
<div>
<button type="button" class="ant-btn ant-btn-default"><span>Cancel</span></button>
<button type="button" class="ant-btn ant-btn-primary"><span>OK</span></button>
</div>
</div>
</div>
<div tabindex="0" style="width: 0px; height: 0px; overflow: hidden;">sentinel</div>
</div>
</div>
</div>
</div>
<!---->
</div>
`;
exports[`Modal render without footer 1`] = `
<div>
<div>
<div>
<div class="ant-modal-mask"></div>
<div tabindex="-1" role="dialog" class="ant-modal-wrap ">
<div role="document" class="ant-modal" style="width: 520px;">
<div class="ant-modal-content">
<button aria-label="Close" class="ant-modal-close"><span class="ant-modal-close-x"></span></button>
<div class="ant-modal-body">Here is content of Modal</div>
</div>
<div tabindex="0" style="width: 0px; height: 0px; overflow: hidden;">sentinel</div>
</div>
</div>
</div>
</div>
<!---->
</div>
`;

View File

@ -1,3 +1,5 @@
// import Vue from 'vue'
// Vue.config.silent = true
/* eslint-disable global-require */
if (typeof window !== 'undefined') {