/** * Copyright (c) Microsoft Corporation. * * 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. */ import * as React from 'react'; import './callTab.css'; import type { ActionTraceEvent } from '../../../server/trace/common/traceEvents'; import { CallMetadata } from '../../../protocol/callMetadata'; import { parseSerializedValue } from '../../../protocol/serializers'; export const CallTab: React.FunctionComponent<{ action: ActionTraceEvent | undefined, }> = ({ action }) => { if (!action) return null; const logs = action.metadata.log; const error = action.metadata.error?.error?.message; const params = { ...action.metadata.params }; // Strip down the waitForEventInfo data, we never need it. delete params.info; const paramKeys = Object.keys(params); return
; }; function renderLine(metadata: CallMetadata, name: string, value: any) { const { title, type } = toString(metadata, name, value); let text = trimRight(title.replace(/\n/g, '↵'), 80); if (type === 'string') text = `"${text}"`; return
{name}: {text}
} function toString(metadata: CallMetadata, name: string, value: any): { title: string, type: string } { if (metadata.method.includes('eval')) { if (name === 'arg') value = parseSerializedValue(value.value, new Array(10).fill({ handle: '' })); if (name === 'value') value = parseSerializedValue(value, new Array(10).fill({ handle: '' })); } const type = typeof value; if (type !== 'object') return { title: String(value), type }; if (value.guid) return { title: '', type: 'handle' }; return { title: JSON.stringify(value), type: 'object' }; } function trimRight(text: string, max: number): string { if (text.length > max) return text.substr(0, max) + '\u2026'; return text; }