expect(isShallow(shallowReadonly({}))).toBe(true)
})
+ // #5271
+ test('should respect shallow reactive nested inside reactive on reset', () => {
+ const r = reactive({ foo: shallowReactive({ bar: {} }) })
+ expect(isShallow(r.foo)).toBe(true)
+ expect(isReactive(r.foo.bar)).toBe(false)
+
+ r.foo = shallowReactive({ bar: {} })
+ expect(isShallow(r.foo)).toBe(true)
+ expect(isReactive(r.foo.bar)).toBe(false)
+ })
+
+ test('should respect shallow/deep versions of same target on access', () => {
+ const original = {}
+ const shallow = shallowReactive(original)
+ const deep = reactive(original)
+ const r = reactive({ shallow, deep })
+ expect(r.shallow).toBe(shallow)
+ expect(r.deep).toBe(deep)
+ })
+
describe('collections', () => {
test('should be reactive', () => {
const shallowSet = shallowReactive(new Set())
reactiveMap,
shallowReactiveMap,
shallowReadonlyMap,
- isReadonly
+ isReadonly,
+ isShallow
} from './reactive'
import { TrackOpTypes, TriggerOpTypes } from './operations'
import {
): boolean {
let oldValue = (target as any)[key]
if (!shallow && !isReadonly(value)) {
- value = toRaw(value)
- oldValue = toRaw(oldValue)
+ if (!isShallow(value)) {
+ value = toRaw(value)
+ oldValue = toRaw(oldValue)
+ }
if (!isArray(target) && isRef(oldValue) && !isRef(value)) {
oldValue.value = value
return true