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
|
// 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));
}
|