用玩笑测试Firebase函数

问题描述 投票:0回答:1

从两天以来,我一直在努力理解并编写针对我的Firebase函数的测试。对于该测试,我只想使用Jest框架。 https://jestjs.io/

export const updateTipsPerFixture = functions.firestore.document('users/{userId}').onUpdate((change) => {
    const beforeTips: Tip[] = change.before.data() !== undefined ? change.before.data().tips : [];
    const afterTips: Tip[] = change.after.data() !== undefined ? change.after.data().tips : [];

    if (JSON.stringify(beforeTips) === JSON.stringify(afterTips)) {
        return new Promise(resolve => resolve('equal'));
    }

    if (afterTips.length === beforeTips.length) {
        return new Promise(resolve => resolve('same length'));
    }

    if (beforeTips.length < afterTips.length) {
        return new Promise(resolve => resolve('afterTips.length is longer'));
    }

    return false;
});

即使在阅读了Jest文档之后,也无法弄清楚如何为用例模拟/存入firebase功能模块。

据我所知。是的,不是很远。

describe('updateTipsPerFixture', () => {
    test('it should return true when tips are equal', () => {
        expect(updateTipsPerFixture).toEqual(new Promise(resolve => 'equal'));
    });
});

我应该如何编写测试并模拟firebase模块?

typescript firebase jestjs google-cloud-functions
1个回答
0
投票

我发现的解决方案非常简单而且不错。可以通过调用函数run()并传递一些数据来测试该函数。参见示例:

describe('updateTipsPerFixture', () => {
    test('it should return true when tips are equal', () => {
        const mockedData = {
            before: {
                data(): FirebaseFirestore.DocumentData | undefined {
                    return {tips: [{fixtureId: 123, teamId: 123} as Tip]}
                }
            },
            after: {
                data(): FirebaseFirestore.DocumentData | undefined {
                    return {tips: [{fixtureId: 123, teamId: 123} as Tip]}
                }
            }
        } as Change<DocumentSnapshot>;

        const actual = updateTipsPerFixture.run(mockedData, null);

        return expect(actual).resolves.toEqual('equal');
    });
});
© www.soinside.com 2019 - 2024. All rights reserved.