-
Notifications
You must be signed in to change notification settings - Fork 258
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Bug: Props in child component defined in mixin are missing with shallowMount
on @vue/compat
#2333
Comments
Thanks for the repros. compat mode is the realm of @xanf , so let's ping him |
I do not doubt this is a bug, but I suspect fixing this will be quite complex. It may be a good time to attempt to move your test to use |
Any news for this issue? We are migrating a large repo from Vue 2 + VTU 1 to Vue 3 + VTU 2 + @vue/compat and we have hundreds of falling tests because of this. I don't think using mount instead of shallowMount is a good fix for us because of performance. |
Thanks for ping, I will look into that this week
чт, 21 лист. 2024 р., 16:19 користувач vidal7 ***@***.***>
пише:
… Any news for this issue? We are migrating a large repo from Vue 2 + VTU 1
to Vue 3 + VTU 2 + @vue/compat and we have hundreds of falling tests
because of this.
—
Reply to this email directly, view it on GitHub
<#2333 (comment)>,
or unsubscribe
<https://github.com/notifications/unsubscribe-auth/AABRCJM62QDIYH6AUL4RN532BXTXZAVCNFSM6AAAAABSHDTS2WVHI2DSMVQWIX3LMV43OSLTON2WKQ3PNVWWK3TUHMZDIOJRGM2DAMBTGM>
.
You are receiving this because you were assigned.Message ID:
***@***.***>
|
I found a workaround for now that solve some of my issues but I am not sure if is a good fix or not. I am still experiencing, but the idea is to merge the mixin props with the component props something like it. @xanf , @lmiller1990 , if it a valid solution, it might not be that hard afterall. export const createStub = ({
name,
type,
renderStubDefaultSlot
}: StubOptions) => {
const anonName = 'anonymous-stub'
const tag = name ? `${hyphenate(name)}-stub` : anonName
const componentOptions = type
? unwrapLegacyVueExtendComponent(type) || {}
: {}
const props = {}
// Add mixins props
componentOptions.mixins?.forEach((mixin: ComponentOptions) => {
Object.assign(props, mixin.props);
});
// Add component props
Object.assign(props, component.props);
const stub = defineComponent({
name: name || anonName,
props
// fix #1550 - respect old-style v-model for shallow mounted components with @vue/compat
// @ts-expect-error
model: componentOptions.model,
setup(props, { slots }) {
return () => {
// https://github.com/vuejs/test-utils/issues/1076
// Passing a symbol as a static prop is not legal, since Vue will try to do
// something like `el.setAttribute('val', Symbol())` which is not valid and
// causes an error.
// Only a problem when shallow mounting. For this reason we iterate of the
// props that will be passed and stringify any that are symbols.
// Also having function text as attribute is useless and annoying so
// we replace it with "[Function]""
const stubProps = normalizeStubProps(props)
// if renderStubDefaultSlot is true, we render the default slot
if (renderStubDefaultSlot && slots.default) {
// we explicitly call the default slot with an empty object
// so scope slots destructuring works
return h(tag, stubProps, slots.default({}))
}
return h(tag, stubProps)
}
}
})
const { __asyncLoader: asyncLoader } = type as ComponentOptions
if (asyncLoader) {
asyncLoader().then(() => {
registerStub({
source: (type as ComponentOptions).__asyncResolved,
stub
})
})
}
return stub
} I am using config.plugins.createStubs to override the default createStub function in src/vnodeTransformers/stubComponentsTransformer.ts |
Describe the bug
With
shallowMount
on Vue 3 + @vue/compat, properties of a child component are undefined when using them through a mixin.If the property is moved from the mixin directly to the component, then the property is defined.
Also if the
shallowMount
is switched tomount
, the property is defined.To Reproduce
I created a demo repo where this issue can be reproduced, with tags for various working and not working states. It includes the following important files:
And the following tags:
mount
instead ofshallowMount
Expected behavior
The second assertion should pass in the broken case
The text was updated successfully, but these errors were encountered: