-
Notifications
You must be signed in to change notification settings - Fork 28
/
test.js
129 lines (111 loc) · 3.95 KB
/
test.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
var compiler = require('./compiler')
function compile2 (config, done, successCallback) {
compiler.compile(config, function (error, stats) {
if (error) {
fail(error)
done()
} else {
successCallback(stats)
}
})
}
function expectInOutput (str) {
expect(compiler.readOutput()).toEqual(expect.stringContaining(str))
}
test('loads a simple file', function (done) {
compile2({ file: 'simple.js.erb' }, done, function (stats) {
expect(stats.compilation.errors).toEqual([])
expectInOutput("var helloWorld = 'Hello World'")
done()
})
})
test('loads with erb', function (done) {
compile2({ file: 'engine.js.erb', engine: 'erb' }, done, function (stats) {
expect(stats.compilation.errors).toEqual([])
expectInOutput("var engine = 'erb'")
done()
})
})
test('loads with erubis', function (done) {
compile2({ file: 'engine.js.erb', engine: 'erubis' }, done, function (stats) {
expect(stats.compilation.errors).toEqual([])
expectInOutput("var engine = 'erubis'")
done()
})
})
test('loads with erubi', function (done) {
compile2({ file: 'engine.js.erb', engine: 'erubi' }, done, function (stats) {
expect(stats.compilation.errors).toEqual([])
expectInOutput("var engine = 'erubi'")
done()
})
})
test('loads through a Rails-like runner', function (done) {
compile2({ file: 'runner.js.erb', runner: './test/runner' }, done, function (stats) {
expect(stats.compilation.errors).toEqual([])
expectInOutput("var env = 'test'")
done()
})
})
test('loads with env specified in option', function (done) {
compile2({ file: 'runner.js.erb', runner: './test/runner', env: { ENV: 'custom' } }, done, function (stats) {
expect(stats.compilation.errors).toEqual([])
expectInOutput("var env = 'custom'")
done()
})
})
test('does not error with large files', function (done) {
compile2({ file: 'giant.js.erb' }, done, function (stats) {
expect(stats.compilation.errors).toEqual([])
expect(compiler.readOutput()).toMatch(/var bigData = 'a{204740}'/)
done()
})
})
test('times out with error (timeoutMs: 1000)', function (done) {
compile2({ file: 'sleep.js.erb', timeoutMs: 1000 }, done, function (stats) {
expect(stats.compilation.errors.length).toEqual(1)
expect(stats.compilation.errors[0].message).toMatch(
'rails-erb-loader took longer than the specified 1000ms timeout'
)
done()
})
})
test('times out with error (DEPRECATED timeout: 1)', function (done) {
compile2({ file: 'sleep.js.erb', timeout: 1, timeoutMs: null }, done, function (stats) {
expect(stats.compilation.errors[0].message).toMatch(
'rails-erb-loader took longer than the specified 1000ms timeout'
)
done()
})
})
test('fails when both timeout and timeoutMs are set', function (done) {
// TODO this spec is causing jest not to clean up properly, we get a console warning
// 'Jest did not exit one second after the test run has completed.'
compile2({ file: 'sleep.js.erb', timeout: 1, timeoutMs: 1000 }, done, function (stats) {
expect(stats.compilation.errors[0].message).toMatch(
'TypeError: Both options `timeout` and `timeoutMs` were set'
)
done()
})
})
test.skip('loads single file dependencies in dev', function (done) {
var prevEnv = process.env.NODE_ENV
compile2({ file: 'dependencies.js.erb' }, done, function (stats) {
process.env.NODE_ENV = 'development'
expect(stats.compilation.errors).toEqual([])
// TODO: Check that dependencies/dependency.rb and dependencies/dependency/version.rb
// are being watched
done()
})
process.env.NODE_ENV = prevEnv
})
test.skip('loads directory dependencies in dev', function (done) {
var prevEnv = process.env.NODE_ENV
compile2({ file: 'dependencies-all.js.erb' }, done, function (stats) {
process.env.NODE_ENV = 'development'
expect(stats.compilation.errors).toEqual([])
// TODO: Check that the whole dependencies tree is being watched
done()
})
process.env.NODE_ENV = prevEnv
})