Zanim zaczniesz korzystać z Firebase Local Emulator Suite, utwórz projekt w Firebase, skonfiguruj środowisko programistyczne oraz wybierz i zainstaluj pakiety SDK Firebase na swojej platformie zgodnie z instrukcjami w sekcji Pierwsze kroki z Firebase dotyczącymi Twojej platformy: Apple, Android lub sieć.
Prototypowanie i testowanie
Local Emulator Suite zawiera kilka emulatorów usług, jak opisano w artykule Wprowadzenie do Firebase Local Emulator Suite. Możesz prototypować i testować za pomocą pojedynczych emulatorów oraz ich kombinacji, w zależności od tego, które usługi Firebase używasz w środowisku produkcyjnym.
Aby przedstawić przepokój pracy z Local Emulator Suite, załóżmy że pracujesz nad aplikacją, która korzysta z typowej kombinacji usług: bazy danych Firebase i funkcji w chmurze aktywowanych przez operacje w tej bazie danych.
Po lokalnym zainicjowaniu projektu w Firebase cykl programowania z użyciem Local Emulator Suite zwykle obejmuje 3 etapy:
Interaktywne prototypowanie funkcji za pomocą emulatorów i Emulator Suite UI.
Jeśli używasz emulatora bazy danych lub emulatora Cloud Functions, wykonaj jednorazowy krok, aby połączyć aplikację z emulatorami.
Automatyzowanie testów za pomocą emulatorów i skryptów niestandardowych.
Lokalne inicjowanie projektu w Firebase
Upewnij się, że zainstalujesz interfejs CLI lub zaktualizujesz go do najnowszej wersji.
curl -sL firebase.tools | bashJeśli jeszcze tego nie zrobisz, zainicjuj bieżący katalog roboczy jako projekt w Firebase, postępując zgodnie z instrukcjami wyświetlanymi na ekranie, aby określić, że używasz Cloud Functions oraz Cloud Firestore lub Realtime Database:
firebase initKatalog projektu będzie teraz zawierać pliki konfiguracyjne Firebase, a
Firebase Security Rules plik definicji dla bazy danych, a functions katalog
zawierający kod funkcji w chmurze oraz inne pliki pomocnicze.
Interaktywne prototypowanie
Local Emulator Suite został zaprojektowany tak, aby umożliwić szybkie prototypowanie nowych funkcji, a wbudowany interfejs użytkownika jest jednym z jego najbardziej przydatnych narzędzi do prototypowania. To trochę tak, jakby konsola Firebase działała lokalnie.
Za pomocą Emulator Suite UI możesz iteracyjnie projektować bazę danych, wypróbowywać różne przepływy danych obejmujące funkcje w chmurze, oceniać zmiany reguł zabezpieczeń, sprawdzać logi, aby potwierdzić, jak działają usługi backendowe, i wiele więcej. Jeśli chcesz zacząć od nowa, po prostu wyczyść bazę danych i zacznij od nowa z nowym pomysłem na projekt.
Wszystko to jest dostępne po uruchomieniu Local Emulator Suite za pomocą polecenia:
firebase emulators:startAby prototypować naszą hipotetyczną aplikację, skonfigurujmy i przetestujmy podstawową funkcję w chmurze która będzie modyfikować wpisy tekstowe w bazie danych, a następnie utwórzmy i wypełnijmy tę bazę danych w Emulator Suite UI aby ją aktywować.
- Utwórz funkcję w chmurze aktywowaną przez zapisy w bazie danych, edytując plik
functions/index.jsw katalogu projektu. Zastąp zawartość istniejącego pliku tym fragmentem kodu. Ta funkcja nasłuchuje zmian w dokumentach w kolekcjimessages, konwertuje zawartość polaoriginaldokumentu na wielkie litery i zapisuje wynik w poluuppercasedokumentu. - Uruchom Local Emulator Suite za pomocą
firebase emulators:start. Uruchomią się emulatory Cloud Functions i bazy danych emulatory, automatycznie skonfigurowane do współpracy. - Wyświetl interfejs w przeglądarce pod adresem
http://localhost:4000. Port 4000 jest domyślnym portem interfejsu, ale sprawdź komunikaty w terminalu generowane przez interfejs Firebase CLI. Zwróć uwagę na stan dostępnych emulatorów. W naszym przypadku będą działać emulatory Cloud Functions i Cloud Firestore.
- W interfejsie na karcie Firestore > Dane kliknij
Rozpocznij kolekcję i postępuj zgodnie z instrukcjami, aby utworzyć nowy dokument w kolekcji
messages, z nazwą polaoriginali wartościątest. Spowoduje to aktywowanie naszej funkcji w chmurze. Zauważ, że wkrótce pojawi się noweuppercasepole wypełnione ciągiem znaków "TEST".
- Na karcie Firestore > Żądania sprawdź żądania wysyłane do emulowanej bazy danych, w tym wszystkie Firebase Security Rules oceny przeprowadzane w ramach realizacji tych żądań.
- Sprawdź kartę Logi , aby potwierdzić, że podczas aktualizowania bazy danych funkcja nie napotkała błędów.
const functions = require('firebase-functions/v1'); exports.makeUppercase = functions.firestore.document('/messages/{documentId}') .onCreate((snap, context) => { const original = snap.data().original; console.log('Uppercasing', context.params.documentId, original); const uppercase = original.toUpperCase(); return snap.ref.set({uppercase}, {merge: true}); });
Możesz łatwo przełączać się między kodem funkcji w chmurze a interaktywnymi zmianami w bazie danych, aż uzyskasz oczekiwany przepływ danych, bez konieczności modyfikowania kodu dostępu do bazy danych w aplikacji, ponownego kompilowania i ponownego uruchamiania zestawów testów.
Łączenie aplikacji z emulatorami
Gdy osiągniesz postępy w interaktywnym prototypowaniu i zdecydujesz się na projekt, możesz dodać do aplikacji kod dostępu do bazy danych za pomocą odpowiedniego pakietu SDK. Aby potwierdzić, że aplikacja działa prawidłowo, nadal będziesz używać karty bazy danych, a w przypadku funkcji – karty Logi w Emulator Suite UI.
Pamiętaj, że Local Emulator Suite to narzędzie do programowania lokalnego. Zapisy w bazach danych produkcyjnych nie będą aktywować funkcji, które prototypujesz lokalnie.
Aby aplikacja mogła zapisywać dane w bazie danych, musisz skierować klasy testowe lub konfigurację w aplikacji na Cloud Firestore emulator.
Kotlin
// 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); }
Automatyzowanie testów za pomocą skryptów niestandardowych
Teraz przejdźmy do ostatniego kroku ogólnego przepływu pracy. Gdy prototyp funkcji w aplikacji będzie obiecujący na wszystkich platformach, możesz przejść do ostatecznej implementacji i testowania. W przypadku testów jednostkowych i przepływów pracy CI możesz uruchamiać emulatory, uruchamiać testy skryptowe i wyłączać emulatory za pomocą jednego wywołania za pomocą polecenia exec:
firebase emulators:exec "./testdir/test.sh"Szczegółowe informacje o poszczególnych emulatorach
Teraz, gdy znasz już podstawowy przepływ pracy po stronie klienta, możesz przejść do szczegółów dotyczących poszczególnych emulatorów w pakiecie, w tym do sposobu ich używania do programowania aplikacji po stronie serwera:
- Dodawanie emulatora Authentication do przepływów pracy prototypowania
- Szczegółowe informacje o funkcjach emulatora Realtime Database
- Szczegółowe informacje o funkcjach emulatora Cloud Storage for Firebase
- Szczegółowe informacje o funkcjach emulatora Cloud Firestore
- Łączenie aplikacji z emulatorem Cloud Functions
- Ocena Firebase Extensions przy jednoczesnym zminimalizowaniu kosztów rozliczeniowych za pomocą emulatora Extensions
Co dalej?
Przeczytaj artykuły dotyczące poszczególnych emulatorów, do których linki znajdziesz powyżej. Następnie:
- Aby zapoznać się z wyselekcjonowanym zestawem filmów i szczegółowych instrukcji z przykładami, obejrzyj Playlista szkoleń na temat emulatorów Firebase.
- Zapoznaj się z zaawansowanymi przypadkami użycia obejmującymi testowanie reguł zabezpieczeń i pakiet SDK Firebase Test: Testowanie reguł zabezpieczeń (Cloud Firestore) , Testowanie reguł zabezpieczeń (Realtime Database) i Testowanie reguł zabezpieczeń (Cloud Storage for Firebase).