Tester le mode Datastore à l'aide de l'émulateur Firestore

La Google Cloud CLI fournit un émulateur local en mémoire pour Firestore, que vous pouvez utiliser pour tester votre application Firestore en mode Datastore. Vous pouvez utiliser l'émulateur avec toutes les bibliothèques clientes en mode Datastore. Vous ne devez utiliser l'émulateur que pour les tests locaux.

Utilisez gcloud emulators firestore avec --database-mode=datastore-mode pour tester le comportement de Firestore en mode Datastore.

N'utilisez pas l'émulateur pour les déploiements de production. Étant donné que l'émulateur stocke les données uniquement en mémoire, il ne les conserve pas lors des exécutions.

Installer l'émulateur

Pour installer l'émulateur Firestore, installez et mettez à jour gcloud CLI :

  1. Installez la CLI gcloud.

  2. Mettez à jour votre installation de gcloud CLI pour bénéficier des dernières fonctionnalités :

    gcloud components update
    

Exécuter l'émulateur

  1. Exécutez la commande suivante pour démarrer l'émulateur :

    gcloud emulators firestore start --database-mode=datastore-mode
    

    L'émulateur imprime l'hôte et le numéro de port sur lequel il s'exécute.

    Par défaut, l'émulateur tente d'utiliser 127.0.0.1:8080. Pour lier l'émulateur à un hôte et à un port spécifiques, utilisez l'option facultative --host-port, en remplaçant HOST et PORT :

    gcloud emulators firestore start --database-mode=datastore-mode --host-port=HOST:PORT
    
  2. Utilisez le raccourci clavier Control + C pour arrêter l'émulateur.

Se connecter à l'émulateur

Pour connecter une bibliothèque cliente et une application à l'émulateur, définissez la variable d'environnement DATASTORE_EMULATOR_HOST. Lorsque cette variable d'environnement est définie, les bibliothèques clientes se connectent automatiquement à l'émulateur.

export DATASTORE_EMULATOR_HOST="HOST:PORT"

Importer des entités dans l'émulateur

La fonctionnalité d'importation de l'émulateur vous permet de charger des entités dans l'émulateur à partir d'un ensemble de fichiers d'exportation d'entités. Les fichiers d'exportation d'entités peuvent provenir d'une exportation de votre base de données en mode Datastore ou d'une instance d'émulateur.

Vous pouvez importer des entités dans l'émulateur de deux manières. La première consiste à ajouter l'indicateur import-data à la commande de démarrage de l'émulateur. La deuxième méthode consiste à envoyer une requête d'importation POST à l'émulateur. Vous pouvez utiliser curl ou un outil similaire. Consultez les exemples suivants.

Protocole

curl -X POST http://localhost:8080/emulator/v1/projects/PROJECT_ID:import \
-H 'Content-Type: application/json' \
-d '{"database":"DATABASE", "export_directory":"EXPORT_DIRECTORY"}'
Modifiez localhost:8080 si l'émulateur utilise un autre port.

Option de la CLI

gcloud emulators firestore start --database-mode=datastore-mode --import-data=EXPORT_DIRECTORY

où :

  • [PROJECT_ID] est l'ID de votre projet.
  • [DATABASE] est le chemin d'accès à la base de données. Par exemple, un projet avec une base de données par défaut se présenterait comme suit :

    {"database":"projects/myProject/databases/"}

  • [EXPORT_DIRECTORY] est le chemin d'accès au fichier overall_export_metadata des fichiers d'exportation de votre entité. Exemple :

    {"export_directory":"/home/user/myexports/2024-03-26T19:39:33_443/2024-03-26T19:39:33_443.overall_export_metadata"}

Exporter des entités dans l'émulateur

La fonctionnalité d'exportation de l'émulateur vous permet d'enregistrer des entités dans l'émulateur au sein d'un ensemble de fichiers d'exportation d'entités. Vous pouvez alors utiliser une opération d'importation pour charger, dans votre base de données en mode Datastore ou dans une instance d'émulateur, les entités contenues dans les fichiers d'exportation d'entités.

Vous pouvez exporter des entités depuis l'émulateur de deux manières. La première consiste à ajouter l'indicateur export-on-exit à la commande de démarrage de l'émulateur. La deuxième méthode consiste à envoyer une requête d'exportation POST à l'émulateur. Vous pouvez utiliser curl ou un outil similaire. Consultez les exemples suivants.

Protocole

curl -X POST http://localhost:8080/emulator/v1/projects/PROJECT_ID:export \
-H 'Content-Type: application/json' \
-d '{"database":"DATABASE_PATH", "export_directory":"EXPORT_DIRECTORY"}'
Modifiez localhost:8080 si l'émulateur utilise un autre port.

Option de la CLI

gcloud emulators firestore start --database-mode=datastore-mode --export-on-exit=EXPORT_DIRECTORY

où :

  • [PROJECT_ID] est l'ID de votre projet.
  • [DATABASE_PATH] est le chemin d'accès à la base de données. Par exemple, un projet avec une base de données par défaut se présenterait comme suit :

    {"database":"projects/myProject/databases/"}

  • [EXPORT_DIRECTORY] spécifie le répertoire dans lequel l'émulateur enregistre les fichiers d'exportation d'entités. Ce répertoire ne doit pas déjà contenir un ensemble de fichiers d'exportation d'entités. Exemple :

    {"export_directory":"/home/user/myexports/2024-03-26/"}

Persister les données dans l'émulateur

Par défaut, l'émulateur Firestore ne conserve pas les données sur le disque. Pour conserver les données de l'émulateur, exécutez la commande suivante afin d'utiliser les indicateurs d'importation et d'exportation pour charger et enregistrer les données dans les instances de l'émulateur :

gcloud emulators firestore start --database-mode=datastore-mode --import-data=EXPORT_DIRECTORY --export-on-exit=EXPORT_DIRECTORY

Réinitialiser les données de l'émulateur

L'émulateur Firestore inclut un point de terminaison REST permettant de réinitialiser toutes les données de l'émulateur. Vous pouvez utiliser ce point de terminaison pour effacer les données entre les tests sans arrêter l'émulateur.

Pour réinitialiser toutes les données de l'émulateur, effectuez une opération HTTP POST sur le point de terminaison suivant, en remplaçant HOST et PORT par l'hôte et le port que vous avez sélectionnés, et en remplaçant PROJECT_ID par votre propre ID de projet :

http://HOST:PORT/reset

Ajustez l'hôte et le port si l'émulateur n'utilise pas 127.0.0.1:8080. Votre code doit attendre la confirmation REST que la réinitialisation a réussi ou échoué.

Vous pouvez effectuer cette opération à partir du shell à l'aide de curl :

$ curl -X POST "http://HOST:PORT/reset"

Différences entre l'émulateur et la production

L'émulateur tente de reproduire fidèlement le comportement du service de production, avec quelques limites notables.

Simultanéité et cohérence

L'émulateur n'est compatible qu'avec la concurrence pessimiste et la cohérence forte. L'émulateur n'est pas compatible avec les paramètres de cohérence à terme et de concurrence optimiste.

Transactions

L'émulateur ne tente pas d'imiter le comportement des transactions observé en production. Il utilise une approche de verrouillage simple et ne tente pas de refléter les différents modes de simultanéité proposés dans l'environnement de production.

Lorsque vous testez des fonctionnalités impliquant plusieurs écritures simultanées dans un même document, l'émulateur peut mettre du temps à traiter les requêtes d'écriture. L'émulateur peut mettre jusqu'à 30 secondes pour libérer les verrous. Si vous devez ajuster les intervalles de délai avant expiration des tests, faites-le.

L'émulateur ne tente pas non plus d'imiter toutes les limites de production, telles que les délais d'attente et les limites de taille, qui impliquent des transactions. Si vous testez des fonctionnalités qui dépendent de ces limites de production, nous vous recommandons d'utiliser un environnement de production plutôt qu'un émulateur.

Index

L'émulateur ne suit pas les index composites et exécute plutôt toute requête valide. Veillez à tester votre application sur une instance en mode Datastore réelle pour déterminer les index dont vous avez besoin.

Limites

L'émulateur n'applique pas toutes les limites appliquées en production. Par exemple, l'émulateur peut autoriser des transactions qui seraient refusées comme étant trop importantes par le service de production. Assurez-vous de connaître les limites documentées et de concevoir votre application de manière à les éviter de manière proactive.

Étapes suivantes