mirror of
https://gitee.com/element-plus/element-plus.git
synced 2024-12-14 09:20:51 +08:00
b0646b3767
* refactor: radio script setup * refactor: radio script setup
420 lines
12 KiB
TypeScript
420 lines
12 KiB
TypeScript
import { nextTick } from 'vue'
|
|
import { mount } from '@vue/test-utils'
|
|
import { describe, expect, it, test } from 'vitest'
|
|
import { ElFormItem } from '@element-plus/components/form'
|
|
import Radio from '../src/radio.vue'
|
|
import RadioGroup from '../src/radio-group.vue'
|
|
import RadioButton from '../src/radio-button.vue'
|
|
|
|
const _mount = (template: string, data, otherObj?) =>
|
|
mount({
|
|
components: {
|
|
'el-radio': Radio,
|
|
'el-radio-group': RadioGroup,
|
|
'el-radio-button': RadioButton,
|
|
'el-form-item': ElFormItem,
|
|
},
|
|
template,
|
|
data,
|
|
...otherObj,
|
|
})
|
|
|
|
describe('Radio', () => {
|
|
test('create', async () => {
|
|
const wrapper = _mount(
|
|
`<el-radio v-model="radio" label="a">
|
|
</el-radio>`,
|
|
() => ({ radio: '' })
|
|
)
|
|
expect(wrapper.classes()).toContain('el-radio')
|
|
await wrapper.trigger('click')
|
|
expect(wrapper.classes()).toContain('is-checked')
|
|
})
|
|
|
|
test('disabled', async () => {
|
|
const wrapper = _mount(
|
|
`<el-radio
|
|
v-model="radio"
|
|
label="3"
|
|
disabled
|
|
>
|
|
</el-radio>`,
|
|
() => ({ radio: '' })
|
|
)
|
|
await wrapper.trigger('click')
|
|
const vm = wrapper.vm as any
|
|
expect(vm.radio).toBe('')
|
|
expect(wrapper.classes()).toContain('is-disabled')
|
|
})
|
|
|
|
test('border', () => {
|
|
const wrapper = _mount(
|
|
`<el-radio
|
|
v-model="radio"
|
|
label="3"
|
|
border
|
|
>
|
|
</el-radio>`,
|
|
() => ({ radio: '' })
|
|
)
|
|
expect(wrapper.classes()).toContain('is-bordered')
|
|
})
|
|
|
|
test('change event', async () => {
|
|
const wrapper = _mount(
|
|
`<el-radio
|
|
v-model="radio"
|
|
label="3"
|
|
@change="handleChange"
|
|
>
|
|
</el-radio>`,
|
|
() => ({
|
|
radio: '',
|
|
changeData: '',
|
|
}),
|
|
{
|
|
methods: {
|
|
handleChange(val) {
|
|
this.changeData = val
|
|
},
|
|
},
|
|
}
|
|
)
|
|
const vm = wrapper.vm as any
|
|
await wrapper.trigger('click')
|
|
await nextTick()
|
|
expect(vm.changeData).toEqual('3')
|
|
})
|
|
|
|
test('change event only triggers on user input', async () => {
|
|
const wrapper = _mount(
|
|
`<el-radio
|
|
v-model="radio"
|
|
label="3"
|
|
@change="handleChange"
|
|
>
|
|
</el-radio>`,
|
|
() => ({
|
|
radio: '',
|
|
changeData: '',
|
|
}),
|
|
{
|
|
methods: {
|
|
handleChange(val) {
|
|
this.changeData = val
|
|
},
|
|
},
|
|
}
|
|
)
|
|
const vm = wrapper.vm as any
|
|
vm.radio = '3'
|
|
await nextTick()
|
|
expect(vm.changeData).toEqual('')
|
|
expect(vm.radio).toEqual('3')
|
|
})
|
|
})
|
|
|
|
describe('Radio group', () => {
|
|
it('create', async () => {
|
|
const wrapper = _mount(
|
|
`<el-radio-group v-model="radio">
|
|
<el-radio :label="3" ref="radio1">3</el-radio>
|
|
<el-radio :label="6" ref="radio2">6</el-radio>
|
|
<el-radio :label="9">9</el-radio>
|
|
</el-radio-group>`,
|
|
() => ({
|
|
radio: 3,
|
|
})
|
|
)
|
|
const radio1 = wrapper.findComponent({ ref: 'radio1' })
|
|
expect(radio1.classes()).toContain('is-checked')
|
|
const radio2 = wrapper.findComponent({ ref: 'radio2' })
|
|
await radio2.trigger('click')
|
|
expect(radio2.classes()).toContain('is-checked')
|
|
const vm = wrapper.vm as any
|
|
expect(vm.radio).toEqual(6)
|
|
})
|
|
|
|
it('disabled', async () => {
|
|
const wrapper = _mount(
|
|
`<el-radio-group v-model="radio" disabled>
|
|
<el-radio :label="3" ref="radio1">3</el-radio>
|
|
<el-radio :label="6" ref="radio2">6</el-radio>
|
|
<el-radio :label="9">7</el-radio>
|
|
</el-radio-group>`,
|
|
() => ({
|
|
radio: 3,
|
|
})
|
|
)
|
|
|
|
expect(wrapper.find('label.is-disabled').exists()).toBe(true)
|
|
const radio1 = wrapper.findComponent({ ref: 'radio1' })
|
|
expect(radio1.classes()).toContain('is-checked')
|
|
const radio2 = wrapper.findComponent({ ref: 'radio2' })
|
|
await radio2.trigger('click')
|
|
const vm = wrapper.vm as any
|
|
expect(vm.radio).toEqual(3)
|
|
expect(radio1.classes()).toContain('is-checked')
|
|
})
|
|
it('change event', async () => {
|
|
const wrapper = _mount(
|
|
`<el-radio-group v-model="radio" @change="onChange">
|
|
<el-radio :label="3">3</el-radio>
|
|
<el-radio :label="6" ref="radio2">6</el-radio>
|
|
<el-radio :label="9">9</el-radio>
|
|
</el-radio-group>`,
|
|
() => ({
|
|
radio: 3,
|
|
data: 0,
|
|
}),
|
|
{
|
|
methods: {
|
|
onChange(val) {
|
|
this.data = val
|
|
},
|
|
},
|
|
}
|
|
)
|
|
|
|
const radio2 = wrapper.findComponent({ ref: 'radio2' })
|
|
await radio2.trigger('click')
|
|
await nextTick()
|
|
const vm = wrapper.vm as any
|
|
expect(vm.data).toEqual(6)
|
|
})
|
|
it('change event only triggers on user input', async () => {
|
|
const wrapper = _mount(
|
|
`<el-radio-group v-model="radio" @change="onChange">
|
|
<el-radio :label="3">3</el-radio>
|
|
<el-radio :label="6" ref="radio2">6</el-radio>
|
|
<el-radio :label="9">9</el-radio>
|
|
</el-radio-group>`,
|
|
() => ({
|
|
radio: 3,
|
|
data: 0,
|
|
}),
|
|
{
|
|
methods: {
|
|
onChange(val) {
|
|
this.data = val
|
|
},
|
|
},
|
|
}
|
|
)
|
|
const vm = wrapper.vm as any
|
|
vm.radio = 6
|
|
await nextTick()
|
|
expect(vm.data).toEqual(0)
|
|
})
|
|
it('disabled when children is radio button', async () => {
|
|
const wrapper = _mount(
|
|
`<el-radio-group v-model="radio" disabled>
|
|
<el-radio-button :label="3" ref="radio1">3</el-radio-button>
|
|
<el-radio-button :label="6" ref="radio2">6</el-radio-button>
|
|
<el-radio-button :label="9">9</el-radio-button>
|
|
</el-radio-group>`,
|
|
() => ({
|
|
radio: 3,
|
|
})
|
|
)
|
|
|
|
const radio1 = wrapper.findComponent({ ref: 'radio1' })
|
|
const radio2 = wrapper.findComponent({ ref: 'radio2' })
|
|
expect(radio1.classes()).toContain('is-active')
|
|
expect(wrapper.findAll('.is-disabled').length).toBe(3)
|
|
await radio2.trigger('click')
|
|
const vm = wrapper.vm as any
|
|
expect(vm.radio).toEqual(3)
|
|
expect(radio1.classes()).toContain('is-active')
|
|
})
|
|
})
|
|
|
|
describe('Radio Button', () => {
|
|
it('create', async () => {
|
|
const wrapper = _mount(
|
|
`<el-radio-group v-model="radio">
|
|
<el-radio-button :label="3" ref="radio1">3</el-radio-button>
|
|
<el-radio-button :label="6" ref="radio2">6</el-radio-button>
|
|
<el-radio-button :label="9">9</el-radio-button>
|
|
</el-radio-group>`,
|
|
() => ({
|
|
radio: 3,
|
|
})
|
|
)
|
|
const radio1 = wrapper.findComponent({ ref: 'radio1' })
|
|
expect(radio1.classes()).toContain('is-active')
|
|
const radio2 = wrapper.findComponent({ ref: 'radio2' })
|
|
await radio2.trigger('click')
|
|
expect(radio2.classes()).toContain('is-active')
|
|
const vm = wrapper.vm as any
|
|
expect(vm.radio).toEqual(6)
|
|
})
|
|
it('custom color', () => {
|
|
const wrapper = _mount(
|
|
`<el-radio-group v-model="radio" fill="#000" text-color="#ff0">
|
|
<el-radio-button :label="3" ref="radio1">3</el-radio-button>
|
|
<el-radio-button :label="6" ref="radio2">6</el-radio-button>
|
|
<el-radio-button :label="9">9</el-radio-button>
|
|
</el-radio-group>`,
|
|
() => ({
|
|
radio: 3,
|
|
})
|
|
)
|
|
const radio1 = wrapper.findComponent({ ref: 'radio1' })
|
|
expect(radio1.find('span').attributes('style')).toContain(
|
|
'background-color: rgb(0, 0, 0); border-color: #000; box-shadow: -1px 0 0 0 #000; color: rgb(255, 255, 0);'
|
|
)
|
|
})
|
|
it('change event', async () => {
|
|
const wrapper = _mount(
|
|
`<el-radio-group v-model="radio" @change="onChange">
|
|
<el-radio-button :label="3">3</el-radio-button>
|
|
<el-radio-button :label="6" ref="radio2">6</el-radio-button>
|
|
<el-radio-button :label="9">9</el-radio-button>
|
|
</el-radio-group>`,
|
|
() => ({
|
|
data: 0,
|
|
radio: 3,
|
|
}),
|
|
{
|
|
methods: {
|
|
onChange(val) {
|
|
this.data = val
|
|
},
|
|
},
|
|
}
|
|
)
|
|
const radio2 = wrapper.findComponent({ ref: 'radio2' })
|
|
await radio2.trigger('click')
|
|
const vm = wrapper.vm as any
|
|
expect(vm.radio).toEqual(6)
|
|
})
|
|
it('change event only triggers on user input', async () => {
|
|
const wrapper = _mount(
|
|
`<el-radio-group v-model="radio" @change="onChange">
|
|
<el-radio-button :label="3">3</el-radio-button>
|
|
<el-radio-button :label="6" ref="radio2">6</el-radio-button>
|
|
<el-radio-button :label="9">9</el-radio-button>
|
|
</el-radio-group>`,
|
|
() => ({
|
|
data: 0,
|
|
radio: 3,
|
|
}),
|
|
{
|
|
methods: {
|
|
onChange(val) {
|
|
this.data = val
|
|
},
|
|
},
|
|
}
|
|
)
|
|
const vm = wrapper.vm as any
|
|
vm.radio = 6
|
|
await nextTick()
|
|
expect(vm.data).toEqual(0)
|
|
})
|
|
|
|
it('size', () => {
|
|
const wrapper = _mount(
|
|
`<el-radio-group v-model="radio" size="large">
|
|
<el-radio-button :label="3" ref="radio1">3</el-radio-button>
|
|
<el-radio-button :label="6" ref="radio2">6</el-radio-button>
|
|
<el-radio-button :label="9">9</el-radio-button>
|
|
</el-radio-group>`,
|
|
() => ({
|
|
radio: 3,
|
|
})
|
|
)
|
|
expect(wrapper.findAll('.el-radio-button--large').length).toBe(3)
|
|
})
|
|
|
|
describe('form item accessibility integration', () => {
|
|
test('single radio group in form item', async () => {
|
|
const wrapper = _mount(
|
|
`
|
|
<el-form-item ref="item" label="Test">
|
|
<el-radio-group ref="radioGroup">
|
|
<el-radio label="Foo" />
|
|
<el-radio label="Bar" />
|
|
</el-radio-group>
|
|
</el-form-item>
|
|
`,
|
|
() => ({})
|
|
)
|
|
await nextTick()
|
|
const formItem = await wrapper.findComponent({ ref: 'item' })
|
|
const radioGroup = await wrapper.findComponent({
|
|
ref: 'radioGroup',
|
|
})
|
|
const formItemLabel = formItem.find('.el-form-item__label')
|
|
expect(formItem.attributes().role).toBeFalsy()
|
|
expect(radioGroup.attributes().role).toBe('radiogroup')
|
|
expect(formItemLabel.attributes().for).toBe(radioGroup.attributes().id)
|
|
expect(formItemLabel.attributes().id).toBe(
|
|
radioGroup.attributes()['aria-labelledby']
|
|
)
|
|
})
|
|
|
|
test('single radio group in form item, override label', async () => {
|
|
const wrapper = _mount(
|
|
`
|
|
<el-form-item ref="item" label="Test">
|
|
<el-radio-group label="Foo" ref="radioGroup">
|
|
<el-radio label="Foo" />
|
|
<el-radio label="Bar" />
|
|
</el-radio-group>
|
|
</el-form-item>
|
|
`,
|
|
() => ({})
|
|
)
|
|
await nextTick()
|
|
const formItem = await wrapper.findComponent({ ref: 'item' })
|
|
const radioGroup = await wrapper.findComponent({
|
|
ref: 'radioGroup',
|
|
})
|
|
const formItemLabel = formItem.find('.el-form-item__label')
|
|
expect(formItemLabel.attributes().for).toBe(radioGroup.attributes().id)
|
|
expect(radioGroup.attributes().role).toBe('radiogroup')
|
|
expect(radioGroup.attributes()['aria-label']).toBe('Foo')
|
|
expect(radioGroup.attributes()['aria-labelledby']).toBeFalsy()
|
|
})
|
|
|
|
test('multiple radio groups in form item', async () => {
|
|
const wrapper = _mount(
|
|
`
|
|
<el-form-item ref="item" label="Test">
|
|
<el-radio-group label="Foo" ref="radioGroup1">
|
|
<el-radio label="Foo" />
|
|
<el-radio label="Bar" />
|
|
</el-radio-group>
|
|
<el-radio-group label="Bar" ref="radioGroup2">
|
|
<el-radio label="Foo" />
|
|
<el-radio label="Bar" />
|
|
</el-radio-group>
|
|
</el-form-item>
|
|
`,
|
|
() => ({})
|
|
)
|
|
await nextTick()
|
|
const formItem = await wrapper.findComponent({ ref: 'item' })
|
|
const radioGroup1 = await wrapper.findComponent({
|
|
ref: 'radioGroup1',
|
|
})
|
|
const radioGroup2 = await wrapper.findComponent({
|
|
ref: 'radioGroup2',
|
|
})
|
|
const formItemLabel = formItem.find('.el-form-item__label')
|
|
expect(formItem.attributes().role).toBe('group')
|
|
expect(formItem.attributes()['aria-labelledby']).toBe(
|
|
formItemLabel.attributes().id
|
|
)
|
|
expect(radioGroup1.attributes().role).toBe('radiogroup')
|
|
expect(radioGroup1.attributes()['aria-label']).toBe('Foo')
|
|
expect(radioGroup1.attributes()['aria-labelledby']).toBeFalsy()
|
|
expect(radioGroup2.attributes().role).toBe('radiogroup')
|
|
expect(radioGroup2.attributes()['aria-label']).toBe('Bar')
|
|
expect(radioGroup2.attributes()['aria-labelledby']).toBeFalsy()
|
|
})
|
|
})
|
|
})
|