Skip to content

Commit

Permalink
fix: include default props in props object (#716)
Browse files Browse the repository at this point in the history
  • Loading branch information
eddyerburgh authored Jun 14, 2018
1 parent 7fa2fb3 commit 5bcf574
Show file tree
Hide file tree
Showing 11 changed files with 64 additions and 43 deletions.
32 changes: 15 additions & 17 deletions packages/test-utils/src/wrapper.js
Original file line number Diff line number Diff line change
Expand Up @@ -398,15 +398,18 @@ export default class Wrapper implements BaseWrapper {
if (!this.vm) {
throwError('wrapper.props() must be called on a Vue instance')
}
// $props object does not exist in Vue 2.1.x, so use $options.propsData instead
let _props
if (this.vm && this.vm.$options && this.vm.$options.propsData) {
_props = this.vm.$options.propsData
} else {
// $FlowIgnore
_props = this.vm.$props

const props = {}
// $FlowIgnore
const keys = this.vm.$options._propKeys

if (keys) {
keys.forEach(key => {
// $FlowIgnore
props[key] = this.vm[key]
})
}
return _props || {} // Return an empty object if no props exist
return props
}

/**
Expand Down Expand Up @@ -518,26 +521,21 @@ export default class Wrapper implements BaseWrapper {
if (this.isFunctionalComponent) {
throwError('wrapper.setProps() cannot be called on a functional component')
}
if (!this.isVueInstance() || !this.vm) {
if (!this.isVm) {
throwError('wrapper.setProps() can only be called on a Vue instance')
}
if (this.vm && this.vm.$options && !this.vm.$options.propsData) {
this.vm.$options.propsData = {}
}

Object.keys(data).forEach((key) => {
// Ignore properties that were not specified in the component options
// $FlowIgnore : Problem with possibly null this.vm
if (!this.vm.$options._propKeys || !this.vm.$options._propKeys.some(prop => prop === key)) {
if (!this.vm.$options._propKeys ||
!this.vm.$options._propKeys.some(prop => prop === key)) {
throwError(`wrapper.setProps() called with ${key} property which is not defined on component`)
}

// $FlowIgnore : Problem with possibly null this.vm
if (this.vm._props) {
this.vm._props[key] = data[key]
// $FlowIgnore : Problem with possibly null this.vm.$props
this.vm.$props[key] = data[key]
// $FlowIgnore : Problem with possibly null this.vm.$options
this.vm.$options.propsData[key] = data[key]
} else {
// $FlowIgnore : Problem with possibly null this.vm
this.vm[key] = data[key]
Expand Down
10 changes: 10 additions & 0 deletions scripts/test-compat-all.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
#!/bin/sh

set -e

scripts/test-compat.sh "2.0.8"
scripts/test-compat.sh "2.1.10"
scripts/test-compat.sh "2.2.6"
scripts/test-compat.sh "2.3.4"
scripts/test-compat.sh "2.4.2"
scripts/test-compat.sh "2.5.13"
19 changes: 10 additions & 9 deletions test/specs/components/RouterLink.spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -8,13 +8,13 @@ describeWithShallowAndMount('RouterLinkStub', (mountingMethod) => {
<div>
<router-link
to="to1"
tag="tag1"
exact="exact1"
append="append1"
replace="replace1"
tag="a"
activeClass="activeClass1"
exactActiveClass="exactActiveClass1"
event="event1"
exact
append
replace
/>
</div>
`
Expand All @@ -24,12 +24,13 @@ describeWithShallowAndMount('RouterLinkStub', (mountingMethod) => {
RouterLink: RouterLinkStub
}
})

const routerLink = wrapper.find(RouterLinkStub)
expect(routerLink.props().to).to.equal('to1')
expect(routerLink.props().tag).to.equal('tag1')
expect(routerLink.props().exact).to.equal('exact1')
expect(routerLink.props().append).to.equal('append1')
expect(routerLink.props().replace).to.equal('replace1')
expect(routerLink.props().tag).to.equal('a')
expect(routerLink.props().exact).to.equal(true)
expect(routerLink.props().append).to.equal(true)
expect(routerLink.props().replace).to.equal(true)
expect(routerLink.props().activeClass).to.equal('activeClass1')
expect(routerLink.props().exactActiveClass).to.equal('exactActiveClass1')
expect(routerLink.props().event).to.equal('event1')
Expand All @@ -39,7 +40,7 @@ describeWithShallowAndMount('RouterLinkStub', (mountingMethod) => {
const TestComponent = {
template: `
<div>
<router-link>some text</router-link>
<router-link to="/">some text</router-link>
</div>
`
}
Expand Down
3 changes: 2 additions & 1 deletion test/specs/mounting-options/localVue.spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,8 @@ describeWithMountingMethods('options.localVue', (mountingMethod) => {
const TestComponent = {
template: `
<div>{{test}}</div>
`
`,
data: { test: '' }
}
const localVue = Vue.extend()
localVue.version = '2.3'
Expand Down
10 changes: 5 additions & 5 deletions test/specs/wrapper/destroy.spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -3,29 +3,29 @@ import { describeWithShallowAndMount } from '~resources/utils'
import sinon from 'sinon'

describeWithShallowAndMount('destroy', (mountingMethod) => {
it('should trigger beforeDestroy ', () => {
it('triggers beforeDestroy ', () => {
const spy = sinon.stub()
mountingMethod({
render: null,
render: () => {},
beforeDestroy () {
spy()
}
}).destroy()
expect(spy.calledOnce).to.equal(true)
})

it('should trigger destroy ', () => {
it('triggers destroy ', () => {
const spy = sinon.stub()
mountingMethod({
render: null,
render: () => {},
destroyed () {
spy()
}
}).destroy()
expect(spy.calledOnce).to.equal(true)
})

it.skip('should remove element from document.body', () => {
it.skip('removes element from document.body', () => {
const compiled = compileToFunctions('<div></div>')
const wrapper = mountingMethod(compiled, { attachToDocument: true })
expect(wrapper.vm.$el.parentNode).to.equal(document.body)
Expand Down
5 changes: 4 additions & 1 deletion test/specs/wrapper/emitted.spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -63,7 +63,8 @@ describeWithShallowAndMount('emitted', (mountingMethod) => {
},
mounted () {
this.$emit('bar', 1, 2)
}
},
render: () => {}
})

expect(wrapper.emitted().foo).to.eql([[]])
Expand All @@ -74,12 +75,14 @@ describeWithShallowAndMount('emitted', (mountingMethod) => {
const localVue = createLocalVue()

const wrapper1 = mountingMethod({
render: () => {},
beforeCreate () {
this.$emit('foo')
}
}, { localVue })

const wrapper2 = mountingMethod({
render: () => {},
mounted () {
this.$emit('bar')
}
Expand Down
2 changes: 1 addition & 1 deletion test/specs/wrapper/find.spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -240,7 +240,7 @@ describeWithShallowAndMount('find', (mountingMethod) => {
it('returns error Wrapper if Vue component is below Wrapper', () => {
const AComponent = {
render: () => {},
name: 'a component'
name: 'a-component'
}
const localVue = createLocalVue()
localVue.component('a-component', AComponent)
Expand Down
7 changes: 0 additions & 7 deletions test/specs/wrapper/hasClass.spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -40,13 +40,6 @@ describeWithShallowAndMount('hasClass', (mountingMethod) => {
expect(wrapper.hasClass('color-red')).to.equal(true)
})

it('returns false if wrapper does not contain element', () => {
const wrapper = mountingMethod({ render: (h) => h('div.a-class.b-class') })
const div = wrapper.find('div')
div.element = null
expect(wrapper.hasClass('a-class b-class')).to.equal(false)
})

it('returns true when the element contains multiple classes', () => {
const compiled = compileToFunctions('<div class="a-class b-class" />')
const wrapper = mountingMethod(compiled)
Expand Down
13 changes: 13 additions & 0 deletions test/specs/wrapper/props.spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,19 @@ describeWithShallowAndMount('props', (mountingMethod) => {
expect(wrapper.props()).to.eql({ prop1: {}, prop2: 'val2' }) // fail
})

it('returns default props', () => {
const TestComponent = {
render: () => {},
props: {
message: {
default: () => 'hello'
}
}
}
const wrapper = mountingMethod(TestComponent)
expect(wrapper.props().message).to.equal('hello')
})

itSkipIf(!functionalSFCsSupported,
'works correctly a functional component', () => {
const FunctionalComponent = {
Expand Down
1 change: 1 addition & 0 deletions test/specs/wrapper/setComputed.spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -39,6 +39,7 @@ describeWithShallowAndMount('setComputed', (mountingMethod) => {

it('updates vm computed value', () => {
const TestComponent = {
render: () => {},
data () {
return {
a: 1
Expand Down
5 changes: 3 additions & 2 deletions test/specs/wrapper/setData.spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -133,7 +133,7 @@ describeWithShallowAndMount('setData', (mountingMethod) => {
expect(wrapper.text()).to.equal('There is no message yet')
})

it('should update an existing property in a data object', () => {
it('updates an existing property in a data object', () => {
const TestComponent = {
data: () => ({
anObject: {
Expand All @@ -142,7 +142,8 @@ describeWithShallowAndMount('setData', (mountingMethod) => {
},
propB: 'b'
}
})
}),
render: () => {}
}
const wrapper = mountingMethod(TestComponent)
wrapper.setData({
Expand Down

0 comments on commit 5bcf574

Please sign in to comment.