All files / api create-installation.test.ts

100% Statements 26/26
100% Branches 0/0
100% Functions 2/2
100% Lines 25/25

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                                  2x 1x             1x 1x 1x 1x         1x   1x   1x         1x 2x   2x                             2x         1x 1x       1x         1x 1x         1x           1x         1x   2x 1x 1x 1x      
/**
 * @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 { expect } from 'chai';
import { SinonStub, stub } from 'sinon';
import { CreateInstallationResponse } from '../interfaces/api-response';
import { AppConfig } from '../interfaces/app-config';
import {
  InProgressInstallationEntry,
  RequestStatus
} from '../interfaces/installation-entry';
import { compareHeaders } from '../testing/compare-headers';
import { getFakeAppConfig } from '../testing/get-fake-app';
import '../testing/setup';
import {
  INSTALLATIONS_API_URL,
  INTERNAL_AUTH_VERSION,
  PACKAGE_VERSION
} from '../util/constants';
import { createInstallation } from './create-installation';
 
const FID = 'defenders-of-the-faith';
 
describe('api', () => {
  let appConfig: AppConfig;
  let fetchSpy: SinonStub<[RequestInfo, RequestInit?], Promise<Response>>;
  let inProgressInstallationEntry: InProgressInstallationEntry;
 
  beforeEach(() => {
    appConfig = getFakeAppConfig();
 
    inProgressInstallationEntry = {
      fid: FID,
      registrationStatus: RequestStatus.IN_PROGRESS,
      registrationTime: Date.now()
    };
 
    const response: CreateInstallationResponse = {
      refreshToken: 'refreshToken',
      authToken: {
        token:
          'eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCeKKF2QT4fwpMeJf36POk6yJV_adQssw5c',
        expiresIn: '604800s'
      }
    };
 
    fetchSpy = stub(self, 'fetch').resolves(
      new Response(JSON.stringify(response))
    );
  });
 
  it('registers a pending InstallationEntry', async () => {
    const registeredInstallationEntry = await createInstallation(
      appConfig,
      inProgressInstallationEntry
    );
    expect(registeredInstallationEntry.registrationStatus).to.equal(
      RequestStatus.COMPLETED
    );
  });
 
  it('calls the createInstallation server API with correct parameters', async () => {
    const expectedHeaders = new Headers({
      'Content-Type': 'application/json',
      Accept: 'application/json',
      'x-goog-api-key': 'apiKey'
    });
    const expectedBody = {
      fid: FID,
      authVersion: INTERNAL_AUTH_VERSION,
      appId: appConfig.appId,
      sdkVersion: PACKAGE_VERSION
    };
    const expectedRequest: RequestInit = {
      method: 'POST',
      headers: expectedHeaders,
      body: JSON.stringify(expectedBody)
    };
    const expectedEndpoint = `${INSTALLATIONS_API_URL}/projects/projectId/installations`;
 
    await createInstallation(appConfig, inProgressInstallationEntry);
    expect(fetchSpy).to.be.calledOnceWith(expectedEndpoint, expectedRequest);
    const actualHeaders = fetchSpy.lastCall.lastArg.headers;
    compareHeaders(expectedHeaders, actualHeaders);
  });
});