chromium/third_party/google-closure-library/closure/goog/debug/formatter_test.js

/**
 * @license
 * Copyright The Closure Library Authors.
 * SPDX-License-Identifier: Apache-2.0
 */

goog.module('goog.debug.FormatterTest');
goog.setTestOnly();

const HtmlFormatter = goog.require('goog.debug.HtmlFormatter');
const SafeHtml = goog.require('goog.html.SafeHtml');
const testSuite = goog.require('goog.testing.testSuite');
const {Level, LogRecord} = goog.require('goog.log');

const EXPECTED_RECORD_HTML_RE =
    '^prefix \\[.*?\\] \\[  .*?s\\] \\[loggerName\\] ' +
    '<span class="dbg-f">mess<br> &#160;age<br>Message:';
let logRecord;

testSuite({
  setUp() {
    logRecord =
        new LogRecord(Level.CONFIG, 'mess\n  age', 'loggerName', 1, 100);
    // Exception needs to be present for exception text to get printed
    // by HtmlFormatter.
    logRecord.setException(new Error('exc\n  eption'));
  },

  testExposeException() {
    const expected = 'Message: message&quot;<br>' +
        'Url: <a href="view-source:http://fileName&quot;" ' +
        'target="_new">http://fileName&quot;</a><br>' +
        'Line: lineNumber&quot;<br><br>' +
        'Browser stack:<br>' +
        'stack&quot;-&gt; [end]';
    const error = {
      message: 'message"',
      fileName: 'http://fileName"',
      lineNumber: 'lineNumber"',
      stack: 'stack"',
    };
    const actualHtml = HtmlFormatter.exposeExceptionAsHtml(error);
    let actual = SafeHtml.unwrap(actualHtml);
    actual = actual.substring(0, expected.length);
    assertEquals(expected, actual);
  },

  testHtmlFormatter_formatRecord() {
    const formatter = new HtmlFormatter('prefix');
    const actual = formatter.formatRecord(logRecord);
    assertRegExp(EXPECTED_RECORD_HTML_RE, actual);
  },

  testHtmlFormatter_formatRecordAsHtml() {
    const formatter = new HtmlFormatter('prefix');
    const actual = formatter.formatRecordAsHtml(logRecord);
    assertRegExp(EXPECTED_RECORD_HTML_RE, SafeHtml.unwrap(actual));
  },
});