|
|
@ -1,7 +1,9 @@
|
|
|
|
import * as fs from "fs";
|
|
|
|
import * as fs from "fs";
|
|
|
|
import * as path from "path";
|
|
|
|
import * as path from "path";
|
|
|
|
import * as assert from "assert";
|
|
|
|
import * as assert from "assert";
|
|
|
|
import { svelte } from "../helpers.js";
|
|
|
|
import { loadConfig, svelte } from "../helpers.js";
|
|
|
|
|
|
|
|
// keep source-map at version 0.7.x
|
|
|
|
|
|
|
|
// https://github.com/mozilla/source-map/issues/400
|
|
|
|
import { SourceMapConsumer } from "source-map";
|
|
|
|
import { SourceMapConsumer } from "source-map";
|
|
|
|
import { getLocator } from "locate-character";
|
|
|
|
import { getLocator } from "locate-character";
|
|
|
|
|
|
|
|
|
|
|
@ -9,81 +11,80 @@ describe("sourcemaps", () => {
|
|
|
|
fs.readdirSync(`${__dirname}/samples`).forEach(dir => {
|
|
|
|
fs.readdirSync(`${__dirname}/samples`).forEach(dir => {
|
|
|
|
if (dir[0] === ".") return;
|
|
|
|
if (dir[0] === ".") return;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const config = loadConfig(`${__dirname}/samples/${dir}/_config.js`);
|
|
|
|
|
|
|
|
|
|
|
|
// add .solo to a sample directory name to only run that test
|
|
|
|
// add .solo to a sample directory name to only run that test
|
|
|
|
const solo = /\.solo/.test(dir);
|
|
|
|
const solo = config.solo || /\.solo/.test(dir);
|
|
|
|
const skip = /\.skip/.test(dir);
|
|
|
|
const skip = config.skip || /\.skip/.test(dir);
|
|
|
|
|
|
|
|
|
|
|
|
if (solo && process.env.CI) {
|
|
|
|
if (solo && process.env.CI) {
|
|
|
|
throw new Error("Forgot to remove `solo: true` from test");
|
|
|
|
throw new Error("Forgot to remove `solo: true` from test");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
(solo ? it.only : skip ? it.skip : it)(dir, async () => {
|
|
|
|
(solo ? it.only : skip ? it.skip : it)(dir, async () => {
|
|
|
|
const filename = path.resolve(
|
|
|
|
const inputFile = path.resolve(`${__dirname}/samples/${dir}/input.svelte`);
|
|
|
|
`${__dirname}/samples/${dir}/input.svelte`
|
|
|
|
const outputBase = path.resolve(`${__dirname}/samples/${dir}/_actual`);
|
|
|
|
);
|
|
|
|
|
|
|
|
const outputFilename = path.resolve(
|
|
|
|
|
|
|
|
`${__dirname}/samples/${dir}/output`
|
|
|
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const preprocessorFilename = path.resolve(
|
|
|
|
const input = {};
|
|
|
|
`${__dirname}/samples/${dir}/_preprocessor.js`
|
|
|
|
input.code = fs.readFileSync(inputFile, "utf-8");
|
|
|
|
)
|
|
|
|
input.locate = getLocator(input.code);
|
|
|
|
|
|
|
|
|
|
|
|
const input = fs.readFileSync(filename, "utf-8").replace(/\s+$/, "");
|
|
|
|
const preprocessed = await svelte.preprocess(
|
|
|
|
let processed_input = input;
|
|
|
|
input.code,
|
|
|
|
let processed_map = null;
|
|
|
|
config.preprocess, {
|
|
|
|
|
|
|
|
filename: "input.svelte"
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
if (fs.existsSync(preprocessorFilename)) {
|
|
|
|
const { js, css } = svelte.compile(
|
|
|
|
let { preprocessors } = require(preprocessorFilename);
|
|
|
|
preprocessed.code, {
|
|
|
|
if (preprocessors.length > 0) {
|
|
|
|
filename: "input.svelte",
|
|
|
|
({ code: processed_input, map: processed_map } = await svelte.preprocess(input, preprocessors, { filename: 'input.svelte' }));
|
|
|
|
sourcemap: preprocessed.map,
|
|
|
|
}
|
|
|
|
// filenames for sourcemaps
|
|
|
|
}
|
|
|
|
outputFilename: "output.js",
|
|
|
|
|
|
|
|
cssOutputFilename: "output.css",
|
|
|
|
const { js, css } = svelte.compile(processed_input, {
|
|
|
|
|
|
|
|
filename,
|
|
|
|
|
|
|
|
sourcemap: processed_map,
|
|
|
|
|
|
|
|
outputFilename: `${outputFilename}.js`,
|
|
|
|
|
|
|
|
cssOutputFilename: `${outputFilename}.css`
|
|
|
|
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
const _code = js.code.replace(/Svelte v\d+\.\d+\.\d+/, match => match.replace(/\d/g, 'x'));
|
|
|
|
js.code = js.code.replace(
|
|
|
|
|
|
|
|
/generated by Svelte v\d+\.\d+\.\d+/,
|
|
|
|
|
|
|
|
match => match.replace(/\d/g, "x")
|
|
|
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
fs.writeFileSync(`${outputBase}.html`, preprocessed.code);
|
|
|
|
|
|
|
|
if (preprocessed.map) {
|
|
|
|
|
|
|
|
fs.writeFileSync(`${outputBase}.html.map`, JSON.stringify(preprocessed.map, null, 2));
|
|
|
|
|
|
|
|
}
|
|
|
|
fs.writeFileSync(
|
|
|
|
fs.writeFileSync(
|
|
|
|
`${outputFilename}.js`,
|
|
|
|
`${outputBase}.js`,
|
|
|
|
`${_code}\n//# sourceMappingURL=output.js.map`
|
|
|
|
`${js.code}\n//# sourceMappingURL=output.js.map`
|
|
|
|
);
|
|
|
|
);
|
|
|
|
fs.writeFileSync(
|
|
|
|
fs.writeFileSync(
|
|
|
|
`${outputFilename}.js.map`,
|
|
|
|
`${outputBase}.js.map`,
|
|
|
|
JSON.stringify(js.map, null, " ")
|
|
|
|
JSON.stringify(js.map, 0, 2)
|
|
|
|
);
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
|
|
if (css.code) {
|
|
|
|
if (css.code) {
|
|
|
|
fs.writeFileSync(
|
|
|
|
fs.writeFileSync(
|
|
|
|
`${outputFilename}.css`,
|
|
|
|
`${outputBase}.css`,
|
|
|
|
`${css.code}\n/*# sourceMappingURL=output.css.map */`
|
|
|
|
`${css.code}\n/*# sourceMappingURL=output.css.map */`
|
|
|
|
);
|
|
|
|
);
|
|
|
|
fs.writeFileSync(
|
|
|
|
fs.writeFileSync(
|
|
|
|
`${outputFilename}.css.map`,
|
|
|
|
`${outputBase}.css.map`,
|
|
|
|
JSON.stringify(css.map, null, " ")
|
|
|
|
JSON.stringify(css.map, 0, 2)
|
|
|
|
);
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
assert.deepEqual(js.map.sources, ["input.svelte"]);
|
|
|
|
assert.deepEqual(js.map.sources, ["input.svelte"]);
|
|
|
|
|
|
|
|
|
|
|
|
if (css.map) assert.deepEqual(css.map.sources, ["input.svelte"]);
|
|
|
|
if (css.map) assert.deepEqual(css.map.sources, ["input.svelte"]);
|
|
|
|
|
|
|
|
|
|
|
|
const { test } = require(`./samples/${dir}/test.js`);
|
|
|
|
const { test } = require(`./samples/${dir}/test.js`);
|
|
|
|
|
|
|
|
|
|
|
|
const locateInSource = getLocator(input);
|
|
|
|
js.mapConsumer = await new SourceMapConsumer(js.map);
|
|
|
|
|
|
|
|
js.locate = getLocator(js.code);
|
|
|
|
|
|
|
|
|
|
|
|
const smc = await new SourceMapConsumer(js.map);
|
|
|
|
css.mapConsumer = css.map && await new SourceMapConsumer(css.map);
|
|
|
|
const locateInGenerated = getLocator(_code);
|
|
|
|
css.locate = getLocator(css.code || "");
|
|
|
|
|
|
|
|
|
|
|
|
const smcCss = css.map && await new SourceMapConsumer(css.map);
|
|
|
|
test({ assert, input, js, css });
|
|
|
|
const locateInGeneratedCss = getLocator(css.code || '');
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
test({ assert, code: _code, map: js.map, smc, smcCss, locateInSource, locateInGenerated, locateInGeneratedCss });
|
|
|
|
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|