在测试中,我需要一个.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);
}));
答案 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);
}));