element-plus/packages/hooks/__tests__/use-deprecated.vitest.ts
三咲智子 aaf90d99d0
test: switch to vitest (#5991)
* test: use vitest

* test: add script and ci

* chore: improve tsconfig

* refactor: use-form-item

* fix: remove unused

* chore: improve scripts

* test: improve mock

* refactor: change coverage
2022-02-21 14:28:22 +08:00

56 lines
1.2 KiB
TypeScript

import { computed, defineComponent, nextTick } from 'vue'
import { mount } from '@vue/test-utils'
import { describe, it, fn, vi, expect, afterEach } from 'vitest'
import { debugWarn } from '@element-plus/utils'
import { useDeprecated } from '../use-deprecated'
const AXIOM = 'Rem is the best girl'
vi.mock('@element-plus/utils/error', async () => {
return {
...(await vi.importActual<any>('@element-plus/utils/error')),
debugWarn: fn(),
}
})
const DummyComponent = defineComponent({
props: {
shouldWarn: Boolean,
},
setup(props) {
useDeprecated(
{
from: 'oldApi',
replacement: 'newApi',
scope: 'dummyComponent',
version: 'some version',
ref: '',
},
computed(() => props.shouldWarn)
)
return () => AXIOM
},
})
describe('useDeprecated', () => {
afterEach(() => {
vi.restoreAllMocks()
})
it('should warn when condition is true', async () => {
mount(DummyComponent, {
props: {
shouldWarn: true,
},
})
await nextTick()
expect(debugWarn).toHaveBeenCalled()
})
it('should not warn when condition is false', async () => {
mount(DummyComponent)
await nextTick()
expect(debugWarn).not.toHaveBeenCalled()
})
})