diff --git a/src/mount.ts b/src/mount.ts index 483c8b2c7..33de2b5e7 100644 --- a/src/mount.ts +++ b/src/mount.ts @@ -293,9 +293,9 @@ export function mount( }, props: originalComponent.props || {}, setup: - (_, { attrs, slots }) => + (props, { attrs, slots }) => () => - h(originalComponent, attrs, slots), + h(originalComponent, { ...props, ...attrs }, slots), ...instanceOptions }) addToDoNotStubComponents(originalComponent) diff --git a/tests/mountingOptions/props.spec.ts b/tests/mountingOptions/props.spec.ts index adb1f4c8a..86f44f6bf 100644 --- a/tests/mountingOptions/props.spec.ts +++ b/tests/mountingOptions/props.spec.ts @@ -1,5 +1,6 @@ import { defineComponent, h } from 'vue' import { mount } from '../../src' +import Title from '../components/FunctionComponent' describe('mountingOptions.props', () => { const Component = defineComponent({ @@ -85,4 +86,13 @@ describe('mountingOptions.props', () => { expect(onCustomEvent).toHaveBeenCalledTimes(3) }) + + test('props with functional component', async () => { + const wrapper = mount(Title, { + props: { + title: 'Hello' + } + }) + expect(wrapper.text()).toBe('Hello') + }) }) diff --git a/tests/setProps.spec.ts b/tests/setProps.spec.ts index b5b3bcfbc..1107945ab 100644 --- a/tests/setProps.spec.ts +++ b/tests/setProps.spec.ts @@ -1,6 +1,7 @@ import { defineComponent, h, computed } from 'vue' import { mount } from '../src' +import Title from './components/FunctionComponent' describe('setProps', () => { it('updates a primitive prop', async () => { @@ -143,4 +144,14 @@ describe('setProps', () => { 'You can only use setProps on your mounted component' ) }) + + it('sets props for functional component', async () => { + const wrapper = mount(Title) + + await wrapper.setProps({ + title: 'Hello' + }) + + expect(wrapper.text()).toBe('Hello') + }) })