-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathrunner.js
62 lines (56 loc) · 1.82 KB
/
runner.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
import childProcess from 'child_process'
import perfHooks from 'perf_hooks'
import os from 'os'
import batchPromise from './batch-promise.js'
import { Pass, Fail, File, Crash, Completion } from './report.js'
export default function run (files, report = () => {}) {
const timestamp = perfHooks.performance.now()
let passed = 0
let failed = 0
let crashed = 0
let pending = 0
return batchPromise(files, os.cpus().length, file => {
return new Promise((resolve, reject) => {
let running = new Map
const stderr = []
const forked = childProcess.fork(file, {
stdio: ['ignore', 'inherit', 'pipe', 'ipc']
})
forked.stderr.once('error', reject)
forked.once('error', reject)
forked.stderr.on('data', data => {
stderr.push(data)
})
forked.on('message', ({ id, status, title, location, message }) => {
if (status === 'pending') {
running.set(id, title)
pending++
} else if (status === 'passed') {
running.delete(id)
pending--
passed++
report(Pass(timestamp, passed, failed, pending, { file, title, running }))
} else {
running.delete(id)
pending--
failed++
report(Fail(timestamp, passed, failed, pending, { file, title, running, location, message }))
}
})
forked.on('close', code => {
if (code === 0) {
report(File(timestamp, passed, failed, pending, { file, running, stderr }))
} else {
pending -= running.size
crashed++
report(Crash(timestamp, passed, failed, pending, { file, code, stderr }))
}
resolve()
})
})
})
.then(() => {
report(Completion(timestamp, passed, failed, pending))
return { passed, failed, crashed, pending }
})
}