When do I get error: jest fetch is not defined?

1.8K    Asked by Bhaanumatishukla in Salesforce , Asked on Sep 4, 2023

 I am getting the following error as I am trying to use

Below given is the code:

  1. fetch is not available, why?

  2. How can I make fetch work in a Jest test so as to not make a mock request but a proper one?

What is the way to avoid this jest fetch is not defined error?

Answered by Diana Campbell

 In the Node.js environment, fetch is not available by default, as it is a browser API that is used to make HTTP requests. A Node.js environment is run by jest, which is a Javascript testing framework, and that is why fetch does not work out of the box in jest tests. Jest is not used for integration testing but is used mostly for unit testing. Although you can make fetch work as a global variable.


Here’s how:
const MOCK_DATA = {
    "id": 1,
    "name": "Leanne Graham",
    "username": "Bret",
    "email": "Sincere@april.biz",
    "address": {
        "street": "Kulas Light",
        "suite": "Apt. 556",
        "city": "Gwenborough",
        "zipcode": "92998-3874",
        "geo": {
            "lat": "-37.3159",
            "lng": "81.1496"
        }
    },
    "phone": "1-770-736-8031 x56442",
    "website": "hildegard.org",
    "company": {
        "name": "Romaguera-Crona",
        "catchPhrase": "Multi-layered client-server neural-net",
        "bs": "harness real-time e-markets"
    }
};
global.fetch = jest.fn(() => Promise.resolve({
    json: () => Promise.resolve(MOCK_DATA)
}));
describe('FetchTest', () => {
    it('perform a fetch', async () => {
        // Arrange
        // Act
        const res = await fetch('https://jsonplaceholder.typicode.com/users/1');
        const result = await res.json();
        console.log(result);
        // Assert
        expect(1).toBe(1);
    });
});


Your Answer

Answer (1)

The error "Jest Fetch is not defined" typically occurs when attempting to use the global fetch function in Jest tests without configuring it properly. Jest does not include a global fetch function by default, unlike in a browser environment where fetch is available.


To resolve this error, you can use a polyfill to provide the fetch function in your Jest environment. You can install the jest-fetch-mock package, which is a Jest mock for the fetch API.

Here's how you can set it up:

Install the jest-fetch-mock package:

  npm install --save-dev jest-fetch-mock

Configure Jest to use the fetch mock in your jest.config.js or package.json:

{
  "jest": {
    "setupFilesAfterEnv": ["jest-fetch-mock"]
  }
}

Now you can use fetch in your tests as you would in a browser environment. Jest will use the polyfill provided by jest-fetch-mock.

test('example test', async () => {
  const response = await fetch('https://example.com');
  expect(response.status).toBe(200);
});

By setting up jest-fetch-mock, you ensure that fetch is defined in your Jest tests, preventing the "Jest Fetch is not defined" error.

8 Months

Interviews

Parent Categories