Skip to content
This repository has been archived by the owner on Aug 20, 2024. It is now read-only.

Latest commit

 

History

History
90 lines (69 loc) · 3.65 KB

File metadata and controls

90 lines (69 loc) · 3.65 KB

Running Sample Application

In order to run this application, you'll need to follow the following steps!

GoogleService-Info.plist files

You'll need valid GoogleService-Info.plist files for those samples. To get your own GoogleService-Info.plist files:

  1. Go to the Firebase Console
  2. Create a new Firebase project, if you don't already have one
  3. For each sample app you want to test, create a new Firebase app with the sample app's bundle identifier (e.g. com.google.FirebaseExperimental1.dev)
  4. Download the resulting GoogleService-Info.plist and place it in the Sample/ directory

GoogleService-Info_multi.plist files

  1. Create a second sample app and download its GoogleService_Info.plist file. This can be in the same Firebase project as the one above, or a different one. Use a different app bundle identifier (e.g. com.google.FirebaseExperimental2.dev).
  2. Save this plist file as GoogleService-Info_multi.plist in the Sample/ directory. This enables testing that FirebaseAuth continues to work after switching the Firebase App in the runtime.

Getting your own Credential files

Please follow the instructions in Sample/AuthCredentialsTemplate.h to generate the AuthCredentials.h file.

Application.plist file

Generate the Sample/Application.plist file from Sample/ApplicationTemplate.plist by replacing $BUNDLE_ID and $REVERSED_CLIENT_ID with their values from GoogleService-Info.plist and $REVERSED_CLIENT_MULTI_ID with its value from GoogleService-Info_multi.plist.

This could be done in bash via something like this from within the Sample directory:

$ BUNDLE_ID=`xmllint --xpath "/plist/dict/key[.='BUNDLE_ID']/following-sibling::string[1]/text()" GoogleService-Info.plist`
$ REVERSED_CLIENT_ID=`xmllint --xpath "/plist/dict/key[.='REVERSED_CLIENT_ID']/following-sibling::string[1]/text()" GoogleService-Info.plist`
$ REVERSED_CLIENT_MULTI_ID=`xmllint --xpath "/plist/dict/key[.='REVERSED_CLIENT_ID']/following-sibling::string[1]/text()" GoogleService-Info_multi.plist`
$ sed \
      -e 's/\$BUNDLE_ID/'$BUNDLE_ID'/g' \
      -e 's/\$REVERSED_CLIENT_ID/'$REVERSED_CLIENT_ID'/g' \
      -e 's/\$REVERSED_CLIENT_MULTI_ID/'$REVERSED_CLIENT_MULTI_ID'/g' \
      ApplicationTemplate.plist > Application.plist

Sample.entitlements file

In order to test the "Reset Password In App" feature you will need to create a dynamic link for your Firebase project in the Dynamic Links section of the Firebase Console. Once the link is created, please copy the contents of Sample/SampleTemplate.entitlements into a file named Sample/Sample.entitlements and replace $KAPP_LINKS_DOMAIN with your own relevant appLinks domain. Your appLinks domains are domains that your app will handle as universal links, in this particular case you can obtain this domain from the aforementioned Dynamic Links section of the Firebase Console.

Running API tests

In order to run the API tests, you'll need to follow the following steps!

Getting your own Credential files

Please follow the instructions in ApiTests/AuthCredentialsTemplate.h to generate the AuthCredentials.h file.

Console

In the Firebase conosle for your test project, you'll need to enable the following auth providers:

  • Email/Password
  • Google
  • Facebook
  • Anonymous

You'll also need to create a user with email [email protected] and password of password.

Usage

$ pod update
$ open Firebase.xcworkspace

Then select an Auth scheme and run.