firebase-admin-java icon indicating copy to clipboard operation
firebase-admin-java copied to clipboard

Application Default Credentials take precedence over EmulatorCredentials

Open mitschwimmer opened this issue 2 years ago • 2 comments

Environment

  • Operating System version: Fedora 35
  • Firebase SDK version: Firebase Admin Java
  • Library version: 8.1.0
  • Firebase Product: firestore

Problem

If I have an Application Default Credentials File in ~/.config/gcloud/ than I get a warning about using user credentials for a server application while running my test against the emulator. I do not expect to get this message as I am initializing the SDK with credentials provided and Javadoc for the Firestore Builder states that Application Defaults are only taken if Credentials are null.

Steps to reproduce:

Initialize the SDK in a Junit test like stated below.

Starting the test, the SDK will log the following message if there are Application Default Credentials: "WARN com.google.auth.oauth2.DefaultCredentialsProvider - Your application has authenticated using end user credentials from Google Cloud SDK. We recommend that most server applications use service accounts instead. If your application continues to use end user credentials from Cloud SDK, you might receive a "quota exceeded" or "API not enabled" error. For more information about service accounts, see https://cloud.google.com/docs/authentication/."

Though, the test itself seems to run against the emulator just fine. Once I remove the Credentials by moving the credentials file, the test runs without warning.

Relevant Code:

private val firestoreEmulator: Firestore by lazy {
		FirestoreOptions.getDefaultInstance().toBuilder()
			.setEmulatorHost(emulator.emulatorEndpoint)
			.setCredentials(FirestoreOptions.EmulatorCredentials())
			.setProjectId("demo-project")
			.build().service
	}

mitschwimmer avatar Jan 26 '22 08:01 mitschwimmer

I couldn't figure out how to label this issue, so I've labeled it for a human to triage. Hang tight.

google-oss-bot avatar Jan 26 '22 08:01 google-oss-bot

Hi, thanks for filing this issue! We are unable to promise any timeline for this, but if others also have this issue, adding a +1 on this issue can help us prioritize adding this to the roadmap.

(Googler-only internal tracking bug: b/218520192)

yuchenshi avatar Feb 08 '22 19:02 yuchenshi