如何使用内部承诺测试功能?

时间:2018-08-22 22:32:08

标签: javascript typescript promise jestjs

我目前正在尝试编写集成测试,以确保不会因脚本的进一步更改而破坏某些引起问题的特定客户案例。我不确定如何正确设置测试的格式,以使其运行并等待函数完成后再返回:

  1. 您的测试套件必须至少包含一个测试。
  2. 系统在被模拟时会调用适当的函数。

    // app.ts
    function doThing() {
        const data = window.data;
        if (!isEmpty(data)) {
            firstAsync(value1 => {
                return secondAsync(value1);
            }).then(value2 => {
                someCall();
            }).catch(error => {
                log(error);
            });
        } else {
            someOtherCall();
        }
    }
    
    // app.test.ts
    someCall = jest.fn();
    someOtherCall = jest.fn();
    
    describe('test', () => {
        it('should work', () => {
            window.data = { value: 'something' };
            doThing();
    
            expect(someCall).toHaveBeenCalled();
            expect(someOtherCall).not.toHaveBeenCalled();
        });
    });
    

TL:DR-我将如何编写测试以覆盖其中包含promise但本身不是promise的函数?

0 个答案:

没有答案