Skip to content

Database connectivity errors are not propagated #2004

Open
@mctavish

Description

@mctavish

Step 2: Describe your environment

  • Operating System version: all
  • Firebase SDK version: 10+
  • Firebase Product: database
  • Node.js version: all
  • NPM version: all

Step 3: Describe the problem

Errors in connecting to the database are not propagated to user's code. Instead, the library will wait indefinitely when an attempt is made to read or write to the database.

Steps to reproduce:

Provide either:

  • valid credentials that do not have correct scopes or permissions to access the database
  • invalid database url

App initialization will succeed.

Attempt to read or write to the database, triggering an attempt to connect to the database.

Errors will be written to the console, but the error handlers (either the callback on set() or promise rejections) will not be called.

Example error in logs:

@firebase/database: FIREBASE WARNING: Firebase error. Please ensure that you have the URL of your Firebase Realtime Database instance configured correctly.

Note that this is appears to be a change going from v9 to v10 of the firebase-admin library.

Relevant Code:

const firebase = require('firebase-admin');

const app = firebase.initializeApp({
  credential: credentialWithoutPermissions,  // only one of these mistakes is required.
  databaseURL: wrongDatabaseUrl,
});

const db = firebase.database();

db.ref('foo').get().then(
  () => {
    // won't be called because it won't succeed
  },
 err => {
    // won't be called because the failure doesn't propagate
  });

Metadata

Metadata

Assignees

No one assigned

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions