Skip to content

Instantly share code, notes, and snippets.

@AriPerkkio
Created August 6, 2025 17:12
Show Gist options
  • Save AriPerkkio/87d6270951c61fc1ced3c810afa7ccd3 to your computer and use it in GitHub Desktop.
Save AriPerkkio/87d6270951c61fc1ced3c810afa7ccd3 to your computer and use it in GitHub Desktop.
debug module runner sourcemapping
const __vite_ssr_import_0__ = await __vite_ssr_import__("node:crypto", {"importedNames":["randomUUID"]});
const __vite_ssr_import_1__ = await __vite_ssr_import__("node:fs", {"importedNames":["rmSync"]});
const __vite_ssr_import_2__ = await __vite_ssr_import__("node:fs/promises", {"importedNames":["writeFile"]});
const __vite_ssr_import_3__ = await __vite_ssr_import__("node:path", {"importedNames":["normalize","resolve"]});
const __vite_ssr_import_4__ = await __vite_ssr_import__("node:url", {"importedNames":["fileURLToPath","pathToFileURL"]});
const __vite_ssr_import_5__ = await __vite_ssr_import__("/node_modules/.pnpm/[email protected]/node_modules/istanbul-lib-coverage/index.js", {"importedNames":["createCoverageMap"]});
const __vite_ssr_import_6__ = await __vite_ssr_import__("/node_modules/.pnpm/[email protected]/node_modules/magic-string/dist/magic-string.es.mjs", {"importedNames":["default"]});
const __vite_ssr_import_7__ = await __vite_ssr_import__("/node_modules/.pnpm/[email protected]_@[email protected][email protected][email protected]/node_modules/vitest/dist/index.js", {"importedNames":["expect","onTestFinished","test"]});
const __vite_ssr_import_8__ = await __vite_ssr_import__("/src/index.ts", {"importedNames":["default"]});
const __vite_ssr_import_9__ = await __vite_ssr_import__("/src/location.ts", {"importedNames":["createEmptySourceMap"]});
const __vite_ssr_import_10__ = await __vite_ssr_import__("/test/utils/index.ts", {"importedNames":["parse"]});
__vite_ssr_import_7__.test.only("function not in source maps is excluded", async () => {
const filename = (0,__vite_ssr_import_3__.normalize)((0,__vite_ssr_import_3__.resolve)("/some/file.ts"));
const code = new __vite_ssr_import_6__.default(`export function covered() {
return "Hello world";
}
export function excluded() {
return "Hello world";
}
export function uncovered() {
return "Hello world";
}
`).toString();
const sourceMap = new __vite_ssr_import_6__.default(`export function covered() {
return "Hello world";
}
export function uncovered() {
return "Hello world";
}
`).generateMap({ hires: "boundary", file: filename });
const data = await (0,__vite_ssr_import_8__.default)({
code,
sourceMap,
coverage: {
url: (0,__vite_ssr_import_4__.pathToFileURL)(filename).href,
functions: [
{
functionName: "covered",
isBlockCoverage: true,
ranges: [{ startOffset: 0, endOffset: 55, count: 1 }]
},
{
functionName: "excluded",
isBlockCoverage: true,
ranges: [{ startOffset: 57, endOffset: 111, count: 1 }]
},
{
functionName: "uncovered",
isBlockCoverage: true,
ranges: [{ startOffset: 113, endOffset: 169, count: 0 }]
}
]
},
ast: (0,__vite_ssr_import_10__.parse)(code)
});
const coverage = (0,__vite_ssr_import_5__.createCoverageMap)(data);
const fileCoverage = coverage.fileCoverageFor(filename);
try {
console.log("Start");
(0,__vite_ssr_import_7__.expect)(fileCoverage).toMatchInlineSnapshot(`
{
"branches": "0/0 (100%)",
"functions": "1/2 (50%)",
"lines": "1/2 (50%)",
"statements": "1/2 (50%)",
}
`);
console.log("end");
} catch (error) {
console.log("Failed with", error);
};
const functions = Object.values(fileCoverage.fnMap).map((fn) => fn.name);
(0,__vite_ssr_import_7__.expect)(functions).toMatchInlineSnapshot(`
[
"covered",
"uncovered",
]
`);
(0,__vite_ssr_import_7__.expect)(fileCoverage.getLineCoverage()).toMatchInlineSnapshot(`
{
"10": 0,
"2": 1,
}
`);
});
(0,__vite_ssr_import_7__.test)("map.sources can be file urls", async () => {
const source = (0,__vite_ssr_import_4__.pathToFileURL)((0,__vite_ssr_import_3__.normalize)((0,__vite_ssr_import_3__.resolve)("/some/path/to/source.ts")));
const target = (0,__vite_ssr_import_4__.pathToFileURL)((0,__vite_ssr_import_3__.normalize)((0,__vite_ssr_import_3__.resolve)("/other/path/to/target.js")));
const s = new __vite_ssr_import_6__.default(`export function covered() {
return "Hello world";
}
`);
const code = s.toString();
const sourceMap = s.generateMap({
file: target.href,
hires: "boundary"
});
sourceMap.sources = [source.href];
const data = await (0,__vite_ssr_import_8__.default)({
code,
sourceMap,
coverage: {
url: target.href,
functions: [
{
functionName: "covered",
isBlockCoverage: true,
ranges: [{ startOffset: 0, endOffset: 55, count: 1 }]
}
]
},
ast: (0,__vite_ssr_import_10__.parse)(code)
});
const coverage = (0,__vite_ssr_import_5__.createCoverageMap)(data);
const fileCoverage = coverage.fileCoverageFor((0,__vite_ssr_import_4__.fileURLToPath)(source));
(0,__vite_ssr_import_7__.expect)(fileCoverage).toMatchInlineSnapshot(`
{
"branches": "0/0 (100%)",
"functions": "1/1 (100%)",
"lines": "1/1 (100%)",
"statements": "1/1 (100%)",
}
`);
});
(0,__vite_ssr_import_7__.test)("source map is optional", async () => {
const filename = (0,__vite_ssr_import_3__.normalize)((0,__vite_ssr_import_3__.resolve)("/some/file.ts"));
const s = new __vite_ssr_import_6__.default(`export function covered() {
return "Hello world";
}
`);
const code = s.toString();
const data = await (0,__vite_ssr_import_8__.default)({
code,
sourceMap: void 0,
ast: (0,__vite_ssr_import_10__.parse)(code),
coverage: {
url: (0,__vite_ssr_import_4__.pathToFileURL)(filename).href,
functions: [
{
functionName: "covered",
isBlockCoverage: true,
ranges: [{ startOffset: 0, endOffset: 53, count: 1 }]
}
]
}
});
const coverage = (0,__vite_ssr_import_5__.createCoverageMap)(data);
const fileCoverage = coverage.fileCoverageFor(filename);
(0,__vite_ssr_import_7__.expect)(fileCoverage).toMatchInlineSnapshot(`
{
"branches": "0/0 (100%)",
"functions": "1/1 (100%)",
"lines": "1/1 (100%)",
"statements": "1/1 (100%)",
}
`);
});
(0,__vite_ssr_import_7__.test)("empty source map mappings match magic-string", async () => {
const filename = "hello.js";
const code = `function hello(name) {
return "Hello " + name;
}`;
const expected = new __vite_ssr_import_6__.default(code, { filename }).generateDecodedMap({
file: filename,
hires: "boundary",
includeContent: true,
source: filename
});
const actual = (0,__vite_ssr_import_9__.createEmptySourceMap)(filename, code);
(0,__vite_ssr_import_7__.expect)(actual.mappings).toStrictEqual(expected.mappings);
});
(0,__vite_ssr_import_7__.test)("inline source map as base64", async () => {
const filename = (0,__vite_ssr_import_3__.normalize)((0,__vite_ssr_import_3__.resolve)("/some/file.ts"));
const s = new __vite_ssr_import_6__.default(` export function covered() {
return "Hello world";
}
`);
s.replace("export function", "\n\n\nexport function");
let code = s.toString();
const map = s.generateDecodedMap({ hires: "boundary", source: filename });
const encoded = Buffer.from(JSON.stringify(map)).toString("base64");
code += `
//# sourceMappingURL=data:application/json;base64,${encoded}
`;
const data = await (0,__vite_ssr_import_8__.default)({
code,
sourceMap: void 0,
ast: (0,__vite_ssr_import_10__.parse)(code),
coverage: {
url: (0,__vite_ssr_import_4__.pathToFileURL)(filename).href,
functions: [
{
functionName: "covered",
isBlockCoverage: true,
ranges: [{ startOffset: 0, endOffset: 53, count: 1 }]
}
]
}
});
const coverage = (0,__vite_ssr_import_5__.createCoverageMap)(data);
const fileCoverage = coverage.fileCoverageFor(filename);
(0,__vite_ssr_import_7__.expect)(fileCoverage).toMatchInlineSnapshot(`
{
"branches": "0/0 (100%)",
"functions": "1/1 (100%)",
"lines": "1/1 (100%)",
"statements": "1/1 (100%)",
}
`);
(0,__vite_ssr_import_7__.expect)(fileCoverage.getLineCoverage()).toMatchInlineSnapshot(`
{
"2": 1,
}
`);
});
(0,__vite_ssr_import_7__.test)("inline source map as filename", async () => {
const uuid = (0,__vite_ssr_import_0__.randomUUID)();
const filename = (0,__vite_ssr_import_3__.normalize)((0,__vite_ssr_import_3__.resolve)(__vite_ssr_import_meta__.dirname, `file-${uuid}.ts`));
const mapName = (0,__vite_ssr_import_3__.normalize)(
(0,__vite_ssr_import_3__.resolve)(__vite_ssr_import_meta__.dirname, `file-${uuid}.js.map`)
);
const s = new __vite_ssr_import_6__.default(` export function covered() {
return "Hello world";
}
`);
s.replace("export function", "\n\n\nexport function");
let code = s.toString();
const map = s.generateDecodedMap({ hires: "boundary", source: filename });
(0,__vite_ssr_import_7__.onTestFinished)(() => (0,__vite_ssr_import_1__.rmSync)(mapName, { force: true }));
await (0,__vite_ssr_import_2__.writeFile)(mapName, JSON.stringify(map, null, 2), "utf8");
code += `
//# sourceMappingURL=file-${uuid}.js.map
`;
const data = await (0,__vite_ssr_import_8__.default)({
code,
sourceMap: void 0,
ast: (0,__vite_ssr_import_10__.parse)(code),
coverage: {
url: (0,__vite_ssr_import_4__.pathToFileURL)(filename).href,
functions: [
{
functionName: "covered",
isBlockCoverage: true,
ranges: [{ startOffset: 0, endOffset: 53, count: 1 }]
}
]
}
});
const coverage = (0,__vite_ssr_import_5__.createCoverageMap)(data);
const fileCoverage = coverage.fileCoverageFor(filename);
(0,__vite_ssr_import_7__.expect)(fileCoverage).toMatchInlineSnapshot(`
{
"branches": "0/0 (100%)",
"functions": "1/1 (100%)",
"lines": "1/1 (100%)",
"statements": "1/1 (100%)",
}
`);
(0,__vite_ssr_import_7__.expect)(fileCoverage.getLineCoverage()).toMatchInlineSnapshot(`
{
"2": 1,
}
`);
});
//# sourceMappingSource=vite-generated
//# sourceMappingURL=data:application/json;base64,{"version":3,"mappings":"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","names":[],"ignoreList":[],"sources":["source-maps.test.ts"],"sourcesContent":["import { randomUUID } from \"node:crypto\";\nimport { rmSync } from \"node:fs\";\nimport { writeFile } from \"node:fs/promises\";\nimport { normalize, resolve } from \"node:path\";\nimport { fileURLToPath, pathToFileURL } from \"node:url\";\n\nimport { createCoverageMap } from \"istanbul-lib-coverage\";\nimport MagicString from \"magic-string\";\nimport { expect, onTestFinished, test } from \"vitest\";\n\nimport convert from \"../src\";\nimport { createEmptySourceMap } from \"../src/location\";\nimport { parse } from \"./utils\";\n\ntest.only(\"function not in source maps is excluded\", async () => {\n  const filename = normalize(resolve(\"/some/file.ts\"));\n\n  const code = new MagicString(`\\\nexport function covered() {\n  return \"Hello world\";\n}\n\nexport function excluded() {\n  return \"Hello world\";\n}\n\nexport function uncovered() {\n  return \"Hello world\";\n}\n`).toString();\n\n  const sourceMap = new MagicString(`\\\nexport function covered() {\n  return \"Hello world\";\n}\n\n\n\n\n\nexport function uncovered() {\n  return \"Hello world\";\n}\n`).generateMap({ hires: \"boundary\", file: filename });\n\n  const data = await convert({\n    code,\n    sourceMap,\n    coverage: {\n      url: pathToFileURL(filename).href,\n      functions: [\n        {\n          functionName: \"covered\",\n          isBlockCoverage: true,\n          ranges: [{ startOffset: 0, endOffset: 55, count: 1 }],\n        },\n        {\n          functionName: \"excluded\",\n          isBlockCoverage: true,\n          ranges: [{ startOffset: 57, endOffset: 111, count: 1 }],\n        },\n        {\n          functionName: \"uncovered\",\n          isBlockCoverage: true,\n          ranges: [{ startOffset: 113, endOffset: 169, count: 0 }],\n        },\n      ],\n    },\n    ast: parse(code),\n  });\n\n  const coverage = createCoverageMap(data);\n  const fileCoverage = coverage.fileCoverageFor(filename);\n\n  try {\n    console.log(\"Start\");\n\n    expect(fileCoverage).toMatchInlineSnapshot(`\n    {\n      \"branches\": \"0/0 (100%)\",\n      \"functions\": \"1/2 (50%)\",\n      \"lines\": \"1/2 (50%)\",\n      \"statements\": \"1/2 (50%)\",\n    }\n  `);\n\n    console.log(\"end\");\n  } catch (error) {\n    console.log(\"Failed with\", error);\n  }\n\n  const functions = Object.values(fileCoverage.fnMap).map((fn) => fn.name);\n\n  expect(functions).toMatchInlineSnapshot(`\n    [\n      \"covered\",\n      \"uncovered\",\n    ]\n  `);\n\n  expect(fileCoverage.getLineCoverage()).toMatchInlineSnapshot(`\n    {\n      \"10\": 0,\n      \"2\": 1,\n    }\n  `);\n});\n\ntest(\"map.sources can be file urls\", async () => {\n  const source = pathToFileURL(normalize(resolve(\"/some/path/to/source.ts\")));\n  const target = pathToFileURL(normalize(resolve(\"/other/path/to/target.js\")));\n\n  const s = new MagicString(`\\\nexport function covered() {\n  return \"Hello world\";\n}\n`);\n\n  const code = s.toString();\n  const sourceMap = s.generateMap({\n    file: target.href,\n    hires: \"boundary\",\n  });\n\n  sourceMap.sources = [source.href];\n\n  const data = await convert({\n    code,\n    sourceMap,\n    coverage: {\n      url: target.href,\n      functions: [\n        {\n          functionName: \"covered\",\n          isBlockCoverage: true,\n          ranges: [{ startOffset: 0, endOffset: 55, count: 1 }],\n        },\n      ],\n    },\n    ast: parse(code),\n  });\n\n  const coverage = createCoverageMap(data);\n  const fileCoverage = coverage.fileCoverageFor(fileURLToPath(source));\n\n  expect(fileCoverage).toMatchInlineSnapshot(`\n    {\n      \"branches\": \"0/0 (100%)\",\n      \"functions\": \"1/1 (100%)\",\n      \"lines\": \"1/1 (100%)\",\n      \"statements\": \"1/1 (100%)\",\n    }\n  `);\n});\n\ntest(\"source map is optional\", async () => {\n  const filename = normalize(resolve(\"/some/file.ts\"));\n\n  const s = new MagicString(`\\\nexport function covered() {\n  return \"Hello world\";\n}\n`);\n\n  const code = s.toString();\n\n  const data = await convert({\n    code,\n    sourceMap: undefined,\n    ast: parse(code),\n    coverage: {\n      url: pathToFileURL(filename).href,\n      functions: [\n        {\n          functionName: \"covered\",\n          isBlockCoverage: true,\n          ranges: [{ startOffset: 0, endOffset: 53, count: 1 }],\n        },\n      ],\n    },\n  });\n\n  const coverage = createCoverageMap(data);\n  const fileCoverage = coverage.fileCoverageFor(filename);\n\n  expect(fileCoverage).toMatchInlineSnapshot(`\n    {\n      \"branches\": \"0/0 (100%)\",\n      \"functions\": \"1/1 (100%)\",\n      \"lines\": \"1/1 (100%)\",\n      \"statements\": \"1/1 (100%)\",\n    }\n  `);\n});\n\ntest(\"empty source map mappings match magic-string\", async () => {\n  const filename = \"hello.js\";\n  const code = `\\\nfunction hello(name) {\n  return \"Hello \" + name;\n}`;\n\n  const expected = new MagicString(code, { filename }).generateDecodedMap({\n    file: filename,\n    hires: \"boundary\",\n    includeContent: true,\n    source: filename,\n  });\n\n  const actual = createEmptySourceMap(filename, code);\n\n  expect(actual.mappings).toStrictEqual(expected.mappings);\n});\n\ntest(\"inline source map as base64\", async () => {\n  const filename = normalize(resolve(\"/some/file.ts\"));\n\n  const s = new MagicString(`\\\n    export function covered() {\n      return \"Hello world\";\n    }\n`);\n\n  s.replace(\"export function\", \"\\n\\n\\nexport function\");\n\n  let code = s.toString();\n  const map = s.generateDecodedMap({ hires: \"boundary\", source: filename });\n  const encoded = Buffer.from(JSON.stringify(map)).toString(\"base64\");\n\n  code += `\\n//# sourceMappingURL=data:application/json;base64,${encoded}\\n`;\n\n  const data = await convert({\n    code,\n    sourceMap: undefined,\n    ast: parse(code),\n    coverage: {\n      url: pathToFileURL(filename).href,\n      functions: [\n        {\n          functionName: \"covered\",\n          isBlockCoverage: true,\n          ranges: [{ startOffset: 0, endOffset: 53, count: 1 }],\n        },\n      ],\n    },\n  });\n\n  const coverage = createCoverageMap(data);\n  const fileCoverage = coverage.fileCoverageFor(filename);\n\n  expect(fileCoverage).toMatchInlineSnapshot(`\n    {\n      \"branches\": \"0/0 (100%)\",\n      \"functions\": \"1/1 (100%)\",\n      \"lines\": \"1/1 (100%)\",\n      \"statements\": \"1/1 (100%)\",\n    }\n  `);\n  expect(fileCoverage.getLineCoverage()).toMatchInlineSnapshot(`\n    {\n      \"2\": 1,\n    }\n  `);\n});\n\ntest(\"inline source map as filename\", async () => {\n  const uuid = randomUUID();\n  const filename = normalize(resolve(import.meta.dirname, `file-${uuid}.ts`));\n  const mapName = normalize(\n    resolve(import.meta.dirname, `file-${uuid}.js.map`),\n  );\n\n  const s = new MagicString(`\\\n    export function covered() {\n      return \"Hello world\";\n    }\n`);\n\n  s.replace(\"export function\", \"\\n\\n\\nexport function\");\n\n  let code = s.toString();\n  const map = s.generateDecodedMap({ hires: \"boundary\", source: filename });\n\n  onTestFinished(() => rmSync(mapName, { force: true }));\n  await writeFile(mapName, JSON.stringify(map, null, 2), \"utf8\");\n\n  code += `\\n//# sourceMappingURL=file-${uuid}.js.map\\n`;\n\n  const data = await convert({\n    code,\n    sourceMap: undefined,\n    ast: parse(code),\n    coverage: {\n      url: pathToFileURL(filename).href,\n      functions: [\n        {\n          functionName: \"covered\",\n          isBlockCoverage: true,\n          ranges: [{ startOffset: 0, endOffset: 53, count: 1 }],\n        },\n      ],\n    },\n  });\n\n  const coverage = createCoverageMap(data);\n  const fileCoverage = coverage.fileCoverageFor(filename);\n\n  expect(fileCoverage).toMatchInlineSnapshot(`\n    {\n      \"branches\": \"0/0 (100%)\",\n      \"functions\": \"1/1 (100%)\",\n      \"lines\": \"1/1 (100%)\",\n      \"statements\": \"1/1 (100%)\",\n    }\n  `);\n  expect(fileCoverage.getLineCoverage()).toMatchInlineSnapshot(`\n    {\n      \"2\": 1,\n    }\n  `);\n});\n"],"file":"/test/source-maps.test.ts"}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment