aboutsummaryrefslogtreecommitdiff
path: root/node_modules/@jest/console/build/getConsoleOutput.js
blob: 18eb3549ba22a8f6491fd6c939b9d2d89f68484a (plain)
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
'use strict';

Object.defineProperty(exports, '__esModule', {
  value: true
});
exports.default = getConsoleOutput;

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.
 */
function getConsoleOutput(buffer, config, globalConfig) {
  const TITLE_INDENT = globalConfig.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';
}