-
-
Notifications
You must be signed in to change notification settings - Fork 8.4k
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
fix(watch): should not fire pre watcher on child component unmount #7181
Conversation
@@ -360,7 +360,10 @@ function doWatch( | |||
} else { | |||
// default: 'pre' | |||
job.pre = true | |||
if (instance) job.id = instance.uid | |||
if (instance) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
this change is unnecessary.
we just check cb.id !== instance.uid
in flushPreFlushCbs will be ok.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks. Updated.
} | ||
|
||
const Parent = { | ||
porps: ['a'], |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
porps
seems to be a typo. This line currently isn't doing anything.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It's necessary to reproduce the issue.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Are you sure? The spelling is wrong. It says porps
, not props
. There's no such option as porps
.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Oh, I see. Thanks.
if (instance && cb.id !== instance.uid) { | ||
continue | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Shouldn't this come before the checkRecursiveUpdates
check? We shouldn't be incrementing the count in seen
unless we're actually running the job.
Maybe something like:
if (cb && cb.pre && (!instance || cb.id === instance.id)) {
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks. Updated.
I prefer to this condition instance && cb.id !== instance.uid
that more clearer.
// #7030 | ||
it('should not fire on child component unmount w/ flush: pre', async () => { | ||
const visible = ref(true) | ||
const cb = jest.fn() |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
jest.fn()
has been replaced with vi.fn()
on the latest main
branch.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks for reminding.
Is there an easy way to test if this PR works? |
/ecosystem-ci run |
📝 Ran ecosystem CI: Open
|
Maybe ecosystem-ci should be triggered after rebase. |
Size ReportBundles
Usages
|
/ecosystem-ci run |
📝 Ran ecosystem CI: Open
|
Fixes #7030