Skip to content

Commit 17e31df

Browse files
authored
Merge pull request #253 from sveltejs/universal-tests
[WIP] run tests with SSR compiler, where possible
2 parents c1187d2 + 0979758 commit 17e31df

File tree

21 files changed

+110
-40
lines changed

21 files changed

+110
-40
lines changed
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,5 @@
11
export default {
22
enter ( generator ) {
3-
generator.append( `\${options.yield()}` );
3+
generator.append( `\${options && options.yield ? options.yield() : ''}` );
44
}
55
};

test/generate.js

+2-25
Original file line numberDiff line numberDiff line change
@@ -4,7 +4,7 @@ import * as path from 'path';
44
import * as fs from 'fs';
55
import * as acorn from 'acorn';
66

7-
import { svelte, env, setupHtmlEqual } from './helpers.js';
7+
import { addLineNumbers, loadConfig, svelte, env, setupHtmlEqual } from './helpers.js';
88

99
let showCompiledCode = false;
1010
let compileOptions = null;
@@ -18,36 +18,13 @@ require.extensions[ '.html' ] = function ( module, filename ) {
1818
return module._compile( code, filename );
1919
};
2020

21-
function addLineNumbers ( code ) {
22-
return code.split( '\n' ).map( ( line, i ) => {
23-
i = String( i + 1 );
24-
while ( i.length < 3 ) i = ` ${i}`;
25-
26-
return `${i}: ${line.replace( /^\t+/, match => match.split( '\t' ).join( ' ' ) )}`;
27-
}).join( '\n' );
28-
}
29-
30-
function loadConfig ( dir ) {
31-
try {
32-
const resolved = require.resolve( `./generator/${dir}/_config.js` );
33-
delete require.cache[ resolved ];
34-
return require( resolved ).default;
35-
} catch ( err ) {
36-
if ( err.code === 'E_NOT_FOUND' ) {
37-
return {};
38-
}
39-
40-
throw err;
41-
}
42-
}
43-
4421
describe( 'generate', () => {
4522
before( setupHtmlEqual );
4623

4724
function runTest ( dir, shared ) {
4825
if ( dir[0] === '.' ) return;
4926

50-
const config = loadConfig( dir );
27+
const config = loadConfig( `./generator/${dir}/_config.js` );
5128

5229
if ( config.solo && process.env.CI ) {
5330
throw new Error( 'Forgot to remove `solo: true` from test' );

test/generator/component-binding-nested/_config.js

+2
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,6 @@
11
export default {
2+
'skip-ssr': true, // TODO delete this line, once binding works
3+
24
data: {
35
x: 'initial'
46
},

test/generator/component-binding/_config.js

+2
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,6 @@
11
export default {
2+
'skip-ssr': true, // TODO delete this line, once binding works
3+
24
html: `
35
<button>+1</button>
46
<p>count: 0</p>
+2-2
Original file line numberDiff line numberDiff line change
@@ -1,3 +1,3 @@
11
export default {
2-
html: '<p>Hello</p>'
3-
}
2+
html: '<p>Hello</p>'
3+
};
+12-11
Original file line numberDiff line numberDiff line change
@@ -1,15 +1,16 @@
11
<p>
2-
Hello
3-
{{#if test}}
4-
{{yield}}
5-
{{/if}}
2+
Hello
3+
{{#if test}}
4+
{{yield}}
5+
{{/if}}
66
</p>
7+
78
<script>
8-
export default {
9-
data(){
10-
return {
11-
test: true
12-
}
13-
}
14-
}
9+
export default {
10+
data () {
11+
return {
12+
test: true
13+
};
14+
}
15+
};
1516
</script>

test/generator/onrender-chain/_config.js

+2
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,6 @@
11
export default {
2+
'skip-ssr': true,
3+
24
html: `
35
<span>3</span><span>2</span><span>1</span>
46
`,
Original file line numberDiff line numberDiff line change
@@ -1,3 +1,5 @@
11
export default {
2+
'skip-ssr': true, // uses onrender
3+
24
html: `<div><p>true</p>\n<p>true</p></div>`
35
};

test/generator/onrender-fires-when-ready/_config.js

+2
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,6 @@
11
export default {
2+
'skip-ssr': true, // uses onrender
3+
24
html: `<div><p>true</p></div>`,
35

46
test ( assert, component, target ) {

test/generator/raw-mustaches/_config.js

+4
Original file line numberDiff line numberDiff line change
@@ -1,8 +1,12 @@
11
const ns = '<noscript></noscript>';
2+
23
export default {
4+
'skip-ssr': true,
5+
36
data: {
47
raw: '<span><em>raw html!!!\\o/</span></em>'
58
},
9+
610
html: `before${ns}<span><em>raw html!!!\\o/</span></em>${ns}after`,
711

812
test ( assert, component, target ) {

test/generator/set-in-observe/_config.js

+2
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,6 @@
11
export default {
2+
'skip-ssr': true, // uses onrender
3+
24
html: `
35
<p>1</p>
46
<p>2</p>
Original file line numberDiff line numberDiff line change
@@ -1,3 +1,5 @@
11
export default {
2+
'skip-ssr': true, // uses onrender
3+
24
html: '<p>2</p>'
35
};

test/generator/svg-xmlns/_config.js

+2
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,6 @@
11
export default {
2+
'skip-ssr': true,
3+
24
data: {
35
x: 0,
46
y: 0,

test/helpers.js

+23
Original file line numberDiff line numberDiff line change
@@ -114,3 +114,26 @@ export function setupHtmlEqual () {
114114
};
115115
});
116116
}
117+
118+
export function loadConfig ( file ) {
119+
try {
120+
const resolved = require.resolve( file );
121+
delete require.cache[ resolved ];
122+
return require( resolved ).default;
123+
} catch ( err ) {
124+
if ( err.code === 'E_NOT_FOUND' ) {
125+
return {};
126+
}
127+
128+
throw err;
129+
}
130+
}
131+
132+
export function addLineNumbers ( code ) {
133+
return code.split( '\n' ).map( ( line, i ) => {
134+
i = String( i + 1 );
135+
while ( i.length < 3 ) i = ` ${i}`;
136+
137+
return `${i}: ${line.replace( /^\t+/, match => match.split( '\t' ).join( ' ' ) )}`;
138+
}).join( '\n' );
139+
}
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
before<span><em>raw html!!!\o/</span></em>after
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
before<span><em>raw html!!!\o/</span></em>after
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,3 @@
1+
{
2+
"raw": "<span><em>raw html!!!\\o/</span></em>"
3+
}
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
before{{{raw}}}after

test/ssr.js

+44-1
Original file line numberDiff line numberDiff line change
@@ -1,7 +1,7 @@
11
import assert from 'assert';
22
import * as fs from 'fs';
33

4-
import { exists, setupHtmlEqual, tryToLoadJson } from './helpers.js';
4+
import { addLineNumbers, exists, loadConfig, setupHtmlEqual, svelte, tryToLoadJson } from './helpers.js';
55

66
function tryToReadFile ( file ) {
77
try {
@@ -47,4 +47,47 @@ describe( 'ssr', () => {
4747
assert.equal( css.replace( /^\s+/gm, '' ), expectedCss.replace( /^\s+/gm, '' ) );
4848
});
4949
});
50+
51+
// duplicate client-side tests, as far as possible
52+
fs.readdirSync( 'test/generator' ).forEach( dir => {
53+
if ( dir[0] === '.' ) return;
54+
55+
const config = loadConfig( `./generator/${dir}/_config.js` );
56+
57+
if ( config.solo && process.env.CI ) {
58+
throw new Error( 'Forgot to remove `solo: true` from test' );
59+
}
60+
61+
if ( config['skip-ssr'] ) return;
62+
63+
( config.skip ? it.skip : config.solo ? it.only : it )( dir, () => {
64+
let compiled;
65+
66+
try {
67+
const source = fs.readFileSync( `test/generator/${dir}/main.html`, 'utf-8' );
68+
compiled = svelte.compile( source, { generate: 'ssr' });
69+
} catch ( err ) {
70+
if ( config.compileError ) {
71+
config.compileError( err );
72+
return;
73+
} else {
74+
throw err;
75+
}
76+
}
77+
78+
const component = require( `./generator/${dir}/main.html` );
79+
let html;
80+
81+
try {
82+
html = component.render( config.data );
83+
84+
if ( config.html ) {
85+
assert.htmlEqual( html, config.html );
86+
}
87+
} catch ( err ) {
88+
console.log( addLineNumbers( compiled.code ) ); // eslint-disable-line no-console
89+
throw err;
90+
}
91+
});
92+
});
5093
});

0 commit comments

Comments
 (0)