@apache-royale/royale-js
Version:
Apache Royale (formerly FlexJS)
72 lines (59 loc) • 2.45 kB
JavaScript
// Copyright 2014 The Closure Library Authors. All Rights Reserved.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS-IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
goog.provide('goog.debug.FormatterTest');
goog.setTestOnly('goog.debug.FormatterTest');
goog.require('goog.debug.HtmlFormatter');
goog.require('goog.debug.LogRecord');
goog.require('goog.debug.Logger');
goog.require('goog.html.SafeHtml');
goog.require('goog.testing.jsunit');
var EXPECTED_RECORD_HTML_RE =
'^prefix \\[.*?\\] \\[  .*?s\\] \\[loggerName\\] ' +
'<span class="dbg-f">mess<br>  age<br>Message:';
var logRecord;
function setUp() {
logRecord = new goog.debug.LogRecord(
goog.debug.Logger.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'));
}
function testExposeException() {
var expected = 'Message: message"<br>' +
'Url: <a href="view-source:http://fileName"" ' +
'target="_new">http://fileName"</a><br>' +
'Line: lineNumber"<br><br>' +
'Browser stack:<br>' +
'stack"-> [end]';
var error = {
message: 'message"',
fileName: 'http://fileName"',
lineNumber: 'lineNumber"',
stack: 'stack"'
};
var actualHtml = goog.debug.HtmlFormatter.exposeExceptionAsHtml(error);
var actual = goog.html.SafeHtml.unwrap(actualHtml);
actual = actual.substring(0, expected.length);
assertEquals(expected, actual);
}
function testHtmlFormatter_formatRecord() {
var formatter = new goog.debug.HtmlFormatter('prefix');
var actual = formatter.formatRecord(logRecord);
assertRegExp(EXPECTED_RECORD_HTML_RE, actual);
}
function testHtmlFormatter_formatRecordAsHtml() {
var formatter = new goog.debug.HtmlFormatter('prefix');
var actual = formatter.formatRecordAsHtml(logRecord);
assertRegExp(EXPECTED_RECORD_HTML_RE, goog.html.SafeHtml.unwrap(actual));
}