mirror of
https://gitee.com/element-plus/element-plus.git
synced 2024-11-30 02:08:12 +08:00
c2710d97d0
* fix(components): [loading] * Remove inappropriate way of using injection in directives. * chore: rewrite implementation * fix(components): [global-config] * Fix global config injection in global components. * chore: fix format * chore: remove .only modifier * chore: fix failing tests
98 lines
2.5 KiB
TypeScript
98 lines
2.5 KiB
TypeScript
import { computed, defineComponent, nextTick } from 'vue'
|
|
import { mount } from '@vue/test-utils'
|
|
import { afterEach, beforeEach, describe, expect, it } from 'vitest'
|
|
import Chinese from '@element-plus/locale/lang/zh-cn'
|
|
import English from '@element-plus/locale/lang/en'
|
|
import { provideGlobalConfig } from '@element-plus/components/config-provider'
|
|
import { buildTranslator, useLocale } from '../use-locale'
|
|
import type { Language } from '@element-plus/locale'
|
|
import type { ComponentPublicInstance, PropType } from 'vue'
|
|
import type { VueWrapper } from '@vue/test-utils'
|
|
|
|
const TestComp = defineComponent({
|
|
setup() {
|
|
const { t } = useLocale()
|
|
return () => (
|
|
<div class="locale-manifest">{t('el.popconfirm.confirmButtonText')}</div>
|
|
)
|
|
},
|
|
})
|
|
|
|
describe('use-locale', () => {
|
|
let wrapper: VueWrapper<ComponentPublicInstance>
|
|
|
|
beforeEach(() => {
|
|
wrapper = mount(
|
|
defineComponent({
|
|
props: {
|
|
locale: {
|
|
type: Object as PropType<Language>,
|
|
default: Chinese,
|
|
},
|
|
},
|
|
setup(props) {
|
|
provideGlobalConfig(computed(() => ({ locale: props.locale })))
|
|
return () => <TestComp />
|
|
},
|
|
})
|
|
)
|
|
})
|
|
|
|
afterEach(() => {
|
|
wrapper.unmount()
|
|
})
|
|
|
|
it('should provide locale correctly', async () => {
|
|
await nextTick()
|
|
expect(wrapper.find('.locale-manifest').text()).toBe(
|
|
Chinese.el.popconfirm.confirmButtonText
|
|
)
|
|
})
|
|
|
|
it('should update the text reactively', async () => {
|
|
await nextTick()
|
|
expect(wrapper.find('.locale-manifest').text()).toBe(
|
|
Chinese.el.popconfirm.confirmButtonText
|
|
)
|
|
await wrapper.setProps({
|
|
locale: English,
|
|
})
|
|
|
|
expect(wrapper.find('.locale-manifest').text()).toBe(
|
|
English.el.popconfirm.confirmButtonText
|
|
)
|
|
})
|
|
|
|
it('return key name if not defined', () => {
|
|
const t = buildTranslator(English)
|
|
expect(t('el.popconfirm.someThing')).toBe('el.popconfirm.someThing')
|
|
})
|
|
|
|
describe('overrides', () => {
|
|
it('should be override correctly', () => {
|
|
const override = computed(() => English)
|
|
|
|
const wrapper = mount(
|
|
defineComponent({
|
|
setup(_, { expose }) {
|
|
const { locale } = useLocale(override)
|
|
expose({
|
|
locale,
|
|
})
|
|
},
|
|
template: '<div></div>',
|
|
}),
|
|
{
|
|
global: {
|
|
provide: {
|
|
locale: Chinese,
|
|
},
|
|
},
|
|
}
|
|
)
|
|
|
|
expect(wrapper.vm.locale).toBe(override.value)
|
|
})
|
|
})
|
|
})
|