我应该如何针对Vue单文件组件进行存根某些方法(尤其是getter),以便使用mocha/expect进行单元测试?
我面临的问题是:我有一个具有get方法someData的组件。
<script lang="ts">
import { Vue, Component } from 'vue-property-decorator'
import SomeService from '@/services/some.service'
@Component()
export default class MyApp extends Vue {
...
mounted () {
...
}
get someData () {
return this.$route.path.split('/')[1] || 'main'
}
get getLocation () {
return this.someService.getBaseURL()
}
initSomeStringProperty (): string {
return 'some string'
}
}
</script>
我的测试总是失败,提示如下:
[Vue warn]: Error in render: "TypeError: Cannot read property 'path' of undefined"
当我尝试使用sinon桩方法时,如下所示:
describe('MyApp.vue', () => {
if('returns main', () => {
const dataStub = sinon.stub(MyApp, 'someData')
listStub.yields(undefined, 'main')
const wrapper = shallowMount(AppNavBar)
expect(wrapper.text()).to.include('Some Content')
})
})
然而,我遇到了以下错误:
TypeError:无法存根不存在的 own 属性 someData
此外,我想为其他我想要存根的方法(例如 initSomeStringProperty())进行类似的存根操作时同样出现了相同的错误。