forked from bitwit/strider-template
-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathworker.js
79 lines (72 loc) · 2.64 KB
/
worker.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
'use strict';
const debug = require('debug')('strider-template:worker');
/* Functions for demonstration purposes only */
function checkSomething(context, callback) {
//Do something here, then call back
callback(true);
}
function doThings(callback) {
callback(null);
}
module.exports = {
// Initialize the plugin for a job
// config: the config for this job, made by extending the DB config
// with any flat-file config
// job: see strider-runner-core for a description of that object
// context: currently only defines "dataDir"
// cb(err, initializedPlugin)
init: function (config, job, context, cb) {
return cb(null, {
// any extra env variables. Will be available during all phases
env: {},
// Listen for events on the internal job emitter.
// Look at strider-runner-core for an
// enumeration of the events. Emit plugin.[pluginid].myevent to
// communicate things up to the browser or to the webapp.
listen: function (emitter, context) {
debug(context);
emitter.on('job.status.phase.done', function (id, data) {
const phase = data.phase;
debug(`the ${phase} phase has completed`);
return true;
});
},
// For each phase that you want to deal with, provide either a
// shell command [string] or [Object] (as demo'd below)
// or a fn(context, done(err, didrun))
//string style
environment: `echo "${config.template.environment}"`,
//object style
prepare: {
command: 'echo',
args: [`"${config.template.prepare}"`]
},
//function style (calling done is a MUST)
test: function (context, done) {
//this will show up in the terminal log as 'info'
debug(config.template.test);
//demonstration of how to perform async tasks, finishing with a call to done()
checkSomething(context, function (shouldDoThings) {
if (!shouldDoThings) {
// Send `false` to indicate that we didn't actually run
// anything. This is so we can warn users when no plugins
// actually do anything during a test run, and avoid false
// positives.
return done(null, false);
}
doThings(function (err) {
done(err, true);
});
});
},
deploy: `echo "${config.template.deploy}"`,
cleanup: `echo "${config.template.cleanup}"`
});
},
// this is only used if there is _no_ plugin configuration for a
// project. See gumshoe for documentation on detection rules.
autodetect: {
filename: 'package.json',
exists: true
}
};