Heim  >  Fragen und Antworten  >  Hauptteil

Der Test gibt keinen Fehler aus, wenn sich der erwartete Wert innerhalb der Schleife befindet

Ich versuche, einige Unit-Tests umzugestalten, habe aber festgestellt, dass das Erwarten innerhalb einer Schleife nicht funktioniert. Ich durchlaufe eine Aufzählung. Ich habe den folgenden Code:

Irgendwelche Lösungen oder Workarounds?

it('should block approval of ads if status is not in pending revision', async () => {
  mockAdsRepository.findOne = jest.fn(() =>
    Promise.resolve({ ...adsDto, status: Status.REJECTED }),
  );
  await expect(service.approve(1, 1)).rejects.toThrow(BadRequestException);

  mockAdsRepository.findOne = jest.fn(() =>
    Promise.resolve({ ...adsDto, status: Status.UNPUBLISH }),
  );
  await expect(service.approve(1, 1)).rejects.toThrow(BadRequestException);

  // error trigger, working
  // mockAdsRepository.findOne = jest.fn(() =>
  //   Promise.resolve({ ...adsDto, status: Status.PENDING_REVISION }),
  // );
  // await expect(service.approve(1, 1)).rejects.toThrow(BadRequestException);

  //refactor
  Object.keys(Status).map(async (key) => {
    if (Status[key] !== Status./*changing this value for error triggers not working*/ ) {
      mockAdsRepository.findOne = jest.fn(() =>
        Promise.resolve({ ...adsDto, status: Status[key] }),
      );

      await expect(service.approve(1, 1)).rejects.toThrow(
        BadRequestException,
      );
    }
  });
});

P粉060112396P粉060112396367 Tage vor529

Antworte allen(1)Ich werde antworten

  • P粉545910687

    P粉5459106872023-09-19 14:50:38

    我认为,在你的情况下问题是map不处理异步操作,所以在循环结束时有几个处于挂起状态的promise。你应该等待map中的所有promise被解决/拒绝。

    你可以使用这个函数来处理所有的promise。

    export async function mapAsync<T, R>(
      elements: Promise<T>[] | T[],
      mapAction: (arg: T) => Promise<R>,
    ): Promise<R[]> {
      const results: R[] = [];
      for (const element of await Promise.all(elements)) {
        const mappedItem = await mapAction(element);
        results.push(mappedItem);
      }
      return results;
    }

    Antwort
    0
  • StornierenAntwort