12

我需要能够模拟激活的路由参数才能测试我的组件。

到目前为止,这是我最好的尝试,但它不起作用。

{ provide: ActivatedRoute, useValue: { params: [ { 'id': 1 } ] } },

ActivatedRoute 在实际组件中使用如下:

this.route.params.subscribe(params => {
    this.stateId = +params['id'];

    this.stateService.getState(this.stateId).then(state => {
        this.state = state;
    });
});

我当前尝试得到的错误很简单:

TypeError: undefined is not a constructor (evaluating 'this.route.params.subscribe')

任何帮助将不胜感激。

4

2 回答 2

37

您的模拟必须反映它正在替换的对象。你.subscribe因为它返回一个可观察的,而不仅仅是对象,所以你的模拟值也应该:

import { Observable } from 'rxjs/Rx';

...

{ provide: ActivatedRoute, useValue: { 'params': Observable.from([{ 'id': 1 }]) } }
于 2016-09-07T18:36:31.267 回答
7

@jonrsharpe 给出的答案允许您模拟params,但这些参数在每个测试中都是相同的。

如果您希望能够更改params, 在测试开始时设置它,您可以这样做:

在顶部:

describe('SomeComponent', () => {
  (...)
  let params: Subject<Params>;
  (...)

beforeEachasync你拥有的那个importsproviders等等):

beforeEach(async(() => {
  params = new Subject<Params>();
  (...)

providers

  (...)
  {
    provide: ActivatedRoute,
    useValue: {
      params: params
    }
  }
  (...)

然后在测试中:

it('someTest', () => {
  params.next({'id': '123'});
  fixture.detectChanges();
  (...)

重要的提示

一定要打电话fixture.detectChangesparams.next

这意味着您应该从每个测试中删除fixture.detectChanges并将beforeEach其添加到每个测试中。

于 2018-03-09T11:32:44.853 回答