mirror of
https://github.com/microsoft/playwright.git
synced 2025-01-07 11:46:42 +03:00
parent
d125ff4d39
commit
0c3f60e95e
@ -26,11 +26,11 @@ import type { StackFrame } from '@protocol/channels';
|
|||||||
|
|
||||||
export const SourceTab: React.FunctionComponent<{
|
export const SourceTab: React.FunctionComponent<{
|
||||||
stack: StackFrame[] | undefined,
|
stack: StackFrame[] | undefined,
|
||||||
|
stackFrameLocation: 'bottom' | 'right',
|
||||||
sources: Map<string, SourceModel>,
|
sources: Map<string, SourceModel>,
|
||||||
hideStackFrames?: boolean,
|
|
||||||
rootDir?: string,
|
rootDir?: string,
|
||||||
fallbackLocation?: SourceLocation,
|
fallbackLocation?: SourceLocation,
|
||||||
}> = ({ stack, sources, hideStackFrames, rootDir, fallbackLocation }) => {
|
}> = ({ stack, sources, rootDir, fallbackLocation, stackFrameLocation }) => {
|
||||||
const [lastStack, setLastStack] = React.useState<StackFrame[] | undefined>();
|
const [lastStack, setLastStack] = React.useState<StackFrame[] | undefined>();
|
||||||
const [selectedFrame, setSelectedFrame] = React.useState<number>(0);
|
const [selectedFrame, setSelectedFrame] = React.useState<number>(0);
|
||||||
|
|
||||||
@ -78,7 +78,9 @@ export const SourceTab: React.FunctionComponent<{
|
|||||||
return { source, highlight, targetLine, fileName };
|
return { source, highlight, targetLine, fileName };
|
||||||
}, [stack, selectedFrame, rootDir, fallbackLocation], { source: { errors: [], content: 'Loading\u2026' }, highlight: [] });
|
}, [stack, selectedFrame, rootDir, fallbackLocation], { source: { errors: [], content: 'Loading\u2026' }, highlight: [] });
|
||||||
|
|
||||||
return <SplitView sidebarSize={200} orientation='horizontal' sidebarHidden={hideStackFrames}>
|
const showStackFrames = (stack?.length ?? 0) > 1;
|
||||||
|
|
||||||
|
return <SplitView sidebarSize={200} orientation={stackFrameLocation === 'bottom' ? 'vertical' : 'horizontal'} sidebarHidden={!showStackFrames}>
|
||||||
<div className='vbox' data-testid='source-code'>
|
<div className='vbox' data-testid='source-code'>
|
||||||
{fileName && <div className='source-tab-file-name'>{fileName}</div>}
|
{fileName && <div className='source-tab-file-name'>{fileName}</div>}
|
||||||
<CodeMirrorWrapper text={source.content || ''} language='javascript' highlight={highlight} revealLine={targetLine} readOnly={true} lineNumbers={true} />
|
<CodeMirrorWrapper text={source.content || ''} language='javascript' highlight={highlight} revealLine={targetLine} readOnly={true} lineNumbers={true} />
|
||||||
|
@ -589,7 +589,6 @@ const TraceView: React.FC<{
|
|||||||
return <Workbench
|
return <Workbench
|
||||||
key='workbench'
|
key='workbench'
|
||||||
model={model?.model}
|
model={model?.model}
|
||||||
hideStackFrames={true}
|
|
||||||
showSourcesFirst={true}
|
showSourcesFirst={true}
|
||||||
rootDir={rootDir}
|
rootDir={rootDir}
|
||||||
initialSelection={initialSelection}
|
initialSelection={initialSelection}
|
||||||
|
@ -43,7 +43,6 @@ import type { UITestStatus } from './testUtils';
|
|||||||
|
|
||||||
export const Workbench: React.FunctionComponent<{
|
export const Workbench: React.FunctionComponent<{
|
||||||
model?: MultiTraceModel,
|
model?: MultiTraceModel,
|
||||||
hideStackFrames?: boolean,
|
|
||||||
showSourcesFirst?: boolean,
|
showSourcesFirst?: boolean,
|
||||||
rootDir?: string,
|
rootDir?: string,
|
||||||
fallbackLocation?: modelUtil.SourceLocation,
|
fallbackLocation?: modelUtil.SourceLocation,
|
||||||
@ -51,7 +50,7 @@ export const Workbench: React.FunctionComponent<{
|
|||||||
onSelectionChanged?: (action: ActionTraceEventInContext) => void,
|
onSelectionChanged?: (action: ActionTraceEventInContext) => void,
|
||||||
isLive?: boolean,
|
isLive?: boolean,
|
||||||
status?: UITestStatus,
|
status?: UITestStatus,
|
||||||
}> = ({ model, hideStackFrames, showSourcesFirst, rootDir, fallbackLocation, initialSelection, onSelectionChanged, isLive, status }) => {
|
}> = ({ model, showSourcesFirst, rootDir, fallbackLocation, initialSelection, onSelectionChanged, isLive, status }) => {
|
||||||
const [selectedAction, setSelectedActionImpl] = React.useState<ActionTraceEventInContext | undefined>(undefined);
|
const [selectedAction, setSelectedActionImpl] = React.useState<ActionTraceEventInContext | undefined>(undefined);
|
||||||
const [revealedStack, setRevealedStack] = React.useState<StackFrame[] | undefined>(undefined);
|
const [revealedStack, setRevealedStack] = React.useState<StackFrame[] | undefined>(undefined);
|
||||||
const [highlightedAction, setHighlightedAction] = React.useState<ActionTraceEventInContext | undefined>();
|
const [highlightedAction, setHighlightedAction] = React.useState<ActionTraceEventInContext | undefined>();
|
||||||
@ -158,8 +157,8 @@ export const Workbench: React.FunctionComponent<{
|
|||||||
render: () => <SourceTab
|
render: () => <SourceTab
|
||||||
stack={revealedStack}
|
stack={revealedStack}
|
||||||
sources={sources}
|
sources={sources}
|
||||||
hideStackFrames={hideStackFrames}
|
|
||||||
rootDir={rootDir}
|
rootDir={rootDir}
|
||||||
|
stackFrameLocation={sidebarLocation === 'bottom' ? 'right' : 'bottom'}
|
||||||
fallbackLocation={fallbackLocation} />
|
fallbackLocation={fallbackLocation} />
|
||||||
};
|
};
|
||||||
const consoleTab: TabbedPaneTabModel = {
|
const consoleTab: TabbedPaneTabModel = {
|
||||||
|
@ -442,8 +442,11 @@ for (const useIntermediateMergeReport of [false, true] as const) {
|
|||||||
`,
|
`,
|
||||||
'a.test.js': `
|
'a.test.js': `
|
||||||
import { test, expect } from '@playwright/test';
|
import { test, expect } from '@playwright/test';
|
||||||
|
async function evaluateWrapper(page, expression) {
|
||||||
|
await page.evaluate(expression);
|
||||||
|
}
|
||||||
test('passes', async ({ page }) => {
|
test('passes', async ({ page }) => {
|
||||||
await page.evaluate('2 + 2');
|
await evaluateWrapper(page, '2 + 2');
|
||||||
});
|
});
|
||||||
`,
|
`,
|
||||||
}, { reporter: 'dot,html' }, { PW_TEST_HTML_REPORT_OPEN: 'never' });
|
}, { reporter: 'dot,html' }, { PW_TEST_HTML_REPORT_OPEN: 'never' });
|
||||||
@ -468,6 +471,36 @@ for (const useIntermediateMergeReport of [false, true] as const) {
|
|||||||
await expect(page.getByTestId('stack-trace-list').locator('.list-view-entry.selected')).toContainText('a.test.js');
|
await expect(page.getByTestId('stack-trace-list').locator('.list-view-entry.selected')).toContainText('a.test.js');
|
||||||
});
|
});
|
||||||
|
|
||||||
|
test('should not show stack trace', async ({ runInlineTest, page, showReport }) => {
|
||||||
|
const result = await runInlineTest({
|
||||||
|
'playwright.config.js': `
|
||||||
|
module.exports = { use: { trace: 'on' } };
|
||||||
|
`,
|
||||||
|
'a.test.js': `
|
||||||
|
import { test, expect } from '@playwright/test';
|
||||||
|
test('passes', async ({ page }) => {
|
||||||
|
await page.evaluate('2 + 2');
|
||||||
|
});
|
||||||
|
`,
|
||||||
|
}, { reporter: 'dot,html' }, { PW_TEST_HTML_REPORT_OPEN: 'never' });
|
||||||
|
expect(result.exitCode).toBe(0);
|
||||||
|
expect(result.passed).toBe(1);
|
||||||
|
|
||||||
|
await showReport();
|
||||||
|
await page.click('text=passes');
|
||||||
|
await page.click('img');
|
||||||
|
await page.click('.action-title >> text=page.evaluate');
|
||||||
|
await page.click('text=Source');
|
||||||
|
|
||||||
|
await expect(page.locator('.CodeMirror-line')).toContainText([
|
||||||
|
/import.*test/,
|
||||||
|
/page\.evaluate/
|
||||||
|
]);
|
||||||
|
await expect(page.locator('.source-line-running')).toContainText('page.evaluate');
|
||||||
|
|
||||||
|
await expect(page.getByTestId('stack-trace-list')).toHaveCount(0);
|
||||||
|
});
|
||||||
|
|
||||||
test('should show trace title', async ({ runInlineTest, page, showReport }) => {
|
test('should show trace title', async ({ runInlineTest, page, showReport }) => {
|
||||||
const result = await runInlineTest({
|
const result = await runInlineTest({
|
||||||
'playwright.config.js': `
|
'playwright.config.js': `
|
||||||
|
Loading…
Reference in New Issue
Block a user