节点 - 使用 mocha 测试时更改输出颜色

Posted

技术标签:

【中文标题】节点 - 使用 mocha 测试时更改输出颜色【英文标题】:Node - change colors on the output when testing with mocha 【发布时间】:2018-12-11 05:28:26 【问题描述】:

我有一个gulp 任务负责使用mocha 运行测试用例。

gulp.task('test', ['cls'], () => 
    execout('mocha -r ts-node/register --timeout 999999 --colors test/*.test.ts');
);

我的问题是,如您所见,有一些很难看到的灰线:

我的问题是,我怎样才能改变这种颜色?

我成功尝试了这里推荐的方法(有效):https://github.com/mochajs/mocha/issues/802#issuecomment-18254298):

$ gulp test > >(perl -pe 's/\x1b\[90m/\x1b[92m/g') 2> >(perl -pe 's/\x1b\[90m/\x1b[92m/g' 1>&2)

但我不喜欢这样,因为我不想每次想运行该命令时都在命令行上写下所有内容。

然后我尝试将所有内容移到 gulp 任务中,如下所示:

gulp.task('test', ['cls'], () => 
    execout("mocha -r ts-node/register --timeout 999999 --colors test/*.test.ts > >(perl -pe 's/\x1b\[90m/\x1b[92m/g') 2> >(perl -pe 's/\x1b\[90m/\x1b[92m/g' 1>&2)");
);

然后我在终端上收到以下错误。

ERR: > was unexpected at this time.

另一方面,这里还有另一种建议/方法,但我不知道如何使用它:

https://github.com/mochajs/mocha/issues/1200#issuecomment-62780003

你知道如何修改那条难以阅读的灰线的颜色吗?

谢谢!

【问题讨论】:

【参考方案1】:

只需手动更改 base.js 中的颜色即可。

转到:您的项目 root\node_modules\mocha\lib\reporters\base.js 并玩弄数字..

 exports.colors = 
  pass: 32, //with value 32 your gray "pass" lines become green
  fail: 31,
  'bright pass': 92,
  'bright fail': 91,
  'bright yellow': 93,
  pending: 36,
  suite: 0,
  'error title': 0,
  'error message': 31,
  'error stack': 90,
  checkmark: 32,
  fast: 90,
  medium: 33,
  slow: 31,
  green: 32,
  light: 90,
  'diff gutter': 90,
  'diff added': 32,
  'diff removed': 31
; 

或者在您的项目根目录中创建 spec-helper.js 文件。 然后将--require spec-helper.js 放入Mocha 的shell 命令中。 (见下面的cmets)

// spec-helper.js
var colors = require('mocha/lib/reporters/base').colors;
    colors['pass'] = 32;

2020 年更新:

由于不推荐使用 mochaopts 文件并引入了配置文件,因此您不再需要帮助文件。而更改 mocha 源代码是你能做的最糟糕的事情。

现在您可以使用 javascript 格式的配置文件并根据需要重新定义报告器的颜色。

当您在运行时动态地重新定义对象的属性时,这就是所谓的“猴子修补”。 - 最初加载 mocha 时,它使用配置文件。在该文件中,您导入 'mocha/lib/reporters/base' 模块并覆盖颜色或符号。使用该基本文件作为参考。这些更改只会在运行时存在,实际的源代码将保持不变。

.mocharc.js文件放在根目录下。

//.mocharc.js
const colors, symbols = require('mocha/lib/reporters/base');
colors.pass = 32;
symbols.ok = '?';

// example config from Mocha repo       
module.exports = 
    diff: true,
    extension: ['js'],
    package: './package.json',
    reporter: 'spec',
    slow: 75,
    timeout: 2000,
    ui: 'bdd',
    'watch-files': ['lib/**/*.js','test/**/*.js'],
    'watch-ignore': ['lib/vendor']
  ;

看看它的外观。

我在这里使用 Windows 终端和 WSL。表情符号可能无法在本机 Windows 控制台中使用,但在 Linux 或 Mac 上应该可以使用。

【讨论】:

在调用mocha 命令时有什么办法吗?只是在重新安装node_modules 的那一刻思考:$ npm i 我该如何使用它?,有什么参考吗? С在项目的根目录中创建一个新文件 - 这是 package.json 文件所在的主文件夹,将此文件命名为 spec-helper.js ,从答案中复制代码并将其粘贴到新创建的 spec-helper.js 文件中。 var colors = require('mocha/lib/reporters/base').colors;颜色['pass'] = 32; - 这是您的 spec-helper.js 文件的代码。查看答案。 不幸的是它没有用。我认为spec-helper.js 被忽略了【参考方案2】:

实际上,在 iTerm 中调整“最小对比度”对我来说是侵入性最小的修复方法。调整数值,就会出现不可见的文字。

另见此处: https://gitlab.com/gnachman/iterm2/issues/5992#note_38835787

【讨论】:

以上是关于节点 - 使用 mocha 测试时更改输出颜色的主要内容,如果未能解决你的问题,请参考以下文章

更改 spritekit 中的节点颜色

如何在TreeView中选中他的节点时,更改节点的背景颜色?

Node.js 集群;仅在使用颜色时混乱的控制台输出

在 Resharper 中更改 NUnit 测试运行程序中链接的颜色

在 IPython (Jupyter) 中更改 Latex 输出的颜色

使用 tkinter 悬停时更改按钮颜色