vue3-yuanma/packages/vue/__tests__/customElementCasing.spec.ts

43 lines
1.0 KiB
TypeScript
Raw Normal View History

import { createApp } from '../src'
// https://github.com/vuejs/docs/pull/1890
// https://github.com/vuejs/core/issues/5401
// https://github.com/vuejs/docs/issues/1708
test('custom element event casing', () => {
customElements.define(
'custom-event-casing',
class Foo extends HTMLElement {
connectedCallback() {
this.dispatchEvent(new Event('camelCase'))
this.dispatchEvent(new Event('CAPScase'))
this.dispatchEvent(new Event('PascalCase'))
}
}
)
const container = document.createElement('div')
document.body.appendChild(container)
const handler = jest.fn()
const handler2 = jest.fn()
createApp({
template: `
<custom-event-casing
@camelCase="handler"
@CAPScase="handler"
@PascalCase="handler"
v-on="{
camelCase: handler2,
CAPScase: handler2,
PascalCase: handler2
}" />`,
methods: {
handler,
handler2
}
}).mount(container)
expect(handler).toHaveBeenCalledTimes(3)
expect(handler2).toHaveBeenCalledTimes(3)
})