All files / functions delete-installation.test.ts

100% Statements 47/47
100% Branches 1/1
100% Functions 8/8
100% Lines 42/42

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130                                    1x 1x 1x 1x 1x               1x 1x   1x 1x   1x   1x               1x 5x 5x   5x       1x       1x 2x 1x     1x 1x       2x   2x 1x 2x     1x 1x         2x   2x     1x     1x 1x                     2x 1x   2x     1x     1x 1x                     2x   2x 1x 2x      
/**
 * @license
 * Copyright 2019 Google Inc.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *   http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
 
import { FirebaseApp } from '@firebase/app-types';
import { expect } from 'chai';
import { SinonStub, stub } from 'sinon';
import * as deleteInstallationModule from '../api/delete-installation';
import { extractAppConfig } from '../helpers/extract-app-config';
import { get, set } from '../helpers/idb-manager';
import { AppConfig } from '../interfaces/app-config';
import {
  InProgressInstallationEntry,
  RegisteredInstallationEntry,
  RequestStatus,
  UnregisteredInstallationEntry
} from '../interfaces/installation-entry';
import { getFakeApp } from '../testing/get-fake-app';
import '../testing/setup';
import { ErrorCode } from '../util/errors';
import { sleep } from '../util/sleep';
import { deleteInstallation } from './delete-installation';
 
const FID = 'children-of-the-damned';
 
describe('deleteInstallation', () => {
  let app: FirebaseApp;
  let appConfig: AppConfig;
  let deleteInstallationSpy: SinonStub<
    [AppConfig, RegisteredInstallationEntry],
    Promise<void>
  >;
 
  beforeEach(() => {
    app = getFakeApp();
    appConfig = extractAppConfig(app);
 
    deleteInstallationSpy = stub(
      deleteInstallationModule,
      'deleteInstallation'
    ).callsFake(
      () => sleep(100) // Request would take some time
    );
  });
 
  it('resolves without calling server API if there is no installation', async () => {
    await expect(deleteInstallation(app)).to.be.fulfilled;
    expect(deleteInstallationSpy).not.to.have.been.called;
  });
 
  it('deletes and resolves without calling server API if the installation is unregistered', async () => {
    const entry: UnregisteredInstallationEntry = {
      registrationStatus: RequestStatus.NOT_STARTED,
      fid: FID
    };
    await set(appConfig, entry);
 
    await expect(deleteInstallation(app)).to.be.fulfilled;
    expect(deleteInstallationSpy).not.to.have.been.called;
    await expect(get(appConfig)).to.eventually.be.undefined;
  });
 
  it('rejects without calling server API if the installation is pending', async () => {
    const entry: InProgressInstallationEntry = {
      fid: FID,
      registrationStatus: RequestStatus.IN_PROGRESS,
      registrationTime: Date.now() - 3 * 1000
    };
    await set(appConfig, entry);
 
    await expect(deleteInstallation(app)).to.be.rejectedWith(
      ErrorCode.DELETE_PENDING_REGISTRATION
    );
    expect(deleteInstallationSpy).not.to.have.been.called;
  });
 
  it('rejects without calling server API if the installation is registered and app is offline', async () => {
    const entry: RegisteredInstallationEntry = {
      fid: FID,
      registrationStatus: RequestStatus.COMPLETED,
      refreshToken: 'refreshToken',
      authToken: {
        token: 'authToken',
        expiresIn: 123456,
        requestStatus: RequestStatus.COMPLETED,
        creationTime: Date.now()
      }
    };
    await set(appConfig, entry);
    stub(navigator, 'onLine').value(false);
 
    await expect(deleteInstallation(app)).to.be.rejectedWith(
      ErrorCode.APP_OFFLINE
    );
    expect(deleteInstallationSpy).not.to.have.been.called;
  });
 
  it('deletes and resolves after calling server API if the installation is registered', async () => {
    const entry: RegisteredInstallationEntry = {
      fid: FID,
      registrationStatus: RequestStatus.COMPLETED,
      refreshToken: 'refreshToken',
      authToken: {
        token: 'authToken',
        expiresIn: 123456,
        requestStatus: RequestStatus.COMPLETED,
        creationTime: Date.now()
      }
    };
    await set(appConfig, entry);
 
    await expect(deleteInstallation(app)).to.be.fulfilled;
    expect(deleteInstallationSpy).to.have.been.calledOnceWith(appConfig, entry);
    await expect(get(appConfig)).to.eventually.be.undefined;
  });
});