3

TL;博士

有没有人使用 Grunt 和 Jasmine 成功生成覆盖率报告?

很长的故事:

我有一些用 Jasmine 编写的测试,我想为此生成一些覆盖率信息。为了通用,我实际上使用了 grunt-istanbul,它允许检测器(如 isparta)检测我的代码,然后生成报告。然而,这份报告是基于转译的代码(因此在 JavaScript 中)。

然后我遇到了 istanbul remap,它查看由 TypeScript 编译器生成的地图文件,并将结果基于此;但是,我的仪器在转译代码中添加了一些代码,这意味着我的地图文件不再匹配。至少,这是我的猜测,正如 istanbul-remap 所说:

错误:找不到源映射:“src/server/modules/service.js”

这是我的 grunt 配置的一部分:

instrument: {
            files: 'src/server/**/*.js',
            options: {
                lazy: false,
                basePath: '.',
                babel: {
                    sourceMap: true
                },
                instrumenter: require('isparta').Instrumenter
            }
        },
        storeCoverage: {
            options: {
                dir: 'coverage/reports-server/'
            }
        },
        remapIstanbul: {
            dist: {
                options: {
                    reports: {
                        "html": "./coverage/lcov-report",
                        "json": "./coverage/coverage.json"
                    }
                },
                src: "./coverage/reports-server/coverage.json"
            }
        },
4

1 回答 1

0

实际上,我已经能够自己弄清楚了。这里的诀窍如下:

  1. 用地图编译代码
  2. 将代码复制到临时位置
  3. 仪器代码
  4. 执行测试
  5. 从临时位置复制代码
  6. 生成报告

这可能看起来很笨重,但它确实有效!在我的 grunt 文件中,我添加了一个复制任务来为我自动执行这些临时位置副本。

最后,我得到了正确可靠的结果。

于 2016-10-24T06:50:15.410 回答