Search code examples
javascriptreactjspromisejestjscallback

React Jest:- node:internal/process/promises:246 triggerUncaughtException(err, true /* fromPromise */);


I have below code in react.

useEffect(() => {
        (async () => {
            await httpClient
                .get(`${config.resourceServerUrl}/inventory/`)
                .then((response) => {
                    setSponsor(response.data.sponsor);
                    setAddress(response.data.address);
                    setPhaseOfTrial(response.data.phaseOfTrial);
                })
                .catch((error) => {
                    alert(error);
                });
        })();
    }, []);

this code works successfully. only issue is , it is failing in jest test case.

describe('ListInventory', () => {
    it('should render successfully', () => {
        const { baseElement } = render(<ListInventory />);
        expect(baseElement).toBeTruthy();
    });
});

Below is the error.

node:internal/process/promises:246
          triggerUncaughtException(err, true /* fromPromise */);
          ^

[UnhandledPromiseRejection: This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). The promise rejected with the reason "TypeError: Cannot read properties of undefined (reading 'get')".] {
  code: 'ERR_UNHANDLED_REJECTION'
}

I am already using catch block. what wrong is in the code? could you please help me with the same.


Solution

  • The best way to do this is below:

        useEffect(() => {
            (async () => {
                let response = async () => await httpClient.get(
                    `${config.resourceServerUrl}/inventory/`
                );
    
                response
                    .then((res) => {
                        setSponsor(res.data.sponsor);
                        setAddress(res.data.address);
                        setPhaseOfTrial(res.data.phaseOfTrial);
                    }).catch((error) => {
                        alert(error);
                    })
            })();
        }, []);