Skip to content

Commit

Permalink
test coverage - SETUP,DATA,CONTEXT,PROPS
Browse files Browse the repository at this point in the history
  • Loading branch information
lidlanca authored Feb 13, 2022
1 parent 2e2fdfb commit 834965a
Showing 1 changed file with 56 additions and 9 deletions.
65 changes: 56 additions & 9 deletions packages/runtime-core/__tests__/componentPublicInstance.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -344,42 +344,89 @@ describe('component: proxy', () => {
const v2 = instanceProxy.toggle
expect(v2).toEqual('b')

// expect null to be a settable value
Object.defineProperty(instanceProxy, 'toggle', {
value: null
})
const v3 = instanceProxy.toggle
expect(v3).toBeNull()
})

test('defineProperty on proxy property with null value descriptor', () => {
test('defineProperty on public instance proxy should work with SETUP,DATA,CONTEXT,PROPS', () => {
// #5417
let instanceProxy: any
const Comp = {
props: ['fromProp'],
data() {
return { name: 'data.name' }
},
computed: {
greet() {
return 'Hi ' + (this as any).name
}
},
render() {},
setup() {
return {
toggle: 'a'
fromSetup: true
}
},
mounted() {
instanceProxy = this
}
}

const app = createApp(Comp)
const app = createApp(Comp, {
fromProp: true
})

app.mount(nodeOps.createElement('div'))
expect(instanceProxy.greet).toEqual('Hi data.name')

const v1 = instanceProxy.toggle
expect(v1).toEqual('a')
Object.defineProperty(instanceProxy, 'toggle', {
value: null
// define property on data
Object.defineProperty(instanceProxy, 'name', {
get() {
return 'getter.name'
}
})

const v2 = instanceProxy.toggle
expect(v2).toBeNull()
// computed is same still cached
expect(instanceProxy.greet).toEqual('Hi data.name')

// trigger computed
instanceProxy.name = ''

// expect "greet" to evaluated and use name from context getter
expect(instanceProxy.greet).toEqual('Hi getter.name')

// defineProperty on computed ( context )
Object.defineProperty(instanceProxy, 'greet', {
get() {
return 'Hi greet.getter.computed'
}
})
expect(instanceProxy.greet).toEqual('Hi greet.getter.computed')

// defineProperty on setupState
expect(instanceProxy.fromSetup).toBe(true)
Object.defineProperty(instanceProxy, 'fromSetup', {
get() {
return false
}
})
expect(instanceProxy.fromSetup).toBe(false)

// defineProperty on Props
expect(instanceProxy.fromProp).toBe(true)
Object.defineProperty(instanceProxy, 'fromProp', {
get() {
return false
}
})
expect(instanceProxy.fromProp).toBe(false)
})


// #864
test('should not warn declared but absent props', () => {
const Comp = {
Expand Down

0 comments on commit 834965a

Please sign in to comment.