前記事「[基礎知識]既存Flutter(Web)アプリに、Firestore(Firebase Cloud Firestore)機能を追加する手順」では既存FlutterアプリにCloud Firestore 機能を追加(Firestore DB登録等含む)しました。
またローカル環境ではFirebase Emulator Suite を利用しましたが、これのFirestoreエミュレータにも同じ内容のDB登録が必要です。
以下はその際の作業記録です。
1.Firestoreエミュレータ起動
ローカル環境でFirestoreエミュレータを起動します。
> firebase emulators:start
data:image/s3,"s3://crabby-images/c4007/c40075e95abbbba0b235669538635bcddbd1c74b" alt=""
2.Firestoreエミュレータでデータベース作成
(1) コレクションの作成
画面左上の+ Start collection
をクリックします。
data:image/s3,"s3://crabby-images/22a8c/22a8c5da80ebc3d72878f7ca34e31e77037922a9" alt=""
(2) コレクションIDの設定
コレクションIDフィールドにtaskinfo
を入力し、Next
をクリックします。
data:image/s3,"s3://crabby-images/30842/30842cf90534561ab9c7507dfcb9cacf9fc027f5" alt=""
(3) コレクションIDの設定
コレクションIDフィールドにtaskinfo
を入力し、Next
をクリックします。
※ここではFirestoreエミュレータにFirebase本サーバ上のCloud Firestore DBに登録済みのドキュメントIDと同じデータを設定しました。
(本サーバとローカル環境の)ドキュメントIDについて:
ローカル環境でテストしたFlutterアプリのコードを変更せずに、Firebase本サーバー上のCloud Firestoreに接続することは可能です。Firestoreエミュレータでテストする際も、本番環境のFirestoreで使用するのと同じドキュメントIDを使用することで、一貫性を保つことができます。
data:image/s3,"s3://crabby-images/4cbb2/4cbb2c74b1ecac26f15832430d2bbabfae2962ab" alt=""
(4) フィールドの追加
data:image/s3,"s3://crabby-images/67184/67184d7ababc496291b9ff20be4028e12960e168" alt=""
data:image/s3,"s3://crabby-images/1ef42/1ef42cb2a4724ca37ef3742c6609b06871121b46" alt=""
(5) 登録内容の確認
data:image/s3,"s3://crabby-images/27b22/27b22c7d3403a0814d79ee9ba79e80dfa1a459ae" alt=""
3.登録データのエクスポート
Firebase Emulator Suite / Firestore エミュレータは起動する度に登録データが削除(初期化)されます。
開発中毎回DB再登録する手間を無くす為に登録データをエクスポートします。
(1) データ格納フォルダに移動
※ここではFlutterプロジェクトフォルダに移動しています。
(2) エクスポート
> firebase emulators:export ./exported_data
※上記コマンドの場合、カレントフォルダ配下にエクスポートされます(下図)。
data:image/s3,"s3://crabby-images/84d6f/84d6f922c8f6b71efc36f002846996a52eeea364" alt=""
※上記エクスポートデータには、FirestoreデータベースだけでなくAuthenticationデータ(登録ユーザ)等も一緒にエクスポートされます。
4.登録データのインポート
エミュレータが起動する際に、インポート用オプションを指定します。
これにより、エミュレータが起動された時には、データが復元しています。
(1) インポートモードでエミュレータを起動
> firebase emulators:start –import=./exported_data
(2) 復元データ確認
①Firestoreデータベース
data:image/s3,"s3://crabby-images/02b15/02b15c74049d60df1c69b7baafacdee1577859b4" alt=""
②Authentication登録ユーザ情報
data:image/s3,"s3://crabby-images/3fdaa/3fdaaae269a075ee4014b26342d8a87917ce127f" alt=""
エミュレータ登録データのエクスポート・インポート手順は以上です。