Firebase AuthのLocal EmulatorはAuthProviderに応じて適切なダミーユーザを生成してくれる
Firebase Local Emulator Suiteを使ってローカル開発を行う際に↓の設定をするとFirebase Authの接続先をエミュレータに変更できる。
firebase.auth().useEmulator('http://localhost:9099')
Google認証を使いたい場合に、エミュレータだとOAuth認証はどうなるんだろうと思って試してみたところダミーのOAuthユーザを生成してくれる仕組みになっていた。
↓でGoogleログイン用のポップアップを表示すると、既存のダミーユーザか新規ユーザを追加するかが選択できる。
const provider = new firebase.auth.GoogleAuthProvider()
await app.auth().signInWithPopup(provider)
data:image/s3,"s3://crabby-images/36632/366323d5fbad43f1ca2b0bf72ef69a152a5bca8a" alt="local auth1"
新規ユーザの場合は「Auto-Generate」ボタンをクリックするとダミーデータをいい感じに入力してくれる。
data:image/s3,"s3://crabby-images/3dd1c/3dd1cb14db9e411a599debdcd89381fcd3b60211" alt="local auth2"
ユーザ登録後にエミュレータUI(http://localhost:4000/auth
)でカスタムクレームを設定することもできる。
data:image/s3,"s3://crabby-images/82734/8273401c8b787a6c629636913ba414160f08458e" alt="local auth3"
エミュレータがなかった頃は開発用のfirebaseプロジェクトを別途用意した上でfirebase admin sdkを使って都度ユーザのカスタムクレームを設定する必要があったので手間だった。
エミュレータのおかげでfirebaseを使ったサービスでもローカル開発がとてもやりやすくなった。