將應用程式連線至 Cloud Firestore 模擬器前,請務必瞭解整體 Firebase Local Emulator Suite 工作流程,並安裝及設定 Local Emulator Suite,並查看其 CLI 指令。
選擇 Firebase 專案
Firebase Local Emulator Suite 會模擬單一 Firebase 專案的產品。
如要選取要使用的專案,請在啟動模擬器前,在工作目錄的 CLI 中執行 firebase use
。或者,您也可以將 --project
標記傳遞至每個模擬器指令。
Local Emulator Suite 支援模擬實際 Firebase 專案和示範專案。
專案類型 | 功能 | 搭配模擬器使用 |
---|---|---|
真實 |
真正的 Firebase 專案是指您建立及設定的專案 (最有可能是透過 Firebase 控制台)。 真實專案包含使用中的資源,例如資料庫執行個體、儲存空間值區、函式,或是您為該 Firebase 專案設定的任何其他資源。 |
使用實際的 Firebase 專案時,您可以為任何或所有支援的產品執行模擬器。 對於您未模擬的任何產品,應用程式和程式碼會與實際資源 (資料庫執行個體、儲存空間 bucket、函式等) 互動。 |
示範 |
示範 Firebase 專案沒有實際的 Firebase 設定,也沒有即時資源。這些專案通常是透過程式碼研究室或其他教學課程存取。 示範專案的專案 ID 會加上 |
使用 Firebase 示範專案時,應用程式和程式碼只會與模擬器互動。如果應用程式嘗試與未執行模擬器的資源互動,該程式碼將會失敗。 |
建議您盡可能使用示範專案。Meet 具備以下優點:
- 設定更簡單,因為您無須建立 Firebase 專案即可執行模擬器
- 安全性較高,因為如果程式碼意外叫用非模擬的 (正式環境) 資源,就無法變更資料、使用及計費
- 提供更完善的離線支援功能,因為您不需要連上網際網路即可下載 SDK 設定。
檢測應用程式,讓其與模擬器通訊
啟動時,Cloud Firestore 模擬器會為 firebase.json
檔案中的每個 firestore
設定建立預設資料庫和命名資料庫。
系統也會在回應任何 SDK 或 REST API 對模擬器的呼叫時,隱含建立命名資料庫,以便參照特定資料庫。這類隱含的資料庫會以開放規則運作。
如要在 Emulator Suite UI 中以互動方式使用預設和命名資料庫,請在瀏覽器的網址列中更新網址,選取預設或命名資料庫。
- 舉例來說,如要瀏覽預設執行個體中的資料,請將網址更新為
localhost:4000/firestore/default/data
- 如要在名為
ecommerce
的執行個體中瀏覽,請更新為localhost:4000/firestore/ecommerce/data
。
Android、Apple 平台和 Web SDK
請設定應用程式內設定或測試類別,以便與 Cloud Firestore 互動,如下所示。請注意,在下列範例中,應用程式程式碼會連線至預設專案資料庫。如需預設資料庫以外的其他 Cloud Firestore 資料庫範例,請參閱多資料庫指南。
Kotlin+KTX
// 10.0.2.2 is the special IP address to connect to the 'localhost' of // the host computer from an Android emulator. val firestore = Firebase.firestore firestore.useEmulator("10.0.2.2", 8080) firestore.firestoreSettings = firestoreSettings { isPersistenceEnabled = false }
Java
// 10.0.2.2 is the special IP address to connect to the 'localhost' of // the host computer from an Android emulator. FirebaseFirestore firestore = FirebaseFirestore.getInstance(); firestore.useEmulator("10.0.2.2", 8080); FirebaseFirestoreSettings settings = new FirebaseFirestoreSettings.Builder() .setPersistenceEnabled(false) .build(); firestore.setFirestoreSettings(settings);
Swift
let settings = Firestore.firestore().settings settings.host = "127.0.0.1:8080" settings.cacheSettings = MemoryCacheSettings() settings.isSSLEnabled = false Firestore.firestore().settings = settings
Web
import { getFirestore, connectFirestoreEmulator } from "firebase/firestore"; // firebaseApps previously initialized using initializeApp() const db = getFirestore(); connectFirestoreEmulator(db, '127.0.0.1', 8080);
Web
// Firebase previously initialized using firebase.initializeApp(). var db = firebase.firestore(); if (location.hostname === "localhost") { db.useEmulator("127.0.0.1", 8080); }
您不需要額外設定,即可使用模擬器測試由 Firestore 事件觸發的 Cloud Functions。當 Firestore 和 Cloud Functions 模擬器同時執行時,兩者會自動搭配運作。
Admin SDK 秒
設定 FIRESTORE_EMULATOR_HOST
環境變數後,Firebase Admin SDK 會自動連線至 Cloud Firestore 模擬器:
export FIRESTORE_EMULATOR_HOST="127.0.0.1:8080"
如果程式碼在 Cloud Functions 模擬器中執行,系統會在呼叫 initializeApp
時自動設定專案 ID 和其他設定。
如果想讓 Admin SDK 程式碼連線至在其他環境中執行的共用模擬器,您必須指定使用 Firebase CLI 設定的相同專案 ID。您可以直接將專案 ID 傳遞至 initializeApp
,或設定 GCLOUD_PROJECT
環境變數。
Node.js Admin SDK
admin.initializeApp({ projectId: "your-project-id" });
環境變數
export GCLOUD_PROJECT="your-project-id"
在測試之間清除資料庫
Production Firestore 不提供清除資料庫的平台 SDK 方法,但 Firestore 模擬器會提供此專用的 REST 端點。您可以在測試開始之前,從測試架構設定/tearDown 步驟、從測試類別或殼層 (例如使用 curl
) 呼叫這個端點。您可以使用這個方法做為直接關閉模擬器程序的替代方案。
在適當的方法中執行 HTTP DELETE 作業,將 Firebase 專案 ID (例如 firestore-emulator-example
) 提供給下列端點:
"http://localhost:8080/emulator/v1/projects/firestore-emulator-example/databases/(default)/documents"
程式碼應等待 REST 確認資料沖除作業是否完成或失敗。
您可以透過殼層執行這項作業:
// Shell alternative…
$ curl -v -X DELETE "http://localhost:8080/emulator/v1/projects/firestore-emulator-example/databases/(default)/documents"
實作這類步驟後,您可以依序執行測試並觸發函式,確保在執行期間會清除舊資料,且您使用的是新的基準測試設定。
匯入及匯出資料
資料庫和 Cloud Storage for Firebase 模擬器可讓您從執行中的模擬器執行個體匯出資料。定義要在單元測試或持續整合工作流程中使用的基準資料集,然後匯出並在團隊中分享。
firebase emulators:export ./dir
在測試中,在模擬器啟動時匯入基準資料。
firebase emulators:start --import=./dir
您可以指示模擬器在關機時匯出資料,方法是指定匯出路徑,或直接使用傳遞至 --import
旗標的路徑。
firebase emulators:start --import=./dir --export-on-exit
這些資料匯入和匯出選項也適用於 firebase emulators:exec
指令。詳情請參閱模擬器指令參考資料。
以視覺化方式查看安全性規則活動
在進行原型設計和測試迴圈時,您可以使用 Local Emulator Suite 提供的圖像化工具和報表。
使用要求監控工具
Cloud Firestore 模擬器可讓您在 Emulator Suite UI 中以視覺化方式呈現用戶端要求,包括 Firebase Security Rules 的評估追蹤記錄。
開啟「Firestore」>「要求」分頁標籤,即可查看每項要求的詳細評估順序。
以圖表呈現規則評估報表
將安全性規則加入原型後,便可使用 Local Emulator Suite 偵錯工具進行偵錯。
執行一系列測試後,您可以查看測試涵蓋率報表,瞭解每項安全性規則的評估方式。
如要取得報表,請在模擬器執行期間查詢公開的端點。如要使用瀏覽器友善版本,請使用下列網址:
http://localhost:8080/emulator/v1/projects/<database_name>:ruleCoverage.html
這會將規則分解為運算式和子運算式,您可以將滑鼠游標懸停在運算式上,取得更多資訊,包括評估次數和傳回的值。如要取得這項資料的原始 JSON 版本,請在查詢中加入下列網址:
http://localhost:8080/emulator/v1/projects/<database_name>:ruleCoverage
這裡的 HTML 版本報表會醒目顯示含有未定義和空值錯誤的評估資料:
Cloud Firestore 模擬器與實際環境的差異
Cloud Firestore Emulator 會嘗試確實複製實際工作環境服務的行為,並設下一些明顯的限制。
Cloud Firestore 支援多個資料庫
目前 Emulator Suite UI 支援預設資料庫的互動式建立、編輯、刪除、要求監控和安全性視覺化功能,但不支援其他已命名的資料庫。
不過,模擬器本身會根據 firebase.json
檔案中的設定,並在回應 SDK 或 REST API 呼叫時隱含地建立命名資料庫。
交易
模擬器目前並未實作實際工作環境中顯示的所有交易行為。當您測試涉及在單一文件中執行多個並行寫入作業的功能時,模擬器可能會緩慢完成寫入要求。在某些情況下,解除鎖定可能需要長達 30 秒的時間。視需要調整測試逾時時間。
索引
模擬器不會追蹤複合式索引,而是會執行任何有效的查詢。請務必針對實際的 Cloud Firestore 例項測試應用程式,以便判斷需要哪些索引。
限制
模擬器不會強制執行正式版中強制執行的所有限制。舉例來說,模擬器可能會允許交易,但實際工作環境服務會將其視為太大而拒絕。請務必熟悉說明文件中的限制,並在設計應用程式時主動避免超出限制。
後續步驟
- 如需一系列精選影片和詳細教學範例,請參閱 Firebase 模擬器訓練播放清單。
- 瞭解涉及安全性規則測試和 Firebase Test SDK 的進階用途:測試安全性規則 (Firestore)。
- 觸發函式是與 Cloud Firestore 的典型整合方式,如要進一步瞭解 Cloud Functions for Firebase 模擬器,請參閱「在本機執行函式」一文。