diff --git a/src/reactivity/reactive.ts b/src/reactivity/reactive.ts index 86f3e063..2914d1e8 100644 --- a/src/reactivity/reactive.ts +++ b/src/reactivity/reactive.ts @@ -150,7 +150,7 @@ function mockReactivityDeep(obj: any, seen = new Set()) { ) { continue } - mockReactivityDeep(value) + mockReactivityDeep(value, seen) } } diff --git a/test/ssr/ssrReactive.spec.ts b/test/ssr/ssrReactive.spec.ts index fd329827..90ec277a 100644 --- a/test/ssr/ssrReactive.spec.ts +++ b/test/ssr/ssrReactive.spec.ts @@ -11,10 +11,14 @@ import { isRef, set, shallowRef, + getCurrentInstance, + nextTick, } from '../../src' import { createRenderer } from 'vue-server-renderer' +import { mockWarn } from '../helpers' describe('SSR Reactive', () => { + mockWarn(true) beforeEach(() => { process.env.VUE_ENV = 'server' }) @@ -118,4 +122,27 @@ describe('SSR Reactive', () => { set(state.value, 'new', ref(true)) expect(JSON.stringify(state.value)).toBe('{"old":false,"new":true}') }) + + // test the input parameter of mockReactivityDeep + it('ssr should not RangeError: Maximum call stack size exceeded', async () => { + new Vue({ + setup() { + // @ts-expect-error + const app = getCurrentInstance().proxy + let mockNt: any = [] + mockNt.__ob__ = {} + const test = reactive({ + app, + mockNt, + }) + return { + test, + } + }, + }) + await nextTick() + expect( + `"RangeError: Maximum call stack size exceeded"` + ).not.toHaveBeenWarned() + }) })