我正在使用karma-coverage来测量我的项目中的单元测试覆盖率,在这方面一切都很好。我使用HTML reporter进入默认目录。
但是,我需要使用grunt git-describe获得的构建版本信息“标记”覆盖率报告,grunt git-describe当前用于加载生成的version.json文件的AngularJS应用程序页脚。我没有找到任何直接的方法来在karma-coverage的html报告中使用这个version.json文件。所以如果有人知道怎么做,我将不胜感激。
提前感谢!
发布于 2014-12-18 14:50:43
我确实设法通过某种工作实现了这一点。在运行karma之后,我在grunt中使用了文本替换模块来完成此操作。如果有人有更好的解决方案,请分享,因为这是一个有点黑客,但它工作得很好。当我的环境中的karma-coverage的html报告到达项目的根/coverage/文件夹时,我在那里的每个.html文件中进行了一个递归的文本替换,查找默认的页脚,并在那里添加我的版本信息……
首先,安装grunt text-replace
$ npm install grunt-text-replace --save-dev然后我在gruntfile.js中做了一个替换函数:
grunt.initConfig({
replace: {
coverage: {
src: ['coverage/**/*.html'],
overwrite: true,
replacements: [
{
from: '<div class="meta">Generated by',
to: function(){return grunt.config.get('task.replace.versionString');}
}
]
}
},
// and your other stuff in initConfig()为此,我在grunt中添加了一个新任务:
grunt.registerTask('coverage', 'Adds version info to coverage results', function(){
grunt.task.requires('version'); // The 'version' task creates a 'version.json' file
var vers = grunt.file.readJSON('version.json');
// Set the desired string to be used in text-replace -function
grunt.config.set('task.replace.versionString', '<div class="meta">Version ' + vers.version + ', Tag "' + vers.revision[0] + '"<br>Generated by');
grunt.task.run(['replace']);
});有点难看,但效果很好;-)
https://stackoverflow.com/questions/27503967
复制相似问题