Morgan Chen c148216344 Fix import bug (#9624) vor 4 Jahren
..
ApiTests 9f39fdccc3 Style Auth Integration Tests (#9229) vor 4 Jahren
AuthSample.xcodeproj a3a942b997 Add Swift API coverage tests for Auth (#9255) vor 4 Jahren
E2eTests 42655733d5 Auth repo-relative headers (#5332) vor 6 Jahren
Sample 7a273e7bae fix returns typo (#9541) vor 4 Jahren
SwiftApiTests c148216344 Fix import bug (#9624) vor 4 Jahren
Podfile 5d0f16e1e4 Fix Auth sample when pod updating (#9621) vor 4 Jahren
README.md e8f99a5297 Fix 404s and remove missing SwiftSample references (#9517) vor 4 Jahren

README.md

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 user+email_existing_user@example.com and password of password.

Usage

$ pod update
$ open Firebase.xcworkspace

Then select an Auth scheme and run.