getConsoleOutput.js
2.66 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
'use strict';
Object.defineProperty(exports, '__esModule', {
value: true
});
exports.default = void 0;
function _chalk() {
const data = _interopRequireDefault(require('chalk'));
_chalk = function () {
return data;
};
return data;
}
function _jestMessageUtil() {
const data = require('jest-message-util');
_jestMessageUtil = function () {
return data;
};
return data;
}
function _interopRequireDefault(obj) {
return obj && obj.__esModule ? obj : {default: obj};
}
/**
* Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved.
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*/
var _default = (
root,
verbose,
buffer, // TODO: make mandatory and take Config.ProjectConfig in 27
config = {
rootDir: root,
testMatch: []
},
globalConfig
) => {
const TITLE_INDENT = verbose ? ' ' : ' ';
const CONSOLE_INDENT = TITLE_INDENT + ' ';
const logEntries = buffer.reduce((output, {type, message, origin}) => {
message = message
.split(/\n/)
.map(line => CONSOLE_INDENT + line)
.join('\n');
let typeMessage = 'console.' + type;
let noStackTrace = true;
let noCodeFrame = true;
if (type === 'warn') {
var _globalConfig$noStack;
message = _chalk().default.yellow(message);
typeMessage = _chalk().default.yellow(typeMessage);
noStackTrace =
(_globalConfig$noStack =
globalConfig === null || globalConfig === void 0
? void 0
: globalConfig.noStackTrace) !== null &&
_globalConfig$noStack !== void 0
? _globalConfig$noStack
: false;
noCodeFrame = false;
} else if (type === 'error') {
var _globalConfig$noStack2;
message = _chalk().default.red(message);
typeMessage = _chalk().default.red(typeMessage);
noStackTrace =
(_globalConfig$noStack2 =
globalConfig === null || globalConfig === void 0
? void 0
: globalConfig.noStackTrace) !== null &&
_globalConfig$noStack2 !== void 0
? _globalConfig$noStack2
: false;
noCodeFrame = false;
}
const options = {
noCodeFrame,
noStackTrace
};
const formattedStackTrace = (0, _jestMessageUtil().formatStackTrace)(
origin,
config,
options
);
return (
output +
TITLE_INDENT +
_chalk().default.dim(typeMessage) +
'\n' +
message.trimRight() +
'\n' +
_chalk().default.dim(formattedStackTrace.trimRight()) +
'\n\n'
);
}, '');
return logEntries.trimRight() + '\n';
};
exports.default = _default;