Commit 9da88df
committed
esm: add import trace for evaluation errors
Errors thrown during ESM module evaluation often do not show how the failing
module was reached via imports, making it hard to understand why it was loaded.
This change appends an "Import trace" section to the formatted error stack for
evaluation-time ESM errors. The trace is derived from the loaderβs import graph
and shows the chain of modules leading to the failure.
The implementation preserves existing stack formatting and source map handling,
and is limited to module evaluation only.
A new test verifies that the expected import chain is included.
Refs: #469921 parent 6b5178f commit 9da88df
File tree
6 files changed
+101
-3
lines changed- lib/internal/modules/esm
- test
- es-module
- fixtures/es-modules/import-trace
6 files changed
+101
-3
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
195 | 195 | | |
196 | 196 | | |
197 | 197 | | |
| 198 | + | |
198 | 199 | | |
199 | 200 | | |
200 | 201 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
23 | 23 | | |
24 | 24 | | |
25 | 25 | | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
| 45 | + | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
| 51 | + | |
| 52 | + | |
| 53 | + | |
| 54 | + | |
| 55 | + | |
| 56 | + | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
| 63 | + | |
| 64 | + | |
| 65 | + | |
| 66 | + | |
| 67 | + | |
| 68 | + | |
| 69 | + | |
| 70 | + | |
| 71 | + | |
| 72 | + | |
| 73 | + | |
| 74 | + | |
| 75 | + | |
| 76 | + | |
| 77 | + | |
| 78 | + | |
| 79 | + | |
| 80 | + | |
| 81 | + | |
| 82 | + | |
| 83 | + | |
| 84 | + | |
| 85 | + | |
| 86 | + | |
| 87 | + | |
| 88 | + | |
| 89 | + | |
| 90 | + | |
| 91 | + | |
| 92 | + | |
26 | 93 | | |
27 | 94 | | |
28 | 95 | | |
| |||
53 | 120 | | |
54 | 121 | | |
55 | 122 | | |
56 | | - | |
57 | | - | |
58 | | - | |
59 | 123 | | |
60 | 124 | | |
61 | 125 | | |
| |||
159 | 223 | | |
160 | 224 | | |
161 | 225 | | |
| 226 | + | |
162 | 227 | | |
163 | 228 | | |
164 | 229 | | |
| |||
430 | 495 | | |
431 | 496 | | |
432 | 497 | | |
| 498 | + | |
| 499 | + | |
| 500 | + | |
433 | 501 | | |
434 | 502 | | |
435 | 503 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
0 commit comments