Angular2 +-作为变量传递时找不到模块-测试

时间:2018-08-24 08:51:30

标签: javascript angular typescript testing require

在测试中,我需要一个.json文件,其中包含要检查的数据。但是,我似乎无法将在哪里找到它的字符串传递到require ...

工作代码

const data = require('../../../assets/data.json');

不起作用

const jsonUrl = '../../../assets/data.json';
const data = require(jsonUrl);

我想使用变量jsonUrl,因为此url字符串将在测试本身中使用几次。我只是不明白为什么找不到它?


修正问题:

由于模拟是进行此操作的方式,因此我不确定该如何执行...我正在修改问题以帮助解决此问题。

根据我对测试的考虑,我假设我需要读入我实际使用的数据,然后进行测试。如果我错了,请纠正我。

这是我正在测试的...

data.json

[
  {
    "name": "one",
    "id": 1,
  },
  ...
  // This format is used for approx 20 entries
]

component.ts

ngOnInit() {
   loadData().subscribe(data => {
       this.data = data;
    };
}

loadData() {
   const statusUrl = '../../../assets/data.json';
   return this.httpClient.get(statusUrl);
}

test.ts ,由于上述要求问题,接收方找不到模块。

it('should load status data from local json', fakeAsync(() => {
    const jsonUrl = '../../../assets/status.json';
    const data = require(jsonUrl);
    const request = httpMock.expectOne(jsonUrl);
    request.flush(data);
    expect(component.status).toEqual(data);
  }));

1 个答案:

答案 0 :(得分:0)

通过使它等于任何种类的对象来解决:

it('should load status data from local json', fakeAsync(() => {
    const jsonUrl = '../../../assets/greyhound.status.json';
    const data = [];

    const request = httpMock.expectOne(jsonUrl);
    request.flush(data);
    expect(component.raceStatuses).toEqual(data);
  }));