|
|
@ -1,6 +1,6 @@
|
|
|
|
import assert from "assert";
|
|
|
|
import assert from "assert";
|
|
|
|
import * as fs from "fs";
|
|
|
|
import * as fs from "fs";
|
|
|
|
import { svelte } from "../helpers.js";
|
|
|
|
import { env, svelte } from "../helpers.js";
|
|
|
|
|
|
|
|
|
|
|
|
function tryRequire(file) {
|
|
|
|
function tryRequire(file) {
|
|
|
|
try {
|
|
|
|
try {
|
|
|
@ -23,19 +23,45 @@ describe("css", () => {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
(solo ? it.only : it)(dir, () => {
|
|
|
|
(solo ? it.only : it)(dir, () => {
|
|
|
|
const config = tryRequire(`./samples/${dir}/_config.js`) || {};
|
|
|
|
const config = Object.assign(tryRequire(`./samples/${dir}/_config.js`) || {}, {
|
|
|
|
|
|
|
|
format: 'iife',
|
|
|
|
|
|
|
|
name: 'SvelteComponent'
|
|
|
|
|
|
|
|
});
|
|
|
|
const input = fs
|
|
|
|
const input = fs
|
|
|
|
.readFileSync(`test/css/samples/${dir}/input.html`, "utf-8")
|
|
|
|
.readFileSync(`test/css/samples/${dir}/input.html`, "utf-8")
|
|
|
|
.replace(/\s+$/, "");
|
|
|
|
.replace(/\s+$/, "");
|
|
|
|
|
|
|
|
|
|
|
|
const actual = svelte.compile(input, config).css;
|
|
|
|
const actual = svelte.compile(input, config);
|
|
|
|
fs.writeFileSync(`test/css/samples/${dir}/_actual.css`, actual);
|
|
|
|
fs.writeFileSync(`test/css/samples/${dir}/_actual.css`, actual.css);
|
|
|
|
const expected = fs.readFileSync(
|
|
|
|
const expected = {
|
|
|
|
`test/css/samples/${dir}/expected.css`,
|
|
|
|
html: read(`test/css/samples/${dir}/expected.html`),
|
|
|
|
"utf-8"
|
|
|
|
css: read(`test/css/samples/${dir}/expected.css`)
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
assert.equal(actual.trim(), expected.trim());
|
|
|
|
assert.equal(actual.css.trim(), expected.css.trim());
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// verify that the right elements have scoping selectors
|
|
|
|
|
|
|
|
if (expected.html !== null) {
|
|
|
|
|
|
|
|
return env().then(window => {
|
|
|
|
|
|
|
|
const Component = eval(`(function () { ${actual.code}; return SvelteComponent; }())`);
|
|
|
|
|
|
|
|
const target = window.document.querySelector("main");
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
new Component({ target });
|
|
|
|
|
|
|
|
const html = target.innerHTML;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
fs.writeFileSync(`test/css/samples/${dir}/_actual.html`, html);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
assert.equal(html.trim(), expected.html.trim());
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function read(file) {
|
|
|
|
|
|
|
|
try {
|
|
|
|
|
|
|
|
return fs.readFileSync(file, 'utf-8');
|
|
|
|
|
|
|
|
} catch(err) {
|
|
|
|
|
|
|
|
return null;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|