From 0a1db28e89bd492f72d4ab454b400bb996cbe0de Mon Sep 17 00:00:00 2001 From: daiwei Date: Fri, 10 Jan 2025 15:06:15 +0800 Subject: [PATCH 1/3] test: update test cases --- packages/runtime-vapor/__tests__/dom/templateRef.spec.ts | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/packages/runtime-vapor/__tests__/dom/templateRef.spec.ts b/packages/runtime-vapor/__tests__/dom/templateRef.spec.ts index a9a116f8a55..608f70a74c3 100644 --- a/packages/runtime-vapor/__tests__/dom/templateRef.spec.ts +++ b/packages/runtime-vapor/__tests__/dom/templateRef.spec.ts @@ -76,7 +76,7 @@ describe('api: template ref', () => { expect(fooEl.value).toBe(null) }) - it.todo('string ref unmount', async () => { + it('string ref unmount', async () => { const t0 = template('
') const el = ref(null) const toggle = ref(true) @@ -153,7 +153,7 @@ describe('api: template ref', () => { expect(fn2.mock.calls[0][0]).toBe(host.children[0]) }) - it.todo('function ref unmount', async () => { + it('function ref unmount', async () => { const fn = vi.fn() const toggle = ref(true) @@ -361,7 +361,7 @@ describe('api: template ref', () => { }) // #1789 - test.todo('toggle the same ref to different elements', async () => { + test('toggle the same ref to different elements', async () => { const refToggle = ref(false) const spy = vi.fn() From 2d357467a330ba276d1240d1281738260c613222 Mon Sep 17 00:00:00 2001 From: daiwei Date: Fri, 10 Jan 2025 16:11:22 +0800 Subject: [PATCH 2/3] test: update test cases --- .../__tests__/apiLifecycle.spec.ts | 71 +++++++++---------- 1 file changed, 33 insertions(+), 38 deletions(-) diff --git a/packages/runtime-vapor/__tests__/apiLifecycle.spec.ts b/packages/runtime-vapor/__tests__/apiLifecycle.spec.ts index af9f10f9f42..f62bb7f5ae6 100644 --- a/packages/runtime-vapor/__tests__/apiLifecycle.spec.ts +++ b/packages/runtime-vapor/__tests__/apiLifecycle.spec.ts @@ -21,7 +21,7 @@ import { } from '@vue/runtime-dom' import { createComponent, - // createIf, + createIf, createTextNode, renderEffect, setText, @@ -130,14 +130,13 @@ describe('api: lifecycle hooks', () => { expect(fn).toHaveBeenCalledTimes(1) }) - it.todo('onBeforeUnmount', async () => { + it('onBeforeUnmount', async () => { const toggle = ref(true) const fn = vi.fn(() => { - expect(host.innerHTML).toBe('
') + expect(host.innerHTML).toBe('
') }) const { render, host } = define({ setup() { - // @ts-expect-error const n0 = createIf( () => toggle.value, () => createComponent(Child), @@ -160,18 +159,17 @@ describe('api: lifecycle hooks', () => { toggle.value = false await nextTick() - // expect(fn).toHaveBeenCalledTimes(1) // FIXME: not called + expect(fn).toHaveBeenCalledTimes(1) expect(host.innerHTML).toBe('') }) - it.todo('onUnmounted', async () => { + it('onUnmounted', async () => { const toggle = ref(true) const fn = vi.fn(() => { - expect(host.innerHTML).toBe('
') + expect(host.innerHTML).toBe('') }) const { render, host } = define({ setup() { - // @ts-expect-error const n0 = createIf( () => toggle.value, () => createComponent(Child), @@ -194,18 +192,17 @@ describe('api: lifecycle hooks', () => { toggle.value = false await nextTick() - // expect(fn).toHaveBeenCalledTimes(1) // FIXME: not called + expect(fn).toHaveBeenCalledTimes(1) expect(host.innerHTML).toBe('') }) - it.todo('onBeforeUnmount in onMounted', async () => { + it('onBeforeUnmount in onMounted', async () => { const toggle = ref(true) const fn = vi.fn(() => { - expect(host.innerHTML).toBe('
') + expect(host.innerHTML).toBe('
') }) const { render, host } = define({ setup() { - // @ts-expect-error const n0 = createIf( () => toggle.value, () => createComponent(Child), @@ -230,25 +227,24 @@ describe('api: lifecycle hooks', () => { toggle.value = false await nextTick() - // expect(fn).toHaveBeenCalledTimes(1) // FIXME: not called + expect(fn).toHaveBeenCalledTimes(1) expect(host.innerHTML).toBe('') }) - it.todo('lifecycle call order', async () => { + it('lifecycle call order', async () => { const count = ref(0) const toggle = ref(true) const calls: string[] = [] const { render } = define({ setup() { - onBeforeMount(() => calls.push('onBeforeMount')) - onMounted(() => calls.push('onMounted')) - onBeforeUpdate(() => calls.push('onBeforeUpdate')) - onUpdated(() => calls.push('onUpdated')) - onBeforeUnmount(() => calls.push('onBeforeUnmount')) - onUnmounted(() => calls.push('onUnmounted')) - - // @ts-expect-error + onBeforeMount(() => calls.push('root onBeforeMount')) + onMounted(() => calls.push('root onMounted')) + onBeforeUpdate(() => calls.push('root onBeforeUpdate')) + onUpdated(() => calls.push('root onUpdated')) + onBeforeUnmount(() => calls.push('root onBeforeUnmount')) + onUnmounted(() => calls.push('root onUnmounted')) + const n0 = createIf( () => toggle.value, () => createComponent(Mid, { count: () => count.value }), @@ -290,14 +286,14 @@ describe('api: lifecycle hooks', () => { } // mount - render() + const ctx = render() expect(calls).toEqual([ - 'onBeforeMount', + 'root onBeforeMount', 'mid onBeforeMount', 'child onBeforeMount', 'child onMounted', 'mid onMounted', - 'onMounted', + 'root onMounted', ]) calls.length = 0 @@ -318,16 +314,16 @@ describe('api: lifecycle hooks', () => { calls.length = 0 // unmount - toggle.value = false - // FIXME: not called - // expect(calls).toEqual([ - // 'root onBeforeUnmount', - // 'mid onBeforeUnmount', - // 'child onBeforeUnmount', - // 'child onUnmounted', - // 'mid onUnmounted', - // 'root onUnmounted', - // ]) + ctx.app.unmount() + await nextTick() + expect(calls).toEqual([ + 'root onBeforeUnmount', + 'mid onBeforeUnmount', + 'child onBeforeUnmount', + 'child onUnmounted', + 'mid onUnmounted', + 'root onUnmounted', + ]) }) it('onRenderTracked', async () => { @@ -422,12 +418,11 @@ describe('api: lifecycle hooks', () => { }) }) - it.todo('runs shared hook fn for each instance', async () => { + it('runs shared hook fn for each instance', async () => { const fn = vi.fn() const toggle = ref(true) const { render } = define({ setup() { - // @ts-expect-error return createIf( () => toggle.value, () => [createComponent(Child), createComponent(Child)], @@ -446,7 +441,7 @@ describe('api: lifecycle hooks', () => { expect(fn).toHaveBeenCalledTimes(2) toggle.value = false await nextTick() - // expect(fn).toHaveBeenCalledTimes(4) // FIXME: not called unmounted hook + expect(fn).toHaveBeenCalledTimes(4) }) // #136 From d948c5bb8c64430a8c33d028c75c79e5460c331f Mon Sep 17 00:00:00 2001 From: daiwei Date: Fri, 10 Jan 2025 17:27:24 +0800 Subject: [PATCH 3/3] test: update tests --- packages/runtime-vapor/__tests__/apiLifecycle.spec.ts | 11 ++--------- 1 file changed, 2 insertions(+), 9 deletions(-) diff --git a/packages/runtime-vapor/__tests__/apiLifecycle.spec.ts b/packages/runtime-vapor/__tests__/apiLifecycle.spec.ts index f62bb7f5ae6..7c941d254ac 100644 --- a/packages/runtime-vapor/__tests__/apiLifecycle.spec.ts +++ b/packages/runtime-vapor/__tests__/apiLifecycle.spec.ts @@ -301,15 +301,8 @@ describe('api: lifecycle hooks', () => { // update count.value++ await nextTick() - // FIXME: not called - // expect(calls).toEqual([ - // 'root onBeforeUpdate', - // 'mid onBeforeUpdate', - // 'child onBeforeUpdate', - // 'child onUpdated', - // 'mid onUpdated', - // 'root onUpdated', - // ]) + // only child updated + expect(calls).toEqual(['child onBeforeUpdate', 'child onUpdated']) calls.length = 0