繁体   English   中英

如何用 Jest 单元测试覆盖 TypeORM @Column 装饰器?

[英]How to cover TypeORM @Column decorator with Jest unit testing?

我想尽可能多地对我的应用程序进行单元和 e2e 测试,我的目标是 101% 的覆盖率。 我的设置现在的问题是,来自 typeorm 的 @Column 装饰器使用箭头 function 来设置默认值,例如数据库更新的当前时间戳。 这个箭头 function 没有被开玩笑测试覆盖。 消息是: statement not covered

我运行代码覆盖率: jest --coverage 我的版本:

"jest": "^24.9.0",
"typeorm": "^0.2.20"

package.json 中的笑话配置:

{
  "jest": {
    "moduleFileExtensions": [
      "js",
      "json",
      "ts"
    ],
    "rootDir": "src",
    "testRegex": ".spec.ts$",
    "transform": {
      "^.+\\.(t|j)s$": "ts-jest"
    },
    "coverageDirectory": "../build/coverage",
    "testEnvironment": "node",
    "coverageThreshold": {
      "global": {
        "branches": 80,
        "functions": 80,
        "lines": 80,
        "statements": -10
      }
    }
  },
}

我的实体如下所示:

import { Column, Entity, PrimaryGeneratedColumn } from 'typeorm';

@Entity()
export class Role {
    @PrimaryGeneratedColumn()
    id: number;

    @Column()
    tenantId: number;

    @Column({ type: 'timestamp', update: false, default: () => 'CURRENT_TIMESTAMP()' })
    createdAt: Date;

    @Column({ type: 'timestamp', default: () => 'CURRENT_TIMESTAMP()', onUpdate: 'CURRENT_TIMESTAMP()' })
    updatedAt: Date;
}

该实体的覆盖范围:

(要发布一张图片,我需要 10 个声望 -.-): https://i.ibb.co/FYQgstP/Screenshot-2019-11-07-11-46-45.png

我在使用 GraphQL 装饰器时遇到了类似的问题。 由于所有这些都是函数,您可以做的是创建一个文件,其中包含您将使用的所有函数、命名并导出它们,以便您也可以实际测试它们并使用 Jest 获取覆盖范围。 (测试实际上应该类似于expect(namedFunction).toBe('CURRENT_TIMESTAMP()')或非常相似。例如, 您可以在此处查看我的 function 和此处的测试

编辑 2020 年 11 月 3 日

代码示例不再赘述。 话虽如此,您可以执行以下操作

export const returnString = () => String;

@Query(returnString)

对于 GraphQL。 对此的测试看起来像

expect(returnString()).toBe(String);

根据@JayMcDoniel 的回答,这是对我有用的解决方案。

  • 数据库类型: postgreSQl
  • 测试: jest/chai

功能 class:

  export abstract class EntityDefaultFunctions {
    public static defaultNull = (): string => 'NULL';
    public static defaultZero = (): string => '0';
  }

测试:

  expect(EntityDefaultFunctions.defaultNull()).to.equal('NULL');
  expect(EntityDefaultFunctions.defaultZero()).to.equal('0');

示例实体列定义:

  @Column('text', {
    default: EntityDefaultFunctions.defaultNull,
    name: 'somePropertyName'
  })

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM