使用@ firebase / testing连接到Firestore模拟器

时间:2020-03-05 07:02:24

标签: firebase unit-testing google-cloud-firestore firebase-cli

我正在尝试在本地测试Firebase应用。

我正在使用firebase emulators:exec --only firestore 'mocha -r ts-node/register src/**/*.spec.ts

进行测试

在我的规范中,我导入@firebase/testing并设置我的应用,并按照 https://firebase.google.com/docs/rules/unit-tests

我有一个FirebaseService,这是我将Firebase应用程序注入其中的方法的单例包装。 在生产中,我将注入firebase,并在测试中的FirebaseService中对其进行初始化,然后在服务之外进行初始化。

包装程序非常简单


export const FirebaseService = (function(): FirebaseSrvc {
  let firebase;
  const fbServiceObj: FirebaseSrvc = {
    getInstance: (firebaseConfig, firebaseCore, initialize) => {
      firebase = firebaseCore;
      if (initialize && firebase.apps.length === 0) {
        firebase.initializeApp(firebaseConfig);
      }

      return fbServiceObj;
    },


    createActivity: async (title: string) => {
      try {
        const firebaseUid = firebase.auth().currentuser.uid;
        const newActivity: ActivityProps = {
          title,
          created_at: 123445,
          created_by: firebaseUid,
          public: false,
          available_to: [firebaseUid],
        };
        console.log(' before create', newActivity);
        const createResponse = await firebase
          .firestore()
          .collection('activities')
          .doc(stringToSafeId(title))
          .set(newActivity);
        console.log('create response', createResponse);
        return true;
      } catch (e) {
        console.log('error creating activity', e);
      }
    },

    getActivity: async (title: string): Promise<ActivityProps> => {
      try {
        const actResponse: DocumentReferenceTo<ActivityProps> = await firebase
          .firestore()
          .collection('activities')
          .doc(stringToSafeId(title))
          .get();
        return actResponse as ActivityProps;
      } catch (e) {
        console.log('error getting activity from firebase', e);
      }
    },
  };

  return fbServiceObj;
})();

我正在尝试运行的测试是

import * as firebase from '@firebase/testing';
import { assert } from 'chai';
import 'mocha';
import * as appConfig from '../../app-dev.json';
import { FirebaseService } from '../services/FirebaseService';

firebase.initializeTestApp({ ...appConfig.expo.extra.firebase, auth: { uid: 'random', email: 'test@test.com' } });


describe('Activity', async () => {
  const fb = FirebaseService.getInstance(appConfig.expo.extra.firebase, testApp, false);
  const activityData = new Activity(fb);
  beforeEach(async () => await firebase.clearFirestoreData({ projectId }));

  it('should create a new activity', async () => {
    await activityData.set('test-activity'); // this runs FirebaseService.createActivity
    const findActivity = await activityData.get('test-activity'); // this run FirebaseService.getActivity
    assert(findActivity.title === 'test-activity');
  });
});

运行测试时出现错误

Your API key is invalid, please check you have copied it correctly.] {
  code: 'auth/invalid-api-key',
  message: 'Your API key is invalid, please check you have copied it correctly.'
}

我可以确认传递到firebase.initializeTestApp的API密钥与我的Firebase控制台中的Web API密钥匹配。

我还从Firebase控制台和列表中下载了google-services.json

{
 "api_key": [
  { "current_key": different_from_web_key}
  ]
}

并且我已经用这个新密钥替换了现有密钥,我仍然遇到相同的错误。 我还尝试设置initializeTestApp({ projectId }),这是Firebase文档中的示例进行设置的方式,并且我收到相同的结果。

我正在使用相同的项目详细信息在android studio中本地运行项目,并且能够进行身份验证并写入Firestore,因此我正在使用的API密钥确实可以正常工作,但似乎在测试应用程序。

1 个答案:

答案 0 :(得分:1)

通常没有特定的解决方法。甚至可能是将新的API密钥复制并粘贴到参数中,也可能使其起作用并且错误消失。

我建议您看看社区中的以下帖子,这些帖子对您面临的错误有一些可能的修复。

此外,由于Firebase提供免费的支持服务,我认为您可以接触Firebase support可以帮助您快速解决此问题。您应该可以直接联系for free

让我知道信息是否对您有帮助!