Skip to content

Commit

Permalink
Merge pull request #1258 from sveltejs/gh-1254
Browse files Browse the repository at this point in the history
Fix #1254
  • Loading branch information
Rich-Harris authored Mar 19, 2018
2 parents 35a7fc6 + 5b2e810 commit ea9b6b3
Show file tree
Hide file tree
Showing 5 changed files with 65 additions and 12 deletions.
4 changes: 3 additions & 1 deletion src/generators/nodes/EachBlock.ts
Original file line number Diff line number Diff line change
Expand Up @@ -54,9 +54,11 @@ export default class EachBlock extends Node {
this.block.contextTypes.set(this.context, 'each');
this.block.indexNames.set(this.context, indexName);
this.block.listNames.set(this.context, listName);

if (this.index) {
this.block.getUniqueName(this.index); // this prevents name collisions (#1254)
this.block.indexes.set(this.index, this.context);
this.block.changeableIndexes.set(this.index, this.key)
this.block.changeableIndexes.set(this.index, this.key); // TODO is this right?
}

const context = this.block.getUniqueName(this.context);
Expand Down
4 changes: 2 additions & 2 deletions test/helpers.js
Original file line number Diff line number Diff line change
Expand Up @@ -174,7 +174,7 @@ function capitalise(str) {
return str[0].toUpperCase() + str.slice(1);
}

export function showOutput(cwd, options = {}, s = svelte) {
export function showOutput(cwd, options = {}, compile = svelte.compile) {
glob.sync('**/*.html', { cwd }).forEach(file => {
if (file[0] === '_') return;

Expand All @@ -183,7 +183,7 @@ export function showOutput(cwd, options = {}, s = svelte) {
.replace(/^\d/, '_$&')
.replace(/[^a-zA-Z0-9_$]/g, '');

const { code } = s.compile(
const { code } = compile(
fs.readFileSync(`${cwd}/${file}`, 'utf-8'),
Object.assign(options, {
filename: file,
Expand Down
23 changes: 14 additions & 9 deletions test/runtime/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -14,9 +14,11 @@ import {
spaces
} from "../helpers.js";

let svelte$;
let svelte;

let compileOptions = null;
let compile = null;

function getName(filename) {
const base = path.basename(filename).replace(".html", "");
Expand All @@ -25,15 +27,16 @@ function getName(filename) {

describe("runtime", () => {
before(() => {
svelte = loadSvelte(true);
svelte = loadSvelte(false);
svelte$ = loadSvelte(true);

require.extensions[".html"] = function(module, filename) {
const options = Object.assign(
{ filename, name: getName(filename), format: 'cjs' },
compileOptions
);

const { code } = svelte.compile(fs.readFileSync(filename, "utf-8"), options);
const { code } = compile(fs.readFileSync(filename, "utf-8"), options);

return module._compile(code, filename);
};
Expand All @@ -58,6 +61,8 @@ describe("runtime", () => {
throw new Error('skipping test, already failed');
}

compile = (config.preserveIdentifiers ? svelte : svelte$).compile;

const cwd = path.resolve(`test/runtime/samples/${dir}`);
global.document.title = '';

Expand All @@ -75,7 +80,7 @@ describe("runtime", () => {
`test/runtime/samples/${dir}/main.html`,
"utf-8"
);
const { code } = svelte.compile(source, compileOptions);
const { code } = compile(source, compileOptions);
const startIndex = code.indexOf("function create_main_fragment"); // may change!
if (startIndex === -1) throw new Error("missing create_main_fragment");
const endIndex = code.lastIndexOf("export default");
Expand All @@ -95,7 +100,7 @@ describe("runtime", () => {
if (err.frame) {
console.error(chalk.red(err.frame)); // eslint-disable-line no-console
}
showOutput(cwd, { shared, format: 'cjs', store: !!compileOptions.store }, svelte); // eslint-disable-line no-console
showOutput(cwd, { shared, format: 'cjs', store: !!compileOptions.store }, compile); // eslint-disable-line no-console
throw err;
}
}
Expand Down Expand Up @@ -140,7 +145,7 @@ describe("runtime", () => {
try {
SvelteComponent = require(`./samples/${dir}/main.html`);
} catch (err) {
showOutput(cwd, { shared, format: 'cjs', hydratable: hydrate, store: !!compileOptions.store }, svelte); // eslint-disable-line no-console
showOutput(cwd, { shared, format: 'cjs', hydratable: hydrate, store: !!compileOptions.store }, compile); // eslint-disable-line no-console
throw err;
}

Expand Down Expand Up @@ -198,12 +203,12 @@ describe("runtime", () => {
config.error(assert, err);
} else {
failed.add(dir);
showOutput(cwd, { shared, format: 'cjs', hydratable: hydrate, store: !!compileOptions.store }, svelte); // eslint-disable-line no-console
showOutput(cwd, { shared, format: 'cjs', hydratable: hydrate, store: !!compileOptions.store }, compile); // eslint-disable-line no-console
throw err;
}
})
.then(() => {
if (config.show) showOutput(cwd, { shared, format: 'cjs', hydratable: hydrate, store: !!compileOptions.store }, svelte);
if (config.show) showOutput(cwd, { shared, format: 'cjs', hydratable: hydrate, store: !!compileOptions.store }, compile);
});
});
}
Expand All @@ -216,7 +221,7 @@ describe("runtime", () => {
});

it("fails if options.target is missing in dev mode", () => {
const { code } = svelte.compile(`<div></div>`, {
const { code } = svelte$.compile(`<div></div>`, {
format: "iife",
name: "SvelteComponent",
dev: true
Expand All @@ -232,7 +237,7 @@ describe("runtime", () => {
});

it("fails if options.hydrate is true but the component is non-hydratable", () => {
const { code } = svelte.compile(`<div></div>`, {
const { code } = svelte$.compile(`<div></div>`, {
format: "iife",
name: "SvelteComponent",
dev: true
Expand Down
22 changes: 22 additions & 0 deletions test/runtime/samples/deconflict-elements-indexes/_config.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
export default {
html: `
<div>
<i>one</i>
</div>
`,

preserveIdentifiers: true,

test(assert, component, target) {
const { tagList } = component.get();
tagList.push('two');
component.set({ tagList });

assert.htmlEqual(target.innerHTML, `
<div>
<i>one</i>
<i>two</i>
</div>
`);
}
};
24 changes: 24 additions & 0 deletions test/runtime/samples/deconflict-elements-indexes/main.html
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
<div>
{{#each tagList as tag, i}}
<i on:click='remove(i)'>
{{tag}}
</i>
{{/each}}
</div>

<script>
export default {
data() {
return {
inProgress: false,
tagList: ['one']
};
},

methods: {
remove(index) {
// ...
}
}
};
</script>

0 comments on commit ea9b6b3

Please sign in to comment.