Grunt,Istanbul,Isparta和TypeScript

时间:2016-07-21 13:50:14

标签: gruntjs istanbul remap-istanbul isparta grunt-istanbul

TL; DR

有没有人使用Grunt和Jasmine成功生成报道?

长篇故事:

我有一些用Jasmine编写的测试,我想为此生成一些覆盖信息。为了通用,我实际上使用了grunt-istanbul,它允许一个指导员(比如isparta)来检测我的代码,然后生成一个报告。但是,此报告基于已转换的代码(因此在JavaScript中)。

然后我遇到了istanbul重映射,它查看由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"
            }
        },

1 个答案:

答案 0 :(得分:0)

实际上,我已经能够弄明白了。这里的诀窍如下:

  1. 使用地图编译代码
  2. 将代码复制到临时位置
  3. 仪器代码
  4. 执行测试
  5. 从临时位置复制代码
  6. 生成报告
  7. 这可能看起来很笨拙,但它确实有效!在我的grunt文件中,我添加了一个复制任务来为我自动化这些临时位置副本。

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