-
Notifications
You must be signed in to change notification settings - Fork 937
Improve Documentation in Testing #1600
Comments
This is quite interesting problem. One way I have worked around this in our codebase is before mounting checking if there is asyncData property and calling that, getting data and applying that to data of component. Example code: import Component from "./_.vue";
if (Component.asyncData) {
const originalData = Component.data();
const asyncData = await Component.asyncData({
$axios,
route,
params
redirect
});
Component.data = function() {
return { ...originalData, ...asyncData };
};
}
const component = shallowMount(Component); The issue though is if you have something that is expecting the data to fail and use redirect + expecting some of the asyncData to be used inside the lifecycle hook like Example excerpt of the JS for our specific scenario: export default {
name: "TestComponent",
data() {
return {
productDetails: {},
};
},
mounted() {
this.track();
},
methods: {
track() {
this.$gtm.trackEvent({
event: "pageshow",
taxonomy: {
id: this.productDetails.id,
extra: this.productDetails.extra,
}
});
},
},
async asyncData({ $axios, route, params, redirect }) {
try {
const result = await $axios.get(`/productDetail`);
return result;
} catch {
redirect('/somewhere-else');
}
},
}; Trying to test redirect on error with the above workaround will result in errors along the lines of:
As |
@VladDubrovskis you helped me a lot with your code example!!! Thank you! This should be at the documentation! I have spent a lot of time looking for something like this :( |
Thanks guys. |
Thanks for your contributions. We are now closing this repo as docs have now moved to nuxtjs.org using content module. Please continue your contributions on that site especially focusing on the guides folder which is the new docs. Thanks |
suggest some way to do it now stuck here from 2 days can not able to do a unit test for any Axios request
and test file pay.spec.js
But I am getting this error after running it. |
@vipulphysiofirst You are not mocking axios right. Better way of doing this is:
|
What problem does this feature solve?
For a lot of us proper testing is a big topic and it's hard to find documentation on how to test Nuxt-specific features. Currently I am trying to find out how to test
asyncData
and there is very little information on that on the internet and no information on the website. There is one example on how to run a test with AVA, but I feel testing should be a big part of software development and in the documentation.What does the proposed changes look like?
Documentation on how to test a Nuxt app, specifically Nuxt-specific features.
The text was updated successfully, but these errors were encountered: