Angular2测试

时间:2017-02-07 04:51:45

标签: unit-testing angular jasmine

坚持如何测试具有很多第三方依赖关系的组件。我很确定我以错误的方式接近它,我不知道从哪里开始。这是组件:

import { Component, OnInit } from '@angular/core';
import { Http, Response } from '@angular/http';

import { GameService } from '../game.service';
import { environment } from '../../../environments/environment';

import { ActivatedRoute } from '@angular/router';
import { SlimLoadingBarService } from 'ng2-slim-loading-bar';

@Component({
  selector: 'app-list',
  templateUrl: 'list.component.html',
  styleUrls: ['list.component.scss']
})

export class ListComponent implements OnInit {
  config = environment.config;
  games;
  headers;
  params = {
    searchTerm: '',
    searchOwner: '',
    searchType: '',
    order: 'name',
    orderType: 'DESC',
    currentPage: 1,
    page: 1
  };
  pages;
  totalRecords;
  recordsPerPage = 25;
  exportUrl;
  personasPage = 1;
  searchUrl = environment.config.apiUrl + 'personas/';
  public buffer: any;
  public personas: any;
  buttonSpinner: string = 'none';

  constructor(
    private gameService: GameService,
    private http: Http,
    private route: ActivatedRoute,
    private loadingBar: SlimLoadingBarService
  ) { }

  ngOnInit() {
    this.getListing();
    this.getPersonas();
  }

  sort(e, order) {
    e.preventDefault();
    this.params.orderType = (order === this.params.order && this.params.orderType === 'DESC') ? 'ASC' : 'DESC';
    this.params.order = order;
    this.params.page = this.params.currentPage = 1;
    this.getListing();
  }

  updateListing(page) {
    this.params.page = this.params.currentPage = page;
    this.getListing();
  }

  getListing() {
    this.loadingBar.start();
    this.gameService.getGames(this.params)
      .subscribe((res) => {
        this.loadingBar.complete();
        this.buttonSpinner = 'none';

        this.games = res.json();
        this.headers = res.headers;

        this.totalRecords = this.headers.get('x-total');
        this.recordsPerPage = this.headers.get('x-limit');

        this.exportUrl = this.gameService.getExportLink(this.params);
      });
  }

  getPersonas() {
    this.http.get(this.searchUrl + '?page=' + this.personasPage)
    .map((res: Response) => res.json())
    .subscribe((d: {}) => {
      this.buffer = d;
      if (this.personas === undefined) {
        this.personas = this.buffer;
        // console.log(this.personas);
        this.personasPage += 1;
        this.getPersonas();
      } else {
        for (let key in this.buffer) {
          this.personas.push(this.buffer[key]);
        }
        this.personasPage += 1;
        if (this.buffer.length === 25) {
          this.getPersonas();
        }
      }
    });
  }

  onSubmitSearch() {
    this.buttonSpinner = 'searching';
    this.params.page = this.params.currentPage = 1;
    this.getListing();
  }

  clearSearch(e) {
    e.preventDefault();
    this.buttonSpinner = 'clearing';
    this.params.searchTerm = '';
    this.params.searchType = '';
    this.params.searchOwner = '';
    this.params.page = this.params.currentPage = 1;
    this.getListing();
  }
}

这是我尝试过的测试:

import { TestBed, async, ComponentFixture } from '@angular/core/testing';
import {} from 'jasmine';
import { Http } from '@angular/http';
import { ActivatedRoute, RouterModule } from '@angular/router';
import { CUSTOM_ELEMENTS_SCHEMA } from '@angular/core';
import { FormsModule } from '@angular/forms';

import { ListComponent } from './list.component';
import { GameService } from '../game.service';
import { PageitComponent } from '../../shared/pageit/pageit.component';

import { SlimLoadingBarService } from 'ng2-slim-loading-bar';
import { LaddaModule } from 'angular2-ladda';

describe('ListComponent', () => {
  let gameService, http, route, loadingBar;
  let component: ListComponent;
  let fixture: ComponentFixture<ListComponent>;

  beforeEach(() => {
    TestBed.configureTestingModule({
      declarations: [ ListComponent, PageitComponent ],
      providers: [
        { provide: GameService, useValue: gameService }, { provide: Http, useValue: http }, { provide: ActivatedRoute, useValue: route },
        { provide: SlimLoadingBarService, useValue: loadingBar }
      ],
      imports: [FormsModule, LaddaModule, RouterModule]
    }).compileComponents();
  });

  beforeEach(() => {
    fixture = TestBed.createComponent(ListComponent);
    component = fixture.componentInstance;
  });

  it('should create an instance of the component', () => {
    component.ngOnInit();
    expect(component).toBeDefined();
  });
});

到目前为止,我已经认识到了init,现在因为this.loadingBar.start();函数中的getListing而崩溃了。

1 个答案:

答案 0 :(得分:0)

通过使用expect(mockService.someMethod).toHaveBeenCalled()检查它是否生成正确的服务类,只需模拟所有服务并测试组件的行为。

例如

let loadingBar: SlimLoadingBarService;
let gameService: GameService;

beforeEach(() => {
  loadingBar = { 
    start: jasmine.createSpy('start'),
    complete: jasmine.createSpy('complete')
  };
  gameService = {
    getGames: (params) => Observable.of(whatever)
  };

  TestBed.configureTestingModule({
    providers: [
      { provide: SlimLoadingBarService, useValue: loadingBar },
      { provide: GameService, useValue: gameService }
    ]
  })
})

it('..', () -> {
  component.getListing();

  expect(loadingBar.start).toHaveBeenCalled();

  // component calls gameService.getGames is called, wait for async
  // to finish by called fixture.whenStable

  fixture.whenStable().then(() => {
    expect(loadingBar.complete).toHaveBeedCalled();
  })
})

对于你在组件中的Http调用,我会将其抽象为一个服务,以便你可以模拟该服务。