[英]How to create fake object from a data type in Typescript for testing
我正在寻找一种方法来简化在 Angular 解决方案中为单元测试制作假数据。 我正在使用如下接口:
export interface ReferenceDataItemCommon {
codeDescription?: string;
code: string;
deleted?: boolean;
}
作为应用程序中的数据类型。 目前使用 Factory.ts + Faker 为测试目的创建假对象:
export const fakeReferenceDataItemCommon = Factory.Sync.makeFactory<ReferenceDataItemCommon>({
code: Factory.each(() => Faker.lorem.word()),
codeDescription: Factory.each(() => Faker.lorem.sentence(4)),
});
但是我很好奇是否有一种方法可以进一步简化它,因为您只需要一个 object 来进行测试并更快地创建它。 Typescript 中是否有可能有一个通用方法返回该数据类型的 object?
const fake = createFake<ReferenceDataItemCommon>();
我最初的想法是做类似的事情:
Object.keys(object).forEach(key => {
switch(typeof object[key]) {
case 'string':
object[key] = Faker.lorem.word();
break;
}
}
return object;
对于复杂的 object 递归调用此方法。 这有可能吗,如果我觉得有点超出我的深度,那么有什么更好的方法来做到这一点?
当您使用 cli 创建工厂时,而不是在运行时,它是可能的:
我也在寻找类似的东西,但也没有找到。 因此,我创建了这个库https://www.npmjs.com/package/class-validator-mocker ,它适用于使用类验证器装饰器注释的类。 如果您可以使用数据类而不是接口来定义某些类型,我认为值得一看。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.