https://github.com/angular/angular
Raw File
Tip revision: b40b5576df83745c42a45c6379038a51a90f8ac0 authored by Kara Erickson on 08 April 2020, 19:28:12 UTC
release: cut the v10.0.0-next.1 release
Tip revision: b40b557
api.service.spec.ts
import { HttpClientTestingModule, HttpTestingController } from '@angular/common/http/testing';
import { Injector } from '@angular/core';
import { TestBed } from '@angular/core/testing';

import { Logger } from 'app/shared/logger.service';

import { ApiService } from './api.service';

describe('ApiService', () => {

  let injector: Injector;
  let service: ApiService;
  let httpMock: HttpTestingController;

  beforeEach(() => {
    injector = TestBed.configureTestingModule({
      imports: [HttpClientTestingModule],
      providers: [
        ApiService,
        { provide: Logger, useClass: TestLogger }
      ]
    });

    service = injector.get<ApiService>(ApiService);
    httpMock = injector.get(HttpTestingController);
  });

  afterEach(() => httpMock.verify());

  it('should not immediately connect to the server', () => {
    httpMock.expectNone({});
    expect().nothing();  // Prevent jasmine from complaining about no expectations.
  });

  it('subscribers should be completed/unsubscribed when service destroyed', () => {
      let completed = false;

      service.sections.subscribe({complete: () => completed = true});

      service.ngOnDestroy();
      expect(completed).toBe(true);

      // Stop `httpMock.verify()` from complaining.
      httpMock.expectOne({});
  });

  describe('#sections', () => {

    it('first subscriber should fetch sections', done => {
      const data = [
        {name: 'a', title: 'A', path: '', items: [], deprecated: false},
        {name: 'b', title: 'B', path: '', items: [], deprecated: false},
      ];

      service.sections.subscribe(sections => {
        expect(sections).toEqual(data);
        done();
      });

      httpMock.expectOne({}).flush(data);
    });

    it('second subscriber should get previous sections and NOT trigger refetch', done => {
      const data = [
        {name: 'a', title: 'A', path: '', items: [], deprecated: false},
        {name: 'b', title: 'B', path: '', items: [], deprecated: false},
      ];
      let subscriptions = 0;

      service.sections.subscribe(sections => {
        subscriptions++;
        expect(sections).toEqual(data);
      });

      service.sections.subscribe(sections => {
        subscriptions++;
        expect(sections).toEqual(data);
        expect(subscriptions).toBe(2);
        done();
      });

      httpMock.expectOne({}).flush(data);
    });
  });

  describe('#fetchSections', () => {

    it('should connect to the server w/ expected URL', () => {
      service.fetchSections();
      httpMock.expectOne('generated/docs/api/api-list.json');
      expect().nothing();  // Prevent jasmine from complaining about no expectations.
    });

    it('should refresh the #sections observable w/ new content on second call', () => {

      let call = 0;

      let data = [
        {name: 'a', title: 'A', path: '', items: [], deprecated: false},
        {name: 'b', title: 'B', path: '', items: [], deprecated: false},
      ];

      service.sections.subscribe(sections => {
        // called twice during this test
        // (1) during subscribe
        // (2) after refresh
        expect(sections).toEqual(data, 'call ' + call++);
      });

      httpMock.expectOne({}).flush(data);

      // refresh/refetch
      data = [{name: 'c', title: 'C', path: '', items: [], deprecated: false}];
      service.fetchSections();
      httpMock.expectOne({}).flush(data);

      expect(call).toBe(2, 'should be called twice');
    });
  });
});

class TestLogger {
  log = jasmine.createSpy('log');
  error = jasmine.createSpy('error');
}
back to top