1 | ;
|
2 | var task_resolve_1 = require("./task.resolve");
|
3 | var task_return_values_1 = require("./task.return.values");
|
4 | var Rx = require("rx");
|
5 | var debug = require("debug")("cb:task.runner");
|
6 | var _ = require("../lodash.custom");
|
7 | var once = require("once");
|
8 | var domain = require("domain");
|
9 | var TaskReportType;
|
10 | (function (TaskReportType) {
|
11 | TaskReportType[TaskReportType["start"] = "start"] = "start";
|
12 | TaskReportType[TaskReportType["end"] = "end"] = "end";
|
13 | TaskReportType[TaskReportType["error"] = "error"] = "error";
|
14 | })(TaskReportType = exports.TaskReportType || (exports.TaskReportType = {}));
|
15 | var TaskSkipReasons;
|
16 | (function (TaskSkipReasons) {
|
17 | TaskSkipReasons[TaskSkipReasons["SkipFlag"] = "SkipFlag"] = "SkipFlag";
|
18 | TaskSkipReasons[TaskSkipReasons["IfChanged"] = "IfChanged"] = "IfChanged";
|
19 | })(TaskSkipReasons = exports.TaskSkipReasons || (exports.TaskSkipReasons = {}));
|
20 | /**
|
21 | * This creates a wrapper around the actual function that will be run.
|
22 | * This done to allow the before/after reporting to work as expected for consumers
|
23 | */
|
24 | function time(scheduler) {
|
25 | return scheduler ? scheduler.now() : new Date().getTime();
|
26 | }
|
27 | exports.time = time;
|
28 | function createObservableFromSequenceItem(item, trigger, ctx) {
|
29 | var taskTrigger = _.assign({}, trigger, ctx.toJS());
|
30 | return Rx.Observable.create(function (observer) {
|
31 | var startTime = time(taskTrigger.config.scheduler);
|
32 | /**
|
33 | * Complete immediately if this item was marked
|
34 | * as 'skipped'
|
35 | */
|
36 | if (!taskTrigger.config.force && item.task.skipped) {
|
37 | var additionalStats = {
|
38 | skipped: true,
|
39 | skippedReason: TaskSkipReasons.SkipFlag
|
40 | };
|
41 | var stats_1 = getStartStats(startTime, additionalStats);
|
42 | observer.onNext(getTaskReport(TaskReportType.start, item, stats_1));
|
43 | observer.onNext(getTaskReport(TaskReportType.end, item, getEndStats(stats_1, startTime, additionalStats)));
|
44 | observer.onCompleted();
|
45 | return;
|
46 | }
|
47 | /**
|
48 | * Complete immediately if this item was marked
|
49 | * with an 'ifChanged' predicate
|
50 | */
|
51 | if (!taskTrigger.config.force && item.task.ifChanged.length && ctx.hasIn(["ifChanged"])) {
|
52 | var hasChanges = ctx
|
53 | .get("ifChanged")
|
54 | .filter(function (x) {
|
55 | return item.task.ifChanged.indexOf(x.get("userInput")) !== -1;
|
56 | })
|
57 | .some(function (x) { return x.get("changed"); });
|
58 | if (!hasChanges) {
|
59 | var additionalStats = {
|
60 | skipped: true,
|
61 | skippedReason: TaskSkipReasons.IfChanged
|
62 | };
|
63 | var stats_2 = getStartStats(startTime, additionalStats);
|
64 | observer.onNext(getTaskReport(TaskReportType.start, item, stats_2));
|
65 | observer.onNext(getTaskReport(TaskReportType.end, item, getEndStats(stats_2, startTime, additionalStats)));
|
66 | observer.onCompleted();
|
67 | return;
|
68 | }
|
69 | }
|
70 | /**
|
71 | * Timestamp when this task starts
|
72 | * @type {TaskStats}
|
73 | */
|
74 | var stats = getStartStats(startTime, { skipped: false });
|
75 | debug("> seqUID " + item.seqUID + " started");
|
76 | /**
|
77 | * Task started
|
78 | */
|
79 | observer.onNext(getTaskReport(TaskReportType.start, item, stats));
|
80 | /**
|
81 | * Exit after 1 second if we're in a 'dry run'
|
82 | */
|
83 | if (taskTrigger.config.dryRun) {
|
84 | return Rx.Observable
|
85 | .just("dryRun")
|
86 | .delay(taskTrigger.config.dryRunDuration, taskTrigger.config.scheduler)
|
87 | .do(function (_) {
|
88 | observer.onNext(getTaskReport(TaskReportType.end, item, getEndStats(stats, time(taskTrigger.config.scheduler))));
|
89 | observer.onCompleted();
|
90 | }).subscribe();
|
91 | }
|
92 | if (item.task.type === task_resolve_1.TaskTypes.InlineFunction
|
93 | || item.task.type === task_resolve_1.TaskTypes.ExternalTask
|
94 | || item.task.type === task_resolve_1.TaskTypes.Adaptor) {
|
95 | var argCount = item.factory.length;
|
96 | var cb_1 = once(function (err) {
|
97 | if (err) {
|
98 | observer.onError(err);
|
99 | return;
|
100 | }
|
101 | observer.onNext(getTaskReport(TaskReportType.end, item, getEndStats(stats, time(taskTrigger.config.scheduler))));
|
102 | observer.onCompleted();
|
103 | });
|
104 | var d_1 = domain.create();
|
105 | d_1.once("error", function (err) {
|
106 | cb_1(err);
|
107 | });
|
108 | var domainBoundFn = d_1.bind(item.factory.bind(null, item.options, taskTrigger));
|
109 | var done = function (err) {
|
110 | d_1.removeListener("error", function (err) {
|
111 | cb_1(err);
|
112 | });
|
113 | d_1.exit();
|
114 | return cb_1.apply(null, arguments);
|
115 | };
|
116 | var result = domainBoundFn(done);
|
117 | if (result) {
|
118 | var returns = task_return_values_1.default(result, done);
|
119 | /**
|
120 | * If the return value does not need to be consumed,
|
121 | * but it is IS a function, assume it's the tear-down logic
|
122 | * for this task - which also means it MUST signify completion
|
123 | * via the callback
|
124 | */
|
125 | if (!returns && typeof result === "function") {
|
126 | if (argCount >= 3) {
|
127 | return result;
|
128 | }
|
129 | else {
|
130 | done(new Error("You returned tear-down logic, but you never asked for the completion callback"));
|
131 | return;
|
132 | }
|
133 | }
|
134 | }
|
135 | else {
|
136 | /**
|
137 | * Assume sync function if nothing returned
|
138 | * and 3rd argument was not asked for
|
139 | */
|
140 | if (argCount < 3) {
|
141 | done();
|
142 | return;
|
143 | }
|
144 | }
|
145 | }
|
146 | }).catch(function (error) {
|
147 | /**
|
148 | * **--**--MAGIC--**--**
|
149 | * If a task throws an error of any kind, we want that error to propagate as normal,
|
150 | * but we want tp prepend an error report so that the error report can be observed
|
151 | * before the sequence ends.
|
152 | */
|
153 | return Rx.Observable.concat(Rx.Observable.just(getTaskErrorReport(item, getErrorStats(error, time(taskTrigger.config.scheduler)))), Rx.Observable.throw(error));
|
154 | });
|
155 | }
|
156 | exports.createObservableFromSequenceItem = createObservableFromSequenceItem;
|
157 | /**
|
158 | * Factory for TaskReports
|
159 | */
|
160 | function getTaskReport(type, item, stats) {
|
161 | return { type: type, item: item, stats: stats };
|
162 | }
|
163 | /**
|
164 | * Create a new stats object with startTime
|
165 | */
|
166 | function getStartStats(startTime, additional) {
|
167 | return _.assign({}, additional, {
|
168 | startTime: startTime,
|
169 | started: true,
|
170 | endTime: 0,
|
171 | duration: 0,
|
172 | completed: false,
|
173 | errors: []
|
174 | });
|
175 | }
|
176 | exports.getStartStats = getStartStats;
|
177 | /**
|
178 | * Create a new stats object with completed/duration flags etc
|
179 | */
|
180 | function getEndStats(stats, endTime, additional) {
|
181 | return _.assign({}, stats, additional, {
|
182 | endTime: endTime,
|
183 | duration: endTime - stats.startTime,
|
184 | completed: true
|
185 | });
|
186 | }
|
187 | /**
|
188 | * Factory for TaskReports that errored
|
189 | */
|
190 | function getTaskErrorReport(item, stats) {
|
191 | return { type: TaskReportType.error, item: item, stats: stats };
|
192 | }
|
193 | /**
|
194 | * Get basic stats for a task error
|
195 | */
|
196 | function getErrorStats(error, endTime) {
|
197 | if (error._cbError) {
|
198 | return {
|
199 | endTime: endTime,
|
200 | completed: false,
|
201 | errors: [error],
|
202 | cbError: true,
|
203 | cbExitCode: error._cbExitCode
|
204 | };
|
205 | }
|
206 | return {
|
207 | endTime: endTime,
|
208 | completed: false,
|
209 | errors: [error]
|
210 | };
|
211 | }
|
212 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"task.runner.js","sourceRoot":"","sources":["../src/task.runner.ts"],"names":[],"mappings":"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"} |
\ | No newline at end of file |