Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Cannot read property 'mockResolvedValue' of undefined

I'm getting an error mocking my api call

TypeError: Cannot read property 'mockResolvedValue" of undefined

and cannot figure out why. I'm utilizing jest to test my api fetch call function.

This is my function I'm exporting:

//file amData.jsx

const axios = require('axios');

async function fetchAssetManagerSummary() {
  const response = await axios.get("https://www.exampleUrl.com");
  return response.data;
}

module.exports = fetchAssetManagerSummary;

This is my test file

const fetchAssetManagerSummary = require('./amData');
const axios = require('axios');
jest.mock("axios");

it("returns the object from fetch", async () => {
  axios.get.mockResolvedValue({
    data: [
      {
        userId: 1,
        id: 1,
        title: 'test'
      }
    ]
  })
  const data = await fetchAssetManagerSummary();
  console.log("data", data)
});

The error I'm getting:

enter image description here

like image 583
pt2t Avatar asked May 06 '20 04:05

pt2t


1 Answers

Since you have already mocked the axios class, one of the ways of mocking the return value of axios.get is to do this:

axios.get = jest.fn().mockResolvedValue({
  data: [
    {
      userId: 1,
      id: 1,
      title: 'test'
    }
  ]
});
.
.
expect(axios.get).toHaveBeenCalledTimes(1);

Alternatively, you can spy on axios.get(), and provide a mocked return value:

jest.spyOn(axios, 'get').mockResolvedValueOnce({
  data: [
    {
      userId: 1,
      id: 1,
      title: 'test'
    }
  ]
});
like image 114
wentjun Avatar answered Nov 15 '22 06:11

wentjun