尝试使用模拟器测试 Firestore 安全规则时总是出现超时错误
Timeout error always occurs when tried to test firestore security rules with emulator
我尝试使用模拟器测试 firestore 安全规则,但总是出现超时错误...
有相同现象或者有解决办法的请告知
测试结果
启动模拟器
% firebase serve --only firestore
运行 测试
% yarn test
yarn run v1.19.2
$ jest
FAIL tests/firestore.test.ts (7.123s)
Firestore Security Rule
✕ sample1 (5044ms)
● Firestore Security Rule › sample1
: Timeout - Async callback was not invoked within the 5000ms timeout specified by jest.setTimeout.Timeout - Async callback was not invoked within the 5000ms timeout specified by jest.setTimeout.Error:
30 | });
31 |
> 32 | test("sample1", async () => {
| ^
33 | const db = createAuthApp();
34 | const user = usersRef(db).doc("test");
35 | await firebase.assertSucceeds(user.set({ name: "John" }));
at new Spec (node_modules/jest-jasmine2/build/jasmine/Spec.js:116:22)
at Suite.<anonymous> (tests/firestore.test.ts:32:3)
at Object.<anonymous> (tests/firestore.test.ts:16:1)
Test Suites: 1 failed, 1 total
Tests: 1 failed, 1 total
Snapshots: 0 total
Time: 8.038s
Ran all test suites.
error Command failed with exit code 1.
info Visit https://yarnpkg.com/en/docs/cli/run for documentation about this command.
环境
※Firestore 安全规则允许一切因为示例
■firestore.test.ts
import * as firebase from "@firebase/testing";
import * as fs from "fs";
const PROJECT_ID = "firestore-rule-test";
const RULES_PATH = "firestore.rules";
// Create Firestore app with auth
const createAuthApp = (auth?: object): firebase.firestore.Firestore => {
return firebase
.initializeTestApp({ projectId: RULES_PATH, auth: auth })
.firestore();
};
const usersRef = (db: firebase.firestore.Firestore) => db.collection("user");
describe("Firestore Security Rule", () => {
beforeAll(async () => {
await firebase.loadFirestoreRules({
projectId: PROJECT_ID,
rules: fs.readFileSync(RULES_PATH, "utf8")
});
});
afterEach(async () => {
await firebase.clearFirestoreData({ projectId: PROJECT_ID });
});
afterAll(async () => {
await Promise.all(firebase.apps().map(app => app.delete()));
});
test("sample1", async () => {
const db = createAuthApp();
const user = usersRef(db).doc("test");
await firebase.assertSucceeds(user.set({ name: "John" }));
await firebase.assertSucceeds(user.get());
});
});;
在您的 createAuthApp()
函数中,您使用项目 ID RULES_PATH
初始化测试应用程序,但在您的测试中,您使用项目 ID PROJECT_ID
加载安全规则。
改变
.initializeTestApp({ projectId: RULES_PATH, auth: auth })
到
.initializeTestApp({ projectId: PROJECT_ID, auth: auth })
应该可以解决您的问题。
如果它不能解决问题,您可以使用 --testTimeout=<number of ms>
将 Jest 超时更改为 5 秒以上,以便为测试提供更多时间来完成。
最后,为了清楚起见,考虑将 createAuthApp
重命名为 createFirestoreInstance
,因为 "create Auth" 暗示与 FirebaseAuth
class.
我尝试使用模拟器测试 firestore 安全规则,但总是出现超时错误... 有相同现象或者有解决办法的请告知
测试结果
启动模拟器
% firebase serve --only firestore
运行 测试
% yarn test
yarn run v1.19.2
$ jest
FAIL tests/firestore.test.ts (7.123s)
Firestore Security Rule
✕ sample1 (5044ms)
● Firestore Security Rule › sample1
: Timeout - Async callback was not invoked within the 5000ms timeout specified by jest.setTimeout.Timeout - Async callback was not invoked within the 5000ms timeout specified by jest.setTimeout.Error:
30 | });
31 |
> 32 | test("sample1", async () => {
| ^
33 | const db = createAuthApp();
34 | const user = usersRef(db).doc("test");
35 | await firebase.assertSucceeds(user.set({ name: "John" }));
at new Spec (node_modules/jest-jasmine2/build/jasmine/Spec.js:116:22)
at Suite.<anonymous> (tests/firestore.test.ts:32:3)
at Object.<anonymous> (tests/firestore.test.ts:16:1)
Test Suites: 1 failed, 1 total
Tests: 1 failed, 1 total
Snapshots: 0 total
Time: 8.038s
Ran all test suites.
error Command failed with exit code 1.
info Visit https://yarnpkg.com/en/docs/cli/run for documentation about this command.
环境
※Firestore 安全规则允许一切因为示例
■firestore.test.ts
import * as firebase from "@firebase/testing";
import * as fs from "fs";
const PROJECT_ID = "firestore-rule-test";
const RULES_PATH = "firestore.rules";
// Create Firestore app with auth
const createAuthApp = (auth?: object): firebase.firestore.Firestore => {
return firebase
.initializeTestApp({ projectId: RULES_PATH, auth: auth })
.firestore();
};
const usersRef = (db: firebase.firestore.Firestore) => db.collection("user");
describe("Firestore Security Rule", () => {
beforeAll(async () => {
await firebase.loadFirestoreRules({
projectId: PROJECT_ID,
rules: fs.readFileSync(RULES_PATH, "utf8")
});
});
afterEach(async () => {
await firebase.clearFirestoreData({ projectId: PROJECT_ID });
});
afterAll(async () => {
await Promise.all(firebase.apps().map(app => app.delete()));
});
test("sample1", async () => {
const db = createAuthApp();
const user = usersRef(db).doc("test");
await firebase.assertSucceeds(user.set({ name: "John" }));
await firebase.assertSucceeds(user.get());
});
});;
在您的 createAuthApp()
函数中,您使用项目 ID RULES_PATH
初始化测试应用程序,但在您的测试中,您使用项目 ID PROJECT_ID
加载安全规则。
改变
.initializeTestApp({ projectId: RULES_PATH, auth: auth })
到
.initializeTestApp({ projectId: PROJECT_ID, auth: auth })
应该可以解决您的问题。
如果它不能解决问题,您可以使用 --testTimeout=<number of ms>
将 Jest 超时更改为 5 秒以上,以便为测试提供更多时间来完成。
最后,为了清楚起见,考虑将 createAuthApp
重命名为 createFirestoreInstance
,因为 "create Auth" 暗示与 FirebaseAuth
class.