This repository was archived by the owner on May 1, 2020. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 311
/
Copy pathworker-process.ts
72 lines (56 loc) · 1.86 KB
/
worker-process.ts
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
import { BuildError } from './util/errors';
import { buildErrorToJson } from './util/helpers';
import { Logger } from './logger/logger';
import { WorkerMessage } from './util/interfaces';
process.on('message', (msg: WorkerMessage) => {
try {
const modulePath = `./${msg.taskModule}`;
const taskWorker = require(modulePath)[msg.taskWorker];
taskWorker(msg.context, msg.workerConfig)
.then((val: any) => {
taskResolve(msg.taskModule, msg.taskWorker, val);
}, (val: any) => {
taskReject(msg.taskModule, msg.taskWorker, val);
})
.catch((err: any) => {
taskError(msg.taskModule, msg.taskWorker, err);
});
} catch (e) {
taskError(msg.taskModule, msg.taskWorker, e);
process.exit(1);
}
});
function taskResolve(taskModule: string, taskWorker: string, val: any) {
const msg: WorkerMessage = {
taskModule: taskModule,
taskWorker: taskWorker,
resolve: val,
pid: process.pid
};
Logger.debug(`worker resolve, taskModule: ${msg.taskModule}, pid: ${msg.pid}`);
process.send(msg);
}
function taskReject(taskModule: string, taskWorker: string, error: Error) {
const buildError = new BuildError(error.message);
const json = buildErrorToJson(buildError);
const msg: WorkerMessage = {
taskModule: taskModule,
taskWorker: taskWorker,
reject: json,
pid: process.pid
};
Logger.debug(`worker reject, taskModule: ${msg.taskModule}, pid: ${msg.pid}`);
process.send(msg);
}
function taskError(taskModule: string, taskWorker: string, error: Error) {
const buildError = new BuildError(error.message);
const json = buildErrorToJson(buildError);
const msg: WorkerMessage = {
taskModule: taskModule,
taskWorker: taskWorker,
error: json,
pid: process.pid
};
Logger.debug(`worker error, taskModule: ${msg.taskModule}, pid: ${msg.pid}`);
process.send(msg);
}