chrome-devtools-frontend
Version:
Chrome DevTools UI
273 lines (213 loc) • 10.9 kB
text/typescript
// Copyright 2022 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 * as Common from '../../core/common/common.js';
import * as Platform from '../../core/platform/platform.js';
import * as SDK from '../../core/sdk/sdk.js';
import type * as Protocol from '../../generated/protocol.js';
import {describeWithEnvironment} from '../../testing/EnvironmentHelpers.js';
import * as Diff from '../../third_party/diff/diff.js';
import * as PanelUtils from './utils.js';
const {urlString} = Platform.DevToolsPath;
describeWithEnvironment('panels/utils', () => {
it('formats CSS changes from diff arrays', async () => {
const original = `
.container {
width: 10px;
height: 10px;
}
.child {
display: grid;
--child-theme-color: 100, 200, 0;
}
(display: grid) {
.container {
display: grid;
}
}`;
const current = `
.container {
width: 15px;
margin: 0;
}
.child2 {
display: grid;
--child-theme-color: 5, 10, 15;
padding: 10px;
}
(display: flex) {
.container {
display: flex;
}
}`;
const diff = Diff.Diff.DiffWrapper.lineDiff(original.split('\n'), current.split('\n'));
const changes = await PanelUtils.PanelUtils.formatCSSChangesFromDiff(diff);
assert.strictEqual(
changes, `.container {
/* width: 10px; */
/* height: 10px; */
width: 15px;
margin: 0;
}
/* .child { */
.child2 {
/* --child-theme-color: 100, 200, 0; */
--child-theme-color: 5, 10, 15;
padding: 10px;
}
/* @supports (display: grid) { */
(display: flex) {
.container {
/* display: grid; */
display: flex;
}`,
'formatted CSS changes are not correct');
});
describe('getIconForNetworkRequest', () => {
it('creates an error red icon for request with status code 404', async () => {
const request = SDK.NetworkRequest.NetworkRequest.create(
'requestId' as Protocol.Network.RequestId, urlString`https://www.example.com`, urlString``, null, null, null);
request.statusCode = 404;
const iconElement = PanelUtils.PanelUtils.getIconForNetworkRequest(request);
const iconStyle = iconElement.style;
const indexOfIconImage = iconStyle.webkitMaskImage.indexOf('Images/') + 7;
const iconImage = iconStyle.webkitMaskImage.substring(indexOfIconImage);
assert.strictEqual('cross-circle-filled.svg")', iconImage);
const backgroundColorOfIcon = iconStyle.backgroundColor.toString();
assert.strictEqual(backgroundColorOfIcon, 'var(--icon-error)');
});
it('show document icon', async () => {
const request = SDK.NetworkRequest.NetworkRequest.create(
'requestId' as Protocol.Network.RequestId, urlString`https://www.example.com/`, urlString``, null, null,
null);
request.setResourceType(Common.ResourceType.resourceTypes.Document);
request.mimeType = 'text/html';
const iconElement = PanelUtils.PanelUtils.getIconForNetworkRequest(request);
const iconStyle = iconElement.style;
const indexOfIconImage = iconStyle.webkitMaskImage.indexOf('Images/') + 7;
const iconImage = iconStyle.webkitMaskImage.substring(indexOfIconImage);
assert.strictEqual('file-document.svg")', iconImage);
const backgroundColorOfIcon = iconStyle.backgroundColor.toString();
assert.strictEqual(backgroundColorOfIcon, 'var(--icon-file-document)');
});
it('show media icon', async () => {
const request = SDK.NetworkRequest.NetworkRequest.create(
'requestId' as Protocol.Network.RequestId, urlString`https://www.example.com/test.mp3`, urlString``, null,
null, null);
request.setResourceType(Common.ResourceType.resourceTypes.Media);
request.mimeType = 'audio/mpeg';
const iconElement = PanelUtils.PanelUtils.getIconForNetworkRequest(request);
const iconStyle = iconElement.style;
const indexOfIconImage = iconStyle.webkitMaskImage.indexOf('Images/') + 7;
const iconImage = iconStyle.webkitMaskImage.substring(indexOfIconImage);
assert.strictEqual('file-media.svg")', iconImage);
});
it('show wasm icon', async () => {
const request = SDK.NetworkRequest.NetworkRequest.create(
'requestId' as Protocol.Network.RequestId, urlString`https://www.example.com/test.wasm`, urlString``, null,
null, null);
request.setResourceType(Common.ResourceType.resourceTypes.Wasm);
request.mimeType = 'application/wasm';
const iconElement = PanelUtils.PanelUtils.getIconForNetworkRequest(request);
const iconStyle = iconElement.style;
const indexOfIconImage = iconStyle.webkitMaskImage.indexOf('Images/') + 7;
const iconImage = iconStyle.webkitMaskImage.substring(indexOfIconImage);
assert.strictEqual('file-wasm.svg")', iconImage);
});
it('show websocket icon', async () => {
const request = SDK.NetworkRequest.NetworkRequest.create(
'requestId' as Protocol.Network.RequestId, urlString`https://www.example.com/ws`, urlString``, null, null,
null);
request.setResourceType(Common.ResourceType.resourceTypes.WebSocket);
request.mimeType = '';
const iconElement = PanelUtils.PanelUtils.getIconForNetworkRequest(request);
const iconStyle = iconElement.style;
const indexOfIconImage = iconStyle.webkitMaskImage.indexOf('Images/') + 7;
const iconImage = iconStyle.webkitMaskImage.substring(indexOfIconImage);
assert.strictEqual('file-websocket.svg")', iconImage);
});
it('shows fetch icon', async () => {
const request = SDK.NetworkRequest.NetworkRequest.create(
'requestId' as Protocol.Network.RequestId, urlString`https://www.example.com/test.json?keepalive=false`,
urlString``, null, null, null);
request.setResourceType(Common.ResourceType.resourceTypes.Fetch);
request.mimeType = '';
const iconElement = PanelUtils.PanelUtils.getIconForNetworkRequest(request);
const iconStyle = iconElement.style;
const indexOfIconImage = iconStyle.webkitMaskImage.indexOf('Images/') + 7;
const iconImage = iconStyle.webkitMaskImage.substring(indexOfIconImage);
assert.strictEqual('file-fetch-xhr.svg")', iconImage);
});
it('shows xhr icon', async () => {
const request = SDK.NetworkRequest.NetworkRequest.create(
'requestId' as Protocol.Network.RequestId, urlString`https://www.example.com/test.json?keepalive=false`,
urlString``, null, null, null);
request.setResourceType(Common.ResourceType.resourceTypes.XHR);
request.mimeType = 'application/octet-stream';
const iconElement = PanelUtils.PanelUtils.getIconForNetworkRequest(request);
const iconStyle = iconElement.style;
const indexOfIconImage = iconStyle.webkitMaskImage.indexOf('Images/') + 7;
const iconImage = iconStyle.webkitMaskImage.substring(indexOfIconImage);
assert.strictEqual('file-fetch-xhr.svg")', iconImage);
});
it('mime win: show image preview icon for xhr-image', async () => {
const request = SDK.NetworkRequest.NetworkRequest.create(
'requestId' as Protocol.Network.RequestId, urlString`https://www.example.com/test.svg`, urlString``, null,
null, null);
request.setResourceType(Common.ResourceType.resourceTypes.XHR);
request.mimeType = 'image/svg+xml';
const iconElement = PanelUtils.PanelUtils.getIconForNetworkRequest(request);
const imagePreview = iconElement.querySelector('.image-network-icon-preview') as HTMLImageElement;
assert.instanceOf(iconElement, HTMLDivElement);
assert.instanceOf(imagePreview, HTMLImageElement);
});
it('mime win: show document icon for fetch-html', async () => {
const request = SDK.NetworkRequest.NetworkRequest.create(
'requestId' as Protocol.Network.RequestId, urlString`https://www.example.com/page`, urlString``, null, null,
null);
request.setResourceType(Common.ResourceType.resourceTypes.Fetch);
request.mimeType = 'text/html';
const iconElement = PanelUtils.PanelUtils.getIconForNetworkRequest(request);
const iconStyle = iconElement.style;
const indexOfIconImage = iconStyle.webkitMaskImage.indexOf('Images/') + 7;
const iconImage = iconStyle.webkitMaskImage.substring(indexOfIconImage);
assert.strictEqual('file-document.svg")', iconImage);
});
it('mime win: show generic icon for preflight-text', async () => {
const request = SDK.NetworkRequest.NetworkRequest.create(
'requestId' as Protocol.Network.RequestId, urlString`https://www.example.com/api/test`, urlString``, null,
null, null);
request.setResourceType(Common.ResourceType.resourceTypes.Preflight);
request.mimeType = 'text/plain';
const iconElement = PanelUtils.PanelUtils.getIconForNetworkRequest(request);
const iconStyle = iconElement.style;
const indexOfIconImage = iconStyle.webkitMaskImage.indexOf('Images/') + 7;
const iconImage = iconStyle.webkitMaskImage.substring(indexOfIconImage);
assert.strictEqual('file-generic.svg")', iconImage);
});
it('mime win: show script icon for other-javascript)', async () => {
const request = SDK.NetworkRequest.NetworkRequest.create(
'requestId' as Protocol.Network.RequestId, urlString`https://www.example.com/ping`, urlString``, null, null,
null);
request.setResourceType(Common.ResourceType.resourceTypes.Other);
request.mimeType = 'application/javascript';
const iconElement = PanelUtils.PanelUtils.getIconForNetworkRequest(request);
const iconStyle = iconElement.style;
const indexOfIconImage = iconStyle.webkitMaskImage.indexOf('Images/') + 7;
const iconImage = iconStyle.webkitMaskImage.substring(indexOfIconImage);
assert.strictEqual('file-script.svg")', iconImage);
});
it('mime win: shows json icon for fetch-json', async () => {
const request = SDK.NetworkRequest.NetworkRequest.create(
'requestId' as Protocol.Network.RequestId, urlString`https://www.example.com/api/list`, urlString``, null,
null, null);
request.setResourceType(Common.ResourceType.resourceTypes.Fetch);
request.mimeType = 'application/json';
const iconElement = PanelUtils.PanelUtils.getIconForNetworkRequest(request);
const iconStyle = iconElement.style;
const indexOfIconImage = iconStyle.webkitMaskImage.indexOf('Images/') + 7;
const iconImage = iconStyle.webkitMaskImage.substring(indexOfIconImage);
assert.strictEqual('file-json.svg")', iconImage);
});
});
});