Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

v2 #1348

Merged
merged 42 commits into from
Apr 19, 2018
Merged

v2 #1348

Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
42 commits
Select commit Hold shift + click to select a range
470eacf
remove obsolete methods
Rich-Harris Apr 15, 2018
34d2fbf
remove ES5 constraint
Rich-Harris Apr 15, 2018
7b40fed
remove unused store methods
Rich-Harris Apr 15, 2018
9070969
remove references to obsolete methods
Rich-Harris Apr 15, 2018
9bc8b74
update store tests
Rich-Harris Apr 15, 2018
daa2635
update snapshot tests
Rich-Harris Apr 15, 2018
2f86bd3
update tests to account for removal of observe
Rich-Harris Apr 15, 2018
df4e367
update snapshot tests
Rich-Harris Apr 15, 2018
a3add04
remove code, map and cssMap from svelte.compile output
Rich-Harris Apr 15, 2018
80e0dce
remove validate and Stylesheet from public API
Rich-Harris Apr 15, 2018
4fe8d95
dont typecast numeric attributes
Rich-Harris Apr 16, 2018
21168bf
remove v1 parser tests
Rich-Harris Apr 16, 2018
286caba
oops
Rich-Harris Apr 16, 2018
ab79cc6
remove v1 snapshot tests
Rich-Harris Apr 16, 2018
ce11460
remove deprecated renderCss method
Rich-Harris Apr 16, 2018
4b3da75
remove v1 runtime tests
Rich-Harris Apr 16, 2018
1143b0a
remove v1 tests
Rich-Harris Apr 16, 2018
2d5b47b
remove store option
Rich-Harris Apr 16, 2018
39ad124
update validation tests
Rich-Harris Apr 16, 2018
8eb4adc
small fix
Rich-Harris Apr 16, 2018
a275960
SSR tests
Rich-Harris Apr 16, 2018
39d0b86
update hydration tests
Rich-Harris Apr 16, 2018
40e6b4f
update css tests
Rich-Harris Apr 16, 2018
87a8e37
remove cascade option
Rich-Harris Apr 16, 2018
cae4dd9
fix some more tests
Rich-Harris Apr 16, 2018
73e83e5
tidy up
Rich-Harris Apr 16, 2018
dadf21c
skip test, fix post-v2
Rich-Harris Apr 16, 2018
d2a5b36
remove redundant test
Rich-Harris Apr 16, 2018
a32c2ba
Merge branch 'master' into v2
Rich-Harris Apr 17, 2018
7e733d8
enforce uppercase component names
Rich-Harris Apr 17, 2018
b9fcc16
update test
Rich-Harris Apr 17, 2018
07bad96
tidy up
Rich-Harris Apr 17, 2018
5a457bf
rename loc to start, include character info in locations
Rich-Harris Apr 17, 2018
69c41a0
use new Function instead of eval, to prevent Rollup complaining
Rich-Harris Apr 17, 2018
a2d3d05
merge master -> v2
Rich-Harris Apr 18, 2018
da6fa85
update README
Rich-Harris Apr 18, 2018
1e9b32a
fixes
Rich-Harris Apr 18, 2018
f2b6ec4
fix <svelte:window> to use new APIs
Conduitry Apr 18, 2018
06517ce
remove erroneous warnings
Rich-Harris Apr 18, 2018
fb9d7cd
remove obsolete hash stuff
Rich-Harris Apr 18, 2018
6ff02b2
remove legacy prop stuff, now that we emit ES2015
Rich-Harris Apr 18, 2018
aaab685
support $method(...) calls, and warn on store.method(...)
Rich-Harris Apr 19, 2018
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
67 changes: 27 additions & 40 deletions test/parser/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ import assert from 'assert';
import fs from 'fs';
import { svelte, tryToLoadJson } from '../helpers.js';

describe('parse', () => {
describe.only('parse', () => {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

D:

fs.readdirSync('test/parser/samples').forEach(dir => {
if (dir[0] === '.') return;

Expand All @@ -18,48 +18,35 @@ describe('parse', () => {
(solo ? it.only : it)(dir, () => {
const options = tryToLoadJson(`test/parser/samples/${dir}/options.json`) || {};

function test(options, input, expectedOutput, expectedError, outputFile) {
options.parser = 'v2'; // TODO remove

const input = fs.readFileSync(`test/parser/samples/${dir}/input.html`, 'utf-8').replace(/\s+$/, '');
const expectedOutput = tryToLoadJson(`test/parser/samples/${dir}/output.json`);
const expectedError = tryToLoadJson(`test/parser/samples/${dir}/error.json`);

try {
const actual = svelte.parse(input, options);

fs.writeFileSync(`test/parser/samples/${dir}/_actual.json`, JSON.stringify(actual, null, '\t'));

assert.deepEqual(actual.html, expectedOutput.html);
assert.deepEqual(actual.css, expectedOutput.css);
assert.deepEqual(actual.js, expectedOutput.js);
} catch (err) {
if (err.name !== 'ParseError') throw err;
if (!expectedError) throw err;

try {
const actual = svelte.parse(input, options);

fs.writeFileSync(outputFile, JSON.stringify(actual, null, '\t'));

assert.deepEqual(actual.html, expectedOutput.html);
assert.deepEqual(actual.css, expectedOutput.css);
assert.deepEqual(actual.js, expectedOutput.js);
} catch (err) {
if (err.name !== 'ParseError') throw err;
if (!expectedError) throw err;

try {
assert.equal(err.code, expectedError.code);
assert.equal(err.message, expectedError.message);
assert.deepEqual(err.loc, expectedError.loc);
assert.equal(err.pos, expectedError.pos);
assert.equal(err.toString().split('\n')[0], `${expectedError.message} (${expectedError.loc.line}:${expectedError.loc.column})`);
} catch (err2) {
const e = err2.code === 'MODULE_NOT_FOUND' ? err : err2;
throw e;
}
assert.equal(err.code, expectedError.code);
assert.equal(err.message, expectedError.message);
assert.deepEqual(err.loc, expectedError.loc);
assert.equal(err.pos, expectedError.pos);
assert.equal(err.toString().split('\n')[0], `${expectedError.message} (${expectedError.loc.line}:${expectedError.loc.column})`);
} catch (err2) {
const e = err2.code === 'MODULE_NOT_FOUND' ? err : err2;
throw e;
}
}

// TODO remove v1 tests
test(
options,
fs.readFileSync(`test/parser/samples/${dir}/input.html`, 'utf-8').replace(/\s+$/, ''),
tryToLoadJson(`test/parser/samples/${dir}/output.json`),
tryToLoadJson(`test/parser/samples/${dir}/error.json`),
`test/parser/samples/${dir}/_actual.json`
);

test(
Object.assign({ parser: 'v2' }, options),
fs.readFileSync(`test/parser/samples/${dir}/input-v2.html`, 'utf-8').replace(/\s+$/, ''),
tryToLoadJson(`test/parser/samples/${dir}/output-v2.json`),
tryToLoadJson(`test/parser/samples/${dir}/error-v2.json`),
`test/parser/samples/${dir}/_actual-v2.json`
);
});
});

Expand Down
1 change: 0 additions & 1 deletion test/parser/samples/action-with-call/input-v2.html

This file was deleted.

47 changes: 0 additions & 47 deletions test/parser/samples/action-with-call/output-v2.json

This file was deleted.

1 change: 0 additions & 1 deletion test/parser/samples/action-with-identifier/input-v2.html

This file was deleted.

33 changes: 0 additions & 33 deletions test/parser/samples/action-with-identifier/output-v2.json

This file was deleted.

1 change: 0 additions & 1 deletion test/parser/samples/action-with-literal/input-v2.html

This file was deleted.

34 changes: 0 additions & 34 deletions test/parser/samples/action-with-literal/output-v2.json

This file was deleted.

1 change: 0 additions & 1 deletion test/parser/samples/action/input-v2.html

This file was deleted.

28 changes: 0 additions & 28 deletions test/parser/samples/action/output-v2.json

This file was deleted.

This file was deleted.

2 changes: 1 addition & 1 deletion test/parser/samples/attribute-dynamic-boolean/input.html
Original file line number Diff line number Diff line change
@@ -1 +1 @@
<textarea readonly='{{readonly}}'></textarea>
<textarea readonly={readonly}></textarea>
40 changes: 0 additions & 40 deletions test/parser/samples/attribute-dynamic-boolean/output-v2.json

This file was deleted.

16 changes: 8 additions & 8 deletions test/parser/samples/attribute-dynamic-boolean/output.json
Original file line number Diff line number Diff line change
@@ -1,30 +1,30 @@
{
"hash": 3179574701,
"hash": "7xolfv",
"html": {
"start": 0,
"end": 45,
"end": 41,
"type": "Fragment",
"children": [
{
"start": 0,
"end": 45,
"end": 41,
"type": "Element",
"name": "textarea",
"attributes": [
{
"start": 10,
"end": 33,
"end": 29,
"type": "Attribute",
"name": "readonly",
"value": [
{
"start": 20,
"end": 32,
"start": 19,
"end": 29,
"type": "MustacheTag",
"expression": {
"type": "Identifier",
"start": 22,
"end": 30,
"start": 20,
"end": 28,
"name": "readonly"
}
}
Expand Down

This file was deleted.

2 changes: 1 addition & 1 deletion test/parser/samples/attribute-dynamic-reserved/input.html
Original file line number Diff line number Diff line change
@@ -1 +1 @@
<div class='{{class}}'></div>
<div class={class}></div>
40 changes: 0 additions & 40 deletions test/parser/samples/attribute-dynamic-reserved/output-v2.json

This file was deleted.

Loading