blob: fba6a1d5899b0c4afa765d39e750bd90fb3945eb [file]
// Copyright 2021 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
import {assert} from 'chai';
import {$, click, getBrowserAndPages, goToResource, typeText, waitForFunction} from '../../shared/helper.js';
import {describe, it} from '../../shared/mocha-extensions.js';
import {CONSOLE_TAB_SELECTOR, focusConsolePrompt, STACK_PREVIEW_CONTAINER} from '../helpers/console-helpers.js';
import {openSettingsTab} from '../helpers/settings-helpers.js';
const CONSOLE_MESSAGE_WRAPPER = '.console-message-stack-trace-wrapper';
const ADD_FILENAME_PATTERN_BUTTON = 'devtools-button[aria-label="Add filename pattern"]';
const ADD_BUTTON = '.editor-buttons devtools-button:nth-of-type(2)';
const CLOSE_SETTINGS_BUTTON = '.close-button[aria-label="Close"]';
const SHOW_MORE_LINK = '.show-all-link .link';
const SHOW_LESS_LINK = '.show-less-link .link';
describe('The Console Tab', () => {
it('shows messages with stack traces', async () => {
const {frontend} = getBrowserAndPages();
await click(CONSOLE_TAB_SELECTOR);
await focusConsolePrompt();
await goToResource('console/stack-trace.html');
await frontend.waitForSelector(CONSOLE_MESSAGE_WRAPPER);
await click(CONSOLE_MESSAGE_WRAPPER);
const stack = await $(STACK_PREVIEW_CONTAINER);
const expected = [
{text: '\nshown3 @ showMe.js:10', classes: {}},
{text: '\nshown2 @ showMe.js:6', classes: {}},
{text: '\nshown1 @ showMe.js:2', classes: {}},
{text: '\n(anonymous) @ ignoreMe.js:21', classes: {}},
{text: '\nPromise.then (async)', classes: {}},
{text: '\nignoreListed4 @ ignoreMe.js:20', classes: {}},
{text: '\nignoreListed3 @ ignoreMe.js:16', classes: {}},
{text: '\nignoreListed2 @ ignoreMe.js:12', classes: {}},
{text: '\nignoreListed1 @ ignoreMe.js:8', classes: {}},
{text: '\n(anonymous) @ ignoreMe.js:5', classes: {}},
];
await waitForFunction(async () => {
const stackTraceRows = await frontend.evaluate((stack: Element) => {
return Array.from(stack.querySelectorAll('tr'))
.map(node => ({text: node.textContent, classes: node.classList}));
}, stack);
return JSON.stringify(stackTraceRows) === JSON.stringify(expected);
});
});
it('shows messages with stack traces containing ignore-listed frames', async () => {
const {frontend} = getBrowserAndPages();
await openSettingsTab('Ignore List');
await click(ADD_FILENAME_PATTERN_BUTTON);
await typeText('ignoreMe.js');
await click(ADD_BUTTON);
await click(CLOSE_SETTINGS_BUTTON);
await goToResource('console/stack-trace.html');
await click(CONSOLE_TAB_SELECTOR);
await frontend.waitForSelector(CONSOLE_MESSAGE_WRAPPER);
await click(CONSOLE_MESSAGE_WRAPPER);
const stack = await $(STACK_PREVIEW_CONTAINER);
const expected = [
{text: '\nshown3 @ showMe.js:10', classes: {}},
{text: '\nshown2 @ showMe.js:6', classes: {}},
{text: '\nshown1 @ showMe.js:2', classes: {}},
{text: '\n(anonymous) @ ignoreMe.js:21', classes: {'0': 'hidden-row'}},
{text: '\nPromise.then (async)', classes: {'0': 'hidden-row'}},
{text: '\nignoreListed4 @ ignoreMe.js:20', classes: {'0': 'hidden-row'}},
{text: '\nignoreListed3 @ ignoreMe.js:16', classes: {'0': 'hidden-row'}},
{text: '\nignoreListed2 @ ignoreMe.js:12', classes: {'0': 'hidden-row'}},
{text: '\nignoreListed1 @ ignoreMe.js:8', classes: {'0': 'hidden-row'}},
{text: '\n(anonymous) @ ignoreMe.js:5', classes: {'0': 'hidden-row'}},
{text: '\nShow 6 more frames', classes: {'0': 'show-all-link'}},
{text: '\nShow less', classes: {'0': 'show-less-link'}},
];
await waitForFunction(async () => {
const stackTraceRows = await frontend.evaluate((stack: Element) => {
return Array.from(stack.querySelectorAll('tr'))
.map(node => ({text: node.textContent, classes: node.classList}));
}, stack);
return JSON.stringify(stackTraceRows) === JSON.stringify(expected);
});
// assert that hidden rows are not shown initially
let showHidden = stack ? await stack.evaluate(x => x.classList.contains('show-hidden-rows')) : null;
assert.strictEqual(showHidden, false);
// assert that after clicking 'show all'-button, hidden rows are shown
await click(SHOW_MORE_LINK);
showHidden = stack ? await stack.evaluate(x => x.classList.contains('show-hidden-rows')) : null;
assert.strictEqual(showHidden, true);
// assert that after clicking 'show less'-button, hidden rows are hidden again
await click(SHOW_LESS_LINK);
showHidden = stack ? await stack.evaluate(x => x.classList.contains('show-hidden-rows')) : null;
assert.strictEqual(showHidden, false);
});
});