way change in node modules ??? you can change in the package.json - add a jest section like that: "jest": { "collectCoverageFrom": [ "src/**/*.{js,jsx,ts,tsx}" ], "resetMocks": false }
We can mock the axios module by jest.mock('axios') example: import { render, screen } from "@testing-library/react"; import followersResp from "../../__mocks__/followers-response.json"; import { MemoryRouter } from "react-router-dom"; import FollowersList from "./FollowersList"; import axios from "axios"; jest.mock("axios"); describe("FollowersList", () => { test("should dispaly five followers", async () => { axios.get.mockResolvedValue(followersResp); render(
I don't get this video. Is mocking the axios request (just by creating a folder __mocks___ and a file axios.js) supposed to take over the real axios request in FollowersList? How does this work? My tests still use the real axios request so am I missing something?
The reason why it uses the actual implementation of axios is because the jest.mock('axios', {...}) should be placed at the top of the describe block not inside the describe block.
the best way is to use the "mock service worker" but if you want to use axios you can create an axios instance for every request : const getUsers=axios.create({ baseUrl: "...." method: 'get' }) you can use it every time you want to get users for example and mock it as well. const users =await getUsers(''/users"); (sorry my English)
the code in this video didn't work for me, i couldn't trigger a mock for axios. Anyway a quick solution is to put the following code inside the test file and everything will be working fine. Basically the code is for mocking "axios" jest.mock('axios', () => ({ __esModule: true, default: { get: () => ({ data:[ {userId:"not"}, {userId:"really"}, {userId:"one"} ] }) } }));
You missed a part of the tutorial 8:41 he modified the node_modules folder. After changed the resetMocks to false, you should be good (keeps the src/__mocks__)
Why is the __mocks__ folder put into the src folder? In the jest docs you can find that for mocking Node modules (like axios right?) "the mock should be placed in the __mocks__ directory adjacent to node_modules". Is it here different because of being a React project?
Thanks for this video, for the purpose of clarity can you confirm if giving this test the right name is what enables the api request to be able to be mocked as i see that in the testfile for the followerlist component this moked api call was not imported and nothing really refernced it... Thanks
Why not mocking the module directly in the test file ? Something like this: jest.mock('axios', () => ({ __esModule: true, get: () => ({ your: 'object' }) }));
This is my preferred approach (this or spyOn with mockImplementation on a per test basis). You don't have to modify an external file, and it gives you more flexibility for mocking, and also makes it very clear what the mock data you are returning looks like in the scope of that file or specific test
You probably need to mock the default export. Try something like this: jest.mock('axios', () => ({ __esModule: true, default: { get: () => ({ your: 'object' }) } })); or just jest.mock('axios');
I tried using this code in the same file as the test but it didn't work without wrapping the get in a default: {} property. Could you please explain why is that? And what's the point of __esModule: true? Thank you.
@@alinpetrusca9886 it is because axios is a default import (not named). Quoting an article I will link below, "In order to successfully mock a module with a default export, we need to return an object that contains a property for __esModule: true and then a property for the default export. This helps Jest correctly mock an ES6 module that uses a default export." Source codeburst.io/module-mocking-in-jest-ff174397e5ff
@@BookOfSaints My link described exactly what Sonja Moamo asked for. There is no need to delete comments just to show how smart you are :). Best regards.
what if we have more than one endpoints to make a get call? you have shown it for a case where we are making the call to same endpoint.. please respond...thanks
I switched out mocking of axios to the following approach: beforeEach(() => { //jest.mock("../../../__mocks__/axios") const mockGet = jest.spyOn(axios, 'get'); mockGet.mockImplementation(() => mockResponse) });
How to test a dispatch inside a component and have .then() waiting for a response from the server? I want to write a test case for the save function inside my component which is triggering with fireEvent. onSave = () => { dispatch(createItem(payload)) .then(res => { if(res.code === 200 && res.status === 'OK'){ setSomeState(randomValue) } }) }; I want to let the execution go inside .then() block. how can we write the test case for this scenario with jest mock function?
How can you say that tests will run over and over in production? if your tests run in production, then the problem about resource consumption lies in the infrastructure, not the approach.
Thank you so much for the videos, they were super helpful! Regarding this one: How about using spies? Wouldn't it be easier to mock requests? import axios from "axios"; const mockResponse = {...} describe("...", () => { const axiosSpy = jest.spyOn(axios, "get"); // Mock return value for test it("test case", () => { axiosSpy.mockResolvedValueOnce(mockResponse); }); });
Exellent compilation , showing the basics of testing with React.js.Everrything is very well explained. Thank you very much. In this particular video though , I got little confused. What exatly is mocking. What happens when use this method , are the tests go to the Server API , or not , and how we get the data. Thanks again.
Yes same question here to why you wanna mock data something like that and modifying nodemodule is strictly not allowed. why can't use the approach jest.mock()
Based on the last bug of testing, instead of changing node_modules, we can put:
"jest": {
"resetMocks": false
},
in package.json
Great Thanks so much for the good suggestions.
thanks!!
way change in node modules ??? you can change in the package.json - add a jest section like that:
"jest": {
"collectCoverageFrom": [
"src/**/*.{js,jsx,ts,tsx}"
],
"resetMocks": false
}
This really works. Thanks alot
@@shahmirjadoon3587 you Welcome :)
Mock service worker is a great solution for mocking different endpoints and routes. The docs are pretty clean and easy to follow along with.
msw is a godsent for mocking data.
We can mock the axios module by jest.mock('axios')
example:
import { render, screen } from "@testing-library/react";
import followersResp from "../../__mocks__/followers-response.json";
import { MemoryRouter } from "react-router-dom";
import FollowersList from "./FollowersList";
import axios from "axios";
jest.mock("axios");
describe("FollowersList", () => {
test("should dispaly five followers", async () => {
axios.get.mockResolvedValue(followersResp);
render(
);
const followers = await screen.findAllByTestId("follower-item");
expect(followers).toHaveLength(5);
});
});
how to mock post api
@@suvendukumarsahoo4172 you use post instead of get in the same way
@@essaadi_elmehdi6784 i don't get it bro, can u have any example vdo regarding this
modifying node_modules will help us to pass tests only in our local machine right ?
What if we have to run the tests in CI/CD pipelines ?
We can add resetMocks as false under jest in package.json file
If you're doing some changes in node_modules and want that to pass on CI/CD pipeline use patch-package .
I don't get this video. Is mocking the axios request (just by creating a folder __mocks___ and a file axios.js) supposed to take over the real axios request in FollowersList? How does this work? My tests still use the real axios request so am I missing something?
Same question. The component is still being rendered and useEffect hook is still executed which fetches data.
@@ShashotoANur Yes, I really don't get it. The ___mocks__ folder has no effect on my code.
@@ShashotoANur I used this code in the test file and it worked: jest.mock("axios", () => ({
__esModule: true,
default: {
get: () => ({
data: {
results: [
{
name: {
...
},
picture: {
...,
},
login: {
...
},
},
],
},
}),
},
}));
The reason why it uses the actual implementation of axios is because the jest.mock('axios', {...}) should be placed at the top of the describe block not inside the describe block.
Terrific series. Question: how can i mock different responses based on different URLs passed into Axios?
Same question.
did you find any solution?
the best way is to use the "mock service worker" but if you want to use axios you can create an axios instance for every request :
const getUsers=axios.create({
baseUrl: "...."
method: 'get'
})
you can use it every time you want to get users for example and mock it as well.
const users =await getUsers(''/users");
(sorry my English)
@@kadirookirim3231 I agree, I use the same.
@@kadirookirim3231 can u explain how to post api call
the code in this video didn't work for me, i couldn't trigger a mock for axios. Anyway a quick solution is to put the following code inside the test file and everything will be working fine. Basically the code is for mocking "axios"
jest.mock('axios', () => ({
__esModule: true,
default: {
get: () => ({
data:[
{userId:"not"},
{userId:"really"},
{userId:"one"}
]
})
}
}));
thanks, this is helpful
@@ph3ed Thanks, worked for me💌
Thanks, worked for me.
You missed a part of the tutorial 8:41 he modified the node_modules folder. After changed the resetMocks to false, you should be good (keeps the src/__mocks__)
If you delete the src/__mocks__ , the whole point of mocking get data from APIs is gone, so please keep the src/__mocks__ and follow 8:41
And if I have another API in another file, how could I change the mocked data as in this case in receiving the same mocked data
Why is the __mocks__ folder put into the src folder? In the jest docs you can find that for mocking Node modules (like axios right?) "the mock should be placed in the __mocks__ directory adjacent to node_modules". Is it here different because of being a React project?
Thanks for this video, for the purpose of clarity can you confirm if giving this test the right name is what enables the api request to be able to be mocked as i see that in the testfile for the followerlist component this moked api call was not imported and nothing really refernced it... Thanks
If there are multiple apis in the application, how we can mock it ?
Hey, there are external tools like MockServers, msw, requestly you can use them to create mocks.
Why not mocking the module directly in the test file ? Something like this:
jest.mock('axios', () => ({
__esModule: true,
get: () => ({
your: 'object'
})
}));
This is my preferred approach (this or spyOn with mockImplementation on a per test basis). You don't have to modify an external file, and it gives you more flexibility for mocking, and also makes it very clear what the mock data you are returning looks like in the scope of that file or specific test
You probably need to mock the default export. Try something like this:
jest.mock('axios', () => ({
__esModule: true,
default: {
get: () => ({
your: 'object'
})
}
}));
or just
jest.mock('axios');
I tried using this code in the same file as the test but it didn't work without wrapping the get in a default: {} property. Could you please explain why is that? And what's the point of __esModule: true? Thank you.
@@alinpetrusca9886 it is because axios is a default import (not named). Quoting an article I will link below,
"In order to successfully mock a module with a default export, we need to return an object that contains a property for __esModule: true and then a property for the default export. This helps Jest correctly mock an ES6 module that uses a default export."
Source codeburst.io/module-mocking-in-jest-ff174397e5ff
@@BookOfSaints My link described exactly what Sonja Moamo asked for. There is no need to delete comments just to show how smart you are :). Best regards.
what if we have more than one endpoints to make a get call? you have shown it for a case where we are making the call to same endpoint.. please respond...thanks
what happen if a have to test several components that have axios get methods, and each one has different result structure
Do you have an example mocking using the msw library? Btw great videos!!!!!
I switched out mocking of axios to the following approach:
beforeEach(() => {
//jest.mock("../../../__mocks__/axios")
const mockGet = jest.spyOn(axios, 'get');
mockGet.mockImplementation(() => mockResponse)
});
How to test a dispatch inside a component and have .then() waiting for a response from the server?
I want to write a test case for the save function inside my component which is triggering with fireEvent.
onSave = () => {
dispatch(createItem(payload))
.then(res => {
if(res.code === 200 && res.status === 'OK'){
setSomeState(randomValue)
}
})
};
I want to let the execution go inside .then() block.
how can we write the test case for this scenario with jest mock function?
How do you mock more that one API request to different test cases
What if you want to use mocking in different pages?
9:14 I didnt quite understand why it failed in the first place? Anyone?
Thank you, Laith, great explanation
mock service worker is a good alternative to mocking axios or fetch.
How can you say that tests will run over and over in production? if your tests run in production, then the problem about resource consumption lies in the infrastructure, not the approach.
can we use postman to test api instead
msw? Can we use it to mock http call?
Thank you so much for the videos, they were super helpful!
Regarding this one: How about using spies? Wouldn't it be easier to mock requests?
import axios from "axios";
const mockResponse = {...}
describe("...", () => {
const axiosSpy = jest.spyOn(axios, "get");
// Mock return value for test
it("test case", () => {
axiosSpy.mockResolvedValueOnce(mockResponse);
});
});
can we use json server for mocking apis ?
This is great tutorial for react testing library
Glad it was helpful! :)
Exellent compilation , showing the basics of testing with React.js.Everrything is very well explained. Thank you very much. In this particular video though , I got little confused. What exatly is mocking. What happens when use this method , are the tests go to the Server API , or not , and how we get the data. Thanks again.
Is this a unit test or an integration test?
great explanation. Thanks man!
i don't quite get why the Mocks resetting gives out an error
Yes same question here to why you wanna mock data something like that and modifying nodemodule is strictly not allowed. why can't use the approach jest.mock()
we can use Service worker too
You can use MSW for mocking.
Great job asking for feedback on mocking API calls
How to mock post api request
thanks laith n shaun.
very helpful
simpliest:
jest.spyOn(axios,"get").mockReturnValue(mockResponse);
Lol changing node modules to fix your issue... bruh
Can't stop laughing rn