chrome-devtools-frontend
Version:
Chrome DevTools UI
88 lines (69 loc) • 4.23 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 Platform from '../../core/platform/platform.js';
import * as SDK from '../../core/sdk/sdk.js';
import type * as Protocol from '../../generated/protocol.js';
import {createTarget} from '../../testing/EnvironmentHelpers.js';
import {describeWithMockConnection} from '../../testing/MockConnection.js';
import {MockProtocolBackend} from '../../testing/MockScopeChain.js';
import {loadBasicSourceMapExample} from '../../testing/SourceMapHelpers.js';
import * as Workspace from '../workspace/workspace.js';
import * as Bindings from './bindings.js';
const {urlString} = Platform.DevToolsPath;
describeWithMockConnection('DebuggerWorkspaceBinding', () => {
let target: SDK.Target.Target;
let backend: MockProtocolBackend;
let debuggerWorkspaceBinding: Bindings.DebuggerWorkspaceBinding.DebuggerWorkspaceBinding;
beforeEach(() => {
target = createTarget({id: 'main' as Protocol.Target.TargetID, name: 'main', type: SDK.Target.Type.FRAME});
const targetManager = target.targetManager();
const workspace = Workspace.Workspace.WorkspaceImpl.instance();
const resourceMapping = new Bindings.ResourceMapping.ResourceMapping(targetManager, workspace);
debuggerWorkspaceBinding = Bindings.DebuggerWorkspaceBinding.DebuggerWorkspaceBinding.instance(
{forceNew: false, resourceMapping, targetManager});
Bindings.IgnoreListManager.IgnoreListManager.instance({forceNew: false, debuggerWorkspaceBinding});
});
it('can wait for a uiSourceCode if it is not yet available', async () => {
backend = new MockProtocolBackend();
SDK.TargetManager.TargetManager.instance().setScopeTarget(target);
const scriptUrl = urlString`http://script-host/script.js`;
const scriptInfo = {url: scriptUrl, content: 'console.log(1);', startLine: 0, startColumn: 0, hasSourceURL: false};
// Create a second target.
const workerTarget = createTarget({
id: 'worker' as Protocol.Target.TargetID,
name: 'worker',
type: SDK.Target.Type.ServiceWorker,
parentTarget: target,
});
// Before any script is registered, there shouldn't be any uiSourceCodes.
assert.isNull(Workspace.Workspace.WorkspaceImpl.instance().uiSourceCodeForURL(scriptUrl));
// Create promise to await the uiSourceCode given the url and its target.
const uiSourceCodePromise = debuggerWorkspaceBinding.waitForUISourceCodeAdded(scriptUrl, target);
// Register the script, which will kick off creating the uiSourceCode.
await backend.addScript(target, scriptInfo, null);
await backend.addScript(workerTarget, scriptInfo, null);
// Await the promise to retrieve the uiSourceCode.
const uiSourceCode = await uiSourceCodePromise;
// Check if the uiSourceCode is the expected one (from the main target, and having the correct sourceURL).
assert.strictEqual(uiSourceCode.url(), scriptUrl);
assert.deepEqual(Bindings.NetworkProject.NetworkProject.targetForUISourceCode(uiSourceCode), target);
});
it('augments sourcemap with scopes via DebuggerWorkspaceBindings.setFunctionRanges', async () => {
const validFunctionRanges = [{start: {line: 0, column: 0}, end: {line: 10, column: 1}, name: 'foo'}];
const debuggerModel = target.model(SDK.DebuggerModel.DebuggerModel);
assert.exists(debuggerModel);
const script = (await loadBasicSourceMapExample(target)).script;
const sourceMap = await debuggerModel.sourceMapManager().sourceMapForClientPromise(script);
assert.exists(sourceMap);
const url: string = sourceMap.url();
assert.strictEqual(url, 'file://gen.js.map/');
const uiSourceCodeForSourceMap =
Workspace.Workspace.WorkspaceImpl.instance().uiSourceCodeForURL(sourceMap.sourceURLs()[0]);
assert.exists(uiSourceCodeForSourceMap);
Bindings.DebuggerWorkspaceBinding.DebuggerWorkspaceBinding.instance().setFunctionRanges(
uiSourceCodeForSourceMap, validFunctionRanges);
assert.isTrue(sourceMap.hasScopeInfo());
assert.strictEqual(sourceMap.findOriginalFunctionName({line: 0, column: 110}), 'foo');
});
});