From 6df48a1a8abb8db01ed3ef41ded8eb2949d490e7 Mon Sep 17 00:00:00 2001 From: adrienbaron Date: Mon, 26 Dec 2022 09:02:43 +0000 Subject: [PATCH] chore(node): remove all references to sourcePos --- .../ui/client/components/views/ViewEditor.vue | 10 +++---- .../client/components/views/ViewReport.cy.tsx | 9 ++----- .../ui/client/components/views/ViewReport.vue | 12 ++------- packages/vitest/src/node/error.ts | 27 +++++++------------ packages/vitest/src/node/reporters/json.ts | 3 +-- packages/vitest/src/node/reporters/junit.ts | 3 +-- packages/vitest/src/typecheck/typechecker.ts | 4 --- packages/vitest/src/types/general.ts | 1 - 8 files changed, 20 insertions(+), 49 deletions(-) diff --git a/packages/ui/client/components/views/ViewEditor.vue b/packages/ui/client/components/views/ViewEditor.vue index dfd3dbd8021ea..963d00c865ade 100644 --- a/packages/ui/client/components/views/ViewEditor.vue +++ b/packages/ui/client/components/views/ViewEditor.vue @@ -79,12 +79,12 @@ watch([cm, failed], ([cmValue]) => { const e = i.result?.error const stacks = (e?.stacks || []).filter(i => i.file && i.file === props.file?.filepath) if (stacks.length) { - const pos = stacks[0].sourcePos || stacks[0] + const stack = stacks[0] const div = document.createElement('div') div.className = 'op80 flex gap-x-2 items-center' const pre = document.createElement('pre') pre.className = 'c-red-600 dark:c-red-400' - pre.textContent = `${' '.repeat(pos.column)}^ ${e?.nameStr}: ${e?.message}` + pre.textContent = `${' '.repeat(stack.column)}^ ${e?.nameStr}: ${e?.message}` div.appendChild(pre) const span = document.createElement('span') span.className = 'i-carbon-launch c-red-600 dark:c-red-400 hover:cursor-pointer min-w-1em min-h-1em' @@ -95,12 +95,12 @@ watch([cm, failed], ([cmValue]) => { placement: 'bottom', }, false) const el: EventListener = async () => { - await openInEditor(stacks[0].file, pos.line, pos.column) + await openInEditor(stacks[0].file, stack.line, stack.column) } div.appendChild(span) listeners.push([span, el, () => destroyTooltip(span)]) - handles.push(cm.value!.addLineClass(pos.line - 1, 'wrap', 'bg-red-500/10')) - widgets.push(cm.value!.addLineWidget(pos.line - 1, div)) + handles.push(cm.value!.addLineClass(stack.line - 1, 'wrap', 'bg-red-500/10')) + widgets.push(cm.value!.addLineWidget(stack.line - 1, div)) } }) if (!hasBeenEdited.value) diff --git a/packages/ui/client/components/views/ViewReport.cy.tsx b/packages/ui/client/components/views/ViewReport.cy.tsx index 4dbd790d9a90b..7e87687ea8e58 100644 --- a/packages/ui/client/components/views/ViewReport.cy.tsx +++ b/packages/ui/client/components/views/ViewReport.cy.tsx @@ -9,10 +9,6 @@ const stackRowSelector = '[data-testid=stack]' const makeTextStack = () => ({ line: faker.datatype.number({ min: 0, max: 120 }), column: faker.datatype.number({ min: 0, max: 5000 }), - sourcePos: { - line: faker.datatype.number({ min: 121, max: 240 }), - column: faker.datatype.number({ min: 5001, max: 10000 }), - }, // Absolute file paths file: faker.system.filePath(), method: faker.hacker.verb(), @@ -49,9 +45,8 @@ describe('ViewReport', () => { cy.get(stackRowSelector).should('have.length', stacks.length) .get(stackRowSelector) .each(($stack, idx) => { - const { column, line, file: fileName, sourcePos } = stacks[idx] - expect($stack).not.to.contain.text(`${line}:${column}`) - expect($stack).to.contain.text(`${sourcePos.line}:${sourcePos.column}`) + const { column, line, file: fileName } = stacks[idx] + expect($stack).to.contain.text(`${line}:${column}`) expect($stack).to.contain.text(`- ${fileName}`) }) }) diff --git a/packages/ui/client/components/views/ViewReport.vue b/packages/ui/client/components/views/ViewReport.vue index 25d282c565c62..f7169ed37fc1d 100644 --- a/packages/ui/client/components/views/ViewReport.vue +++ b/packages/ui/client/components/views/ViewReport.vue @@ -88,14 +88,6 @@ function relative(p: string) { return p } -function line(stack: ParsedStack) { - return stack.sourcePos?.line ?? stack.line -} - -function column(stack: ParsedStack) { - return stack.sourcePos?.column ?? stack.column -} - interface Diff { error: NonNullable> } type ResultWithDiff = Task['result'] & Diff function isDiffShowable(result?: Task['result']): result is ResultWithDiff { @@ -128,14 +120,14 @@ function diff(result: ResultWithDiff): string {
{{ task.result.error.name || task.result.error.nameStr }}: {{ task.result.error.message }}
-
 - {{ relative(stack.file) }}:{{ line(stack) }}:{{ column(stack) }}
+
 - {{ relative(stack.file) }}:{{ stack.line }}:{{ stack.column }}
diff --git a/packages/vitest/src/node/error.ts b/packages/vitest/src/node/error.ts
index 5c33eabb3218b..343582c2fea84 100644
--- a/packages/vitest/src/node/error.ts
+++ b/packages/vitest/src/node/error.ts
@@ -1,6 +1,6 @@
 /* eslint-disable prefer-template */
 import { existsSync, readFileSync } from 'fs'
-import { join, normalize, relative } from 'pathe'
+import { normalize, relative } from 'pathe'
 import c from 'picocolors'
 import cliTruncate from 'cli-truncate'
 import type { ErrorWithDiff, ParsedStack, Position } from '../types'
@@ -13,12 +13,6 @@ import type { Vitest } from './core'
 import { divider } from './reporters/renderers/utils'
 import type { Logger } from './logger'
 
-export function fileFromParsedStack(stack: ParsedStack) {
-  if (stack?.sourcePos?.source?.startsWith('..'))
-    return join(stack.file, '../', stack.sourcePos.source)
-  return stack.file
-}
-
 interface PrintErrorOptions {
   type?: string
   fullStack?: boolean
@@ -64,14 +58,13 @@ export async function printError(error: unknown, ctx: Vitest, options: PrintErro
     ctx.logger.error(c.yellow(e.frame))
   }
   else {
-    printStack(ctx, stacks, nearest, errorProperties, (s, pos) => {
+    printStack(ctx, stacks, nearest, errorProperties, (s) => {
       if (showCodeFrame && s === nearest && nearest) {
-        const file = fileFromParsedStack(nearest)
         // could point to non-existing original file
         // for example, when there is a source map file, but no source in node_modules
-        if (nearest.file === file || existsSync(file)) {
-          const sourceCode = readFileSync(file, 'utf-8')
-          ctx.logger.error(c.yellow(generateCodeFrame(sourceCode, 4, pos)))
+        if (existsSync(nearest.file)) {
+          const sourceCode = readFileSync(nearest.file, 'utf-8')
+          ctx.logger.error(c.yellow(generateCodeFrame(sourceCode, 4)))
         }
       }
     })
@@ -181,7 +174,7 @@ function printStack(
   stack: ParsedStack[],
   highlight: ParsedStack | undefined,
   errorProperties: Record,
-  onStack?: ((stack: ParsedStack, pos: Position) => void),
+  onStack?: ((stack: ParsedStack) => void),
 ) {
   if (!stack.length)
     return
@@ -189,13 +182,11 @@ function printStack(
   const logger = ctx.logger
 
   for (const frame of stack) {
-    const pos = frame.sourcePos || frame
     const color = frame === highlight ? c.yellow : c.gray
-    const file = fileFromParsedStack(frame)
-    const path = relative(ctx.config.root, file)
+    const path = relative(ctx.config.root, frame.file)
 
-    logger.error(color(` ${c.dim(F_POINTER)} ${[frame.method, c.dim(`${path}:${pos.line}:${pos.column}`)].filter(Boolean).join(' ')}`))
-    onStack?.(frame, pos)
+    logger.error(color(` ${c.dim(F_POINTER)} ${[frame.method, c.dim(`${path}:${frame.line}:${frame.column}`)].filter(Boolean).join(' ')}`))
+    onStack?.(frame)
 
     // reached at test file, skip the follow stack
     if (frame.file in ctx.state.filesMap)
diff --git a/packages/vitest/src/node/reporters/json.ts b/packages/vitest/src/node/reporters/json.ts
index 9865565978616..98e9b50f155f4 100644
--- a/packages/vitest/src/node/reporters/json.ts
+++ b/packages/vitest/src/node/reporters/json.ts
@@ -188,7 +188,6 @@ export class JsonReporter implements Reporter {
     if (!frame)
       return
 
-    const pos = frame.sourcePos || frame
-    return { line: pos.line, column: pos.column }
+    return { line: frame.line, column: frame.column }
   }
 }
diff --git a/packages/vitest/src/node/reporters/junit.ts b/packages/vitest/src/node/reporters/junit.ts
index 666dcbce1ead3..e66a7625dcc8e 100644
--- a/packages/vitest/src/node/reporters/junit.ts
+++ b/packages/vitest/src/node/reporters/junit.ts
@@ -127,10 +127,9 @@ export class JUnitReporter implements Reporter {
 
     // TODO: This is same as printStack but without colors. Find a way to reuse code.
     for (const frame of stack) {
-      const pos = frame.sourcePos ?? frame
       const path = relative(this.ctx.config.root, frame.file)
 
-      await this.baseLog(` ${F_POINTER} ${[frame.method, `${path}:${pos.line}:${pos.column}`].filter(Boolean).join(' ')}`)
+      await this.baseLog(` ${F_POINTER} ${[frame.method, `${path}:${frame.line}:${frame.column}`].filter(Boolean).join(' ')}`)
 
       // reached at test file, skip the follow stack
       if (frame.file in this.ctx.state.filesMap)
diff --git a/packages/vitest/src/typecheck/typechecker.ts b/packages/vitest/src/typecheck/typechecker.ts
index a4f33b7cce4c4..ce8ae34180b86 100644
--- a/packages/vitest/src/typecheck/typechecker.ts
+++ b/packages/vitest/src/typecheck/typechecker.ts
@@ -149,10 +149,6 @@ export class Typechecker {
             line: info.line,
             column: info.column,
             method: '',
-            sourcePos: {
-              line: info.line,
-              column: info.column,
-            },
           },
         ])
         Error.stackTraceLimit = limit
diff --git a/packages/vitest/src/types/general.ts b/packages/vitest/src/types/general.ts
index 3ddfd5ea07b6b..e4d58727a3c71 100644
--- a/packages/vitest/src/types/general.ts
+++ b/packages/vitest/src/types/general.ts
@@ -58,7 +58,6 @@ export interface ParsedStack {
   file: string
   line: number
   column: number
-  sourcePos?: Position
 }
 
 export interface ErrorWithDiff extends Error {