asyncTesting

제가 테스트하려는 코드는 아래와 같습니다

async function handleFileChange(e) {
    const { files } = e.target;

    const getImagePromises = [].map.call(files, async (file) => {
      const result = await readFile(file);
      return result;
    });

    const uploadImages = await Promise.all(getImagePromises);

    dispatch(setAddRoomImagesField(uploadImages));
  }

promise.All 함수가 실행된 후 dispatch가 실행되는 것을 확인하려면 waitFor를 사용해야합니다. waitFor는 비동기적으로 확인해야하는 항목을 기다려줍니다

const { getByLabelText } = renderAddRoomContainer();

await waitFor(() => {
  fireEvent.change(getByLabelText('방 사진 등록하기'), {
    target: {
      files: {
        0: {
          name: 'test.png',
        },
      },
    },
  });
});

expect(dispatch).toBeCalled();

참고글


Written by@Heaeun
코드리뷰, TDD, 함께 자라기를 지향하는 프론트엔드 개발자입니다

GitHub