Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Emulator Idempotency: Auth #8750

Merged
merged 7 commits into from
Feb 11, 2025
Merged

Emulator Idempotency: Auth #8750

merged 7 commits into from
Feb 11, 2025

Conversation

DellaBitta
Copy link
Contributor

@DellaBitta DellaBitta commented Feb 3, 2025

Discussion

Update the connectAuthEmulator function to support its invocation more than once. If the Auth instance is already in use, and connectAuthEmulator is invoked with the same configuration, then the invocation will now succeed instead of assert.

This unlocks support for web frameworks which may render the page numerous times with the same instances of auth. Before this PR customers needed to add extra code to guard against calling connectAuthEmulator in their SSR logic. Now we do that guarding logic on their behalf which should simplify our customer's apps.

Fixes #6824.

Testing

CI, new tests added to packages/auth/src/core/auth/emulator.test.ts.

API Changes

N/A

Copy link

changeset-bot bot commented Feb 3, 2025

🦋 Changeset detected

Latest commit: c829d99

The changes in this PR will be included in the next version bump.

This PR includes changesets to release 3 packages
Name Type
@firebase/auth Patch
firebase Patch
@firebase/auth-compat Patch

Not sure what this means? Click here to learn what changesets are.

Click here if you're a maintainer who wants to add another changeset to this PR

Copy link
Contributor

github-actions bot commented Feb 3, 2025

Vertex AI Mock Responses Check ⚠️

A newer major version of the mock responses for Vertex AI unit tests is available. update_vertexai_responses.sh should be updated to clone the latest version of the responses: v6.1

@google-oss-bot
Copy link
Contributor

google-oss-bot commented Feb 3, 2025

Size Report 1

Affected Products

  • @firebase/app

    TypeBase (82373b3)Merge (00b3787)Diff
    browser19.5 kB19.5 kB-1 B (-0.0%)
    main20.4 kB20.4 kB-1 B (-0.0%)
    module19.5 kB19.5 kB-1 B (-0.0%)
  • @firebase/auth

    TypeBase (82373b3)Merge (00b3787)Diff
    browser188 kB189 kB+750 B (+0.4%)
    cordova164 kB164 kB+750 B (+0.5%)
    main145 kB146 kB+760 B (+0.5%)
    module188 kB189 kB+750 B (+0.4%)
    react-native163 kB164 kB+760 B (+0.5%)
  • @firebase/auth-cordova

    TypeBase (82373b3)Merge (00b3787)Diff
    browser164 kB164 kB+750 B (+0.5%)
    module164 kB164 kB+750 B (+0.5%)
  • @firebase/auth-web-extension

    TypeBase (82373b3)Merge (00b3787)Diff
    browser140 kB141 kB+750 B (+0.5%)
    main157 kB158 kB+764 B (+0.5%)
    module140 kB141 kB+750 B (+0.5%)
  • @firebase/auth/internal

    TypeBase (82373b3)Merge (00b3787)Diff
    browser199 kB200 kB+750 B (+0.4%)
    main171 kB172 kB+768 B (+0.4%)
    module199 kB200 kB+750 B (+0.4%)
  • @firebase/data-connect

    TypeBase (82373b3)Merge (00b3787)Diff
    browser20.3 kB21.1 kB+835 B (+4.1%)
    main22.2 kB23.1 kB+933 B (+4.2%)
    module20.3 kB21.1 kB+835 B (+4.1%)
  • @firebase/database-compat/standalone

    TypeBase (82373b3)Merge (00b3787)Diff
    main366 kB366 kB+111 B (+0.0%)
  • @firebase/firestore

    TypeBase (82373b3)Merge (00b3787)Diff
    browser380 kB381 kB+334 B (+0.1%)
    main589 kB589 kB+373 B (+0.1%)
    module380 kB381 kB+334 B (+0.1%)
    react-native380 kB381 kB+334 B (+0.1%)
  • @firebase/firestore-lite

    TypeBase (82373b3)Merge (00b3787)Diff
    browser112 kB112 kB+393 B (+0.4%)
    main154 kB154 kB+421 B (+0.3%)
    module112 kB112 kB+393 B (+0.4%)
    react-native112 kB112 kB+393 B (+0.4%)
  • @firebase/performance

    TypeBase (82373b3)Merge (00b3787)Diff
    browser30.6 kB30.6 kB-1 B (-0.0%)
    main31.1 kB31.1 kB-1 B (-0.0%)
    module30.6 kB30.6 kB-1 B (-0.0%)
  • bundle

    46 size changes

    TypeBase (82373b3)Merge (00b3787)Diff
    analytics (logEvent)44.7 kB44.7 kB-1 B (-0.0%)
    app-check (CustomProvider)37.4 kB37.4 kB-1 B (-0.0%)
    app-check (ReCaptchaEnterpriseProvider)39.9 kB39.9 kB-1 B (-0.0%)
    app-check (ReCaptchaV3Provider)39.9 kB39.9 kB-1 B (-0.0%)
    auth (Anonymous)76.5 kB76.6 kB+146 B (+0.2%)
    auth (EmailAndPassword)86.6 kB86.8 kB+146 B (+0.2%)
    auth (GoogleFBTwitterGitHubPopup)103 kB104 kB+291 B (+0.3%)
    auth (GooglePopup)101 kB101 kB+146 B (+0.1%)
    auth (GoogleRedirect)101 kB101 kB+146 B (+0.1%)
    auth (Phone)94.0 kB94.2 kB+146 B (+0.2%)
    database (Append to a list of data)150 kB150 kB-1 B (-0.0%)
    database (Filtering data)148 kB148 kB-1 B (-0.0%)
    database (Listen for child events)165 kB165 kB-1 B (-0.0%)
    database (Listen for value events + Detach listeners)165 kB165 kB-1 B (-0.0%)
    database (Listen for value events)165 kB165 kB-1 B (-0.0%)
    database (Read data once)164 kB164 kB-1 B (-0.0%)
    database (Save data as transactions)167 kB167 kB-1 B (-0.0%)
    database (Sort data)150 kB150 kB-1 B (-0.0%)
    database (Write data)149 kB149 kB-1 B (-0.0%)
    firestore (CSI Auto Indexing Disable and Delete)271 kB271 kB+195 B (+0.1%)
    firestore (CSI Auto Indexing Enable)271 kB271 kB+195 B (+0.1%)
    firestore (Persistence)302 kB303 kB+158 B (+0.1%)
    firestore (Query Cursors)249 kB250 kB+158 B (+0.1%)
    firestore (Query)247 kB247 kB+158 B (+0.1%)
    firestore (Read data once)235 kB235 kB+158 B (+0.1%)
    firestore (Read Write w Persistence)327 kB327 kB+158 B (+0.0%)
    firestore (Realtime updates)237 kB237 kB+158 B (+0.1%)
    firestore (Transaction)214 kB214 kB+195 B (+0.1%)
    firestore (Write data)214 kB214 kB+195 B (+0.1%)
    firestore-lite (Query Cursors)103 kB103 kB+195 B (+0.2%)
    firestore-lite (Query)99.2 kB99.4 kB+195 B (+0.2%)
    firestore-lite (Read data once)74.6 kB74.8 kB+195 B (+0.3%)
    firestore-lite (Transaction)99.9 kB100 kB+195 B (+0.2%)
    firestore-lite (Write data)84.2 kB84.4 kB+195 B (+0.2%)
    functions (call)34.8 kB34.8 kB-3 B (-0.0%)
    messaging (send + receive)47.5 kB47.5 kB-1 B (-0.0%)
    performance (trace)62.4 kB62.4 kB-2 B (-0.0%)
    remote-config (getAndFetch)47.7 kB47.7 kB-1 B (-0.0%)
    storage (getBytes)42.4 kB42.4 kB-1 B (-0.0%)
    storage (getDownloadURL)44.5 kB44.5 kB-1 B (-0.0%)
    storage (getMetadata)43.9 kB43.9 kB-1 B (-0.0%)
    storage (list + listAll)43.3 kB43.3 kB-1 B (-0.0%)
    storage (updateMetadata)44.2 kB44.2 kB-1 B (-0.0%)
    storage (uploadBytes)49.0 kB49.0 kB-1 B (-0.0%)
    storage (uploadBytesResumable)59.0 kB59.0 kB-1 B (-0.0%)
    storage (uploadString)49.3 kB49.3 kB-1 B (-0.0%)

  • firebase

    23 size changes

    TypeBase (82373b3)Merge (00b3787)Diff
    firebase-analytics-compat.js26.5 kB25.7 kB-795 B (-3.0%)
    firebase-app-check-compat.js23.2 kB22.6 kB-615 B (-2.6%)
    firebase-app-compat.js32.5 kB31.8 kB-701 B (-2.2%)
    firebase-app.js103 kB103 kB-1 B (-0.0%)
    firebase-auth-compat.js143 kB140 kB-2.94 kB (-2.1%)
    firebase-auth-cordova.js136 kB137 kB+598 B (+0.4%)
    firebase-auth-web-extension.js119 kB119 kB+598 B (+0.5%)
    firebase-auth.js155 kB155 kB+598 B (+0.4%)
    firebase-compat.js808 kB791 kB-16.7 kB (-2.1%)
    firebase-data-connect.js16.8 kB17.3 kB+554 B (+3.3%)
    firebase-database-compat.js166 kB164 kB-2.85 kB (-1.7%)
    firebase-firestore-compat.js345 kB339 kB-6.43 kB (-1.9%)
    firebase-firestore-lite.js130 kB131 kB+393 B (+0.3%)
    firebase-firestore.js439 kB439 kB+334 B (+0.1%)
    firebase-functions-compat.js10.6 kB10.4 kB-254 B (-2.4%)
    firebase-installations-compat.js13.3 kB12.9 kB-384 B (-2.9%)
    firebase-messaging-compat.js38.7 kB37.0 kB-1.64 kB (-4.2%)
    firebase-performance-compat.js40.9 kB40.0 kB-869 B (-2.1%)
    firebase-performance-standalone-compat.js105 kB105 kB-2 B (-0.0%)
    firebase-performance.js45.5 kB45.5 kB-1 B (-0.0%)
    firebase-remote-config-compat.js28.4 kB27.8 kB-564 B (-2.0%)
    firebase-storage-compat.js40.4 kB39.7 kB-690 B (-1.7%)
    firebase-vertexai.js24.0 kB24.2 kB+238 B (+1.0%)

Test Logs

  1. https://storage.googleapis.com/firebase-sdk-metric-reports/eSZK8D09Tx.html

@google-oss-bot
Copy link
Contributor

google-oss-bot commented Feb 3, 2025

Size Analysis Report 1

This report is too large (639,879 characters) to be displayed here in a GitHub comment. Please use the below link to see the full report on Google Cloud Storage.

Test Logs

  1. https://storage.googleapis.com/firebase-sdk-metric-reports/3hQERRab3Z.html

@DellaBitta DellaBitta marked this pull request as ready for review February 4, 2025 15:23
host,
port,
protocol: protocol.replace(':', ''),
options: Object.freeze({ disableWarnings })
});

if (!authInternal._canInitEmulator) {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think this technically works but it doesn't make the logic clear. There's two reasons to throw here, one is if they're calling this for the first time too late (after a network call has been made, that's the purpose of authInternal._canInitEmulator), and the second reason is if they're calling it for a second time with different args. This makes it look like we're only targeting the second case. It will actually work on the first case, of course, because the local vars emulator and emulatorConfig will have some properties, and won't match {}, but I guess the fact it's nested inside a deepEqual doesn't make it clear that's a case we're trying to block on.

I know it's more verbose, but instead of the || {} maybe a separate _assert before this one that just tests for the existence of authInternal.config.emulator and authInternal.emulatorConfig would make it clearer that we're covering 2 different cases?

Fixed typo in `multiple`
@DellaBitta DellaBitta merged commit c791ecf into main Feb 11, 2025
48 of 49 checks passed
@DellaBitta DellaBitta deleted the ddb-auth-emulator-reconnect branch February 11, 2025 21:59
@google-oss-bot google-oss-bot mentioned this pull request Feb 14, 2025
@firebase firebase locked and limited conversation to collaborators Mar 14, 2025
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

two attempts to connect to auth emulator cause config error
5 participants