J'utilise Jest pour exécuter mes tests en utilisant la bibliothèque vue-test-utils.
Même si j'ai ajouté le VueRouter à l'instance localVue, il indique qu'il est impossible de trouver le composant link-router. Si le code a l'air un peu funky, c'est parce que j'utilise TypeScript, mais il devrait se lire assez près de ES6 ... L'essentiel est que le @Prop () équivaut à transmettre des accessoires: {..}
Composant Vue:
<template>
<div>
<div class="temp">
<div>
<router-link :to="temp.url">{{temp.name}}</router-link>
</div>
</div>
</div>
</template>
<script lang="ts">
import Vue from 'vue'
import Component from 'vue-class-component'
import { Prop } from 'vue-property-decorator'
import { Temp } from './Temp'
@Component({
name: 'temp'
})
export default class TempComponent extends Vue {
@Prop() private temp: Temp
}
</script>
<style lang="scss" scoped>
.temp {
padding-top: 10px;
}
</style>
Modèle temp:
export class Temp {
public static Default: Temp = new Temp(-1, '')
public url: string
constructor(public id: number, public name: string) {
this.id = id
this.name = name
this.url = '/temp/' + id
}
}
Test de plaisanterie
import { createLocalVue, shallow } from '@vue/test-utils'
import TempComponent from '@/components/Temp.vue'
import { Temp } from '@/components/Temp'
import VueRouter from 'vue-router'
const localVue = createLocalVue()
localVue.use(VueRouter)
describe('Temp.vue Component', () => {
test('renders a router-link tag with to temp.url', () => {
const temp = Temp.Default
temp.url = 'http://some-url.com'
const wrapper = shallow(TempComponent, {
propsData: { temp }
})
const aWrapper = wrapper.find('router-link')
expect((aWrapper.attributes() as any).to).toBe(temp.url)
})
})
Qu'est-ce que je rate? Le test réussit réellement, il jette juste l'avertissement. En fait, voici le résultat:
Test de sortie:
$ jest --config test/unit/jest.conf.js
PASS ClientApp\components\__tests__\temp.spec.ts
Temp.vue Component
√ renders a router-link tag with to temp.url (30ms)
console.error node_modules\vue\dist\vue.runtime.common.js:589
[Vue warn]: Unknown custom element: <router-link> - did you register the
component correctly? For recursive components, make sure to provide the
"name" option.
(found in <Root>)
Test Suites: 1 passed, 1 total
Tests: 1 passed, 1 total
Snapshots: 0 total
Time: 4.677s
Ran all test suites.
Done in 6.94s.
Appréciez toute aide que vous pouvez donner!
Ajoutez le stub router-link
aux options de la méthode shallow
(ou shallowMount
) comme ceci:
const wrapper = shallow(TempComponent, {
propsData: { temp },
stubs: ['router-link']
})
ou de cette façon :
import { RouterLinkStub } from '@vue/test-utils';
const wrapper = shallow(TempComponent, {
propsData: { temp },
stubs: {
RouterLink: RouterLinkStub
}
})
L'erreur devrait disparaître après avoir fait cela.
const wrapper = shallow(TempComponent, {
propsData: { temp },
localVue
})