Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions rollup-globals.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,5 +7,6 @@ export default (mod) => {

if (mod === 'firebase') return 'firebase';
if (mod === '@angular/core') return 'ng.core';
if (mod === '@angular/platform-browser') return 'ng.platformBrowser';
if (mod === '@angular/core/testing') return 'ng.core.testing';
}
33 changes: 30 additions & 3 deletions src/angularfire2.spec.ts
Original file line number Diff line number Diff line change
@@ -1,16 +1,19 @@
import * as firebase from 'firebase/app';
import { TestBed, inject } from '@angular/core/testing';
import { ReflectiveInjector, Provider } from '@angular/core';
import { TestBed, inject, withModule, async } from '@angular/core/testing';
import { ReflectiveInjector, Provider, PlatformRef, NgModule, Compiler, ApplicationRef, CompilerFactory } from '@angular/core';
import { FirebaseApp, FirebaseAppConfig, AngularFireModule } from './angularfire2';
import { Subscription } from 'rxjs/Subscription';
import { COMMON_CONFIG } from './test-config';
import { BrowserModule } from '@angular/platform-browser';

describe('angularfire', () => {
let subscription:Subscription;
let app: FirebaseApp;
let rootRef: firebase.database.Reference;
let questionsRef: firebase.database.Reference;
let listOfQuestionsRef: firebase.database.Reference;
let defaultPlatform: PlatformRef;

const APP_NAME = 'super-awesome-test-firebase-app-name';

beforeEach(() => {
Expand All @@ -19,11 +22,12 @@ describe('angularfire', () => {
imports: [AngularFireModule.initializeApp(COMMON_CONFIG, APP_NAME)]
});

inject([FirebaseApp], (_app: FirebaseApp) => {
inject([FirebaseApp, PlatformRef], (_app: FirebaseApp, _platform: PlatformRef) => {
app = _app;
rootRef = app.database().ref();
questionsRef = rootRef.child('questions');
listOfQuestionsRef = rootRef.child('list-of-questions');
defaultPlatform = _platform;
})();

});
Expand All @@ -43,5 +47,28 @@ describe('angularfire', () => {
it('should have the provided name', () => {
expect(app.name).toBe(APP_NAME);
})
it('should use an already intialized firebase app if it exists', done => {
@NgModule({
imports: [
AngularFireModule.initializeApp(COMMON_CONFIG, APP_NAME),
BrowserModule
]})
class MyModule {
ngDoBootstrap() {}
}

const compilerFactory: CompilerFactory =
defaultPlatform.injector.get(CompilerFactory, null);
const moduleFactory = compilerFactory.createCompiler().compileModuleSync(MyModule);

defaultPlatform.bootstrapModuleFactory(moduleFactory)
.then(moduleRef => {
const ref = moduleRef.injector.get(FirebaseApp);
expect(ref.name).toEqual(app.name);
}).then(done, e => {
fail(e);
done()
});
})
});
});
4 changes: 4 additions & 0 deletions src/app/firebase.app.module.ts
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,10 @@ export function _firebaseAppFactory(config: FirebaseAppConfig, appName?: string)
}
}
catch (e) {
if (e.code === "app/duplicate-app") {
return firebase.app(e.name);
}

return firebase.app(null);
}
}