首页 > 解决方案 > 导入 json 文件来模拟我的测试数据

问题描述

我尝试在我的茉莉花测试中模拟数据。

在我使用的组件规范中:

describe('MyComponent', () => {
  const user: User = require('../../mocks/user.json');

我放在/src/mocks/services/service.stub.ts中的服务存根

import { Observable, of } from 'rxjs';

export const MyServiceStub =  {
  users: require('../../mocks/users.json'),

  getUsers(): Observable<any> {
    return of(this.users);
  }
};

有了这个npm run test工作,但应用程序没有编译,因为

src/app/mocks/services/UserServiceStub.ts(4,15) 中的错误:错误 TS2304:找不到名称“需要”。

我试过修改tsconfig.json

"compilerOptions": {
    "resolveJsonModule": true,
    "esModuleInterop": true  
  }

并使用以下命令导入模拟 json:

import * as users from '../../mocks/users.json';

这破坏了我所有的导入,比如 momentJS(import * as moment from 'moment')

我读到我可以添加

"allowSyntheticDefaultImports": true

但这并没有帮助...

在我的测试中导入 json 文件的正确方法是什么?

编辑:我忘了说require在我的规范文件中有效,当我在/src/mocks/services/MyService.stub.ts中使用它时它会失败

我将存根服务修改为一个类,并将提供程序更改为使用useClass而不是useValue但这没有帮助。

标签: angularunit-testingjasmine

解决方案


你可以有类似的东西:

export const USER_OBJECTS: User[] = [
    {
        'firstName': 'Ana',
        'lastName': '..',
        'fullName': '..',
        'userName': '..',
        'email': '...'
    } as User,
    {
        'firstName': 'Lisa',
        'lastName': '..',
        'fullName': '..',
        'userName': '...',
        'email': '...'
    } as User
];

在您的mocks/users.json.ts并将其导入到您的存根文件中,例如:

import {USERS_OBJECTS} from '../mocks/users.json.ts';

然后您的存根服务将如下所示:

export const MyServiceStub =  {
  users: require('../../mocks/users.json'),

  getUsers(): Observable<User[]> {
    return of(USER_OBJECTS);
  }
};

推荐阅读