redibox-hook-job
Advanced tools
Comparing version 1.0.1 to 1.0.2
@@ -50,3 +50,22 @@ 'use strict'; | ||
this.subscriptions = []; | ||
if (isNew) return this.save(); | ||
if (isNew) { | ||
// this Proxy allows chaining methods while still keeping the | ||
// save() promise valid | ||
this.proxy = new Proxy(this, { | ||
get(target, name) { | ||
if (name in target) { | ||
return target[name]; | ||
} | ||
// haxxors | ||
if (name === 'then') { | ||
target.promise = target.save(); | ||
return target.promise.then.bind(target.promise); | ||
} | ||
return undefined; | ||
} | ||
}); | ||
return this.proxy; | ||
} | ||
return this; | ||
@@ -131,2 +150,6 @@ } | ||
if (this.options.notifySuccess || this.options.notifyFailure) { | ||
if (!this.core.pubsub.options.subscriber) { | ||
return _bluebird2.default.reject(new Error('Cannot subscribe to job events when RediBox.pubsub \'subscriber\' config is set to disabled.')); | ||
} | ||
return this.core.pubsub.subscribeOnceOf(this.subscriptions, message => { | ||
@@ -173,3 +196,3 @@ // on message received | ||
this.options.retries = n - 1; | ||
return this; | ||
return this.proxy; | ||
} | ||
@@ -186,3 +209,3 @@ | ||
if (!this.onFailureCallback) this.onFailureCallback = _redibox.noop; | ||
return this; | ||
return this.proxy; | ||
} | ||
@@ -199,8 +222,13 @@ | ||
if (!this.onSuccessCallback) this.onSuccessCallback = _redibox.noop; | ||
return this; | ||
return this.proxy; | ||
} | ||
/** | ||
* | ||
* @param bool | ||
* @returns {Job} | ||
*/ | ||
unique(bool) { | ||
this.options.unique = bool; | ||
return this; | ||
return this.proxy; | ||
} | ||
@@ -215,3 +243,3 @@ | ||
this.options.timeout = ms; | ||
return this; | ||
return this.proxy; | ||
} | ||
@@ -309,2 +337,2 @@ | ||
exports.default = Job; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/job.js"],"names":[],"mappings":"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","file":"job.js","sourcesContent":["/**\n *\n * The MIT License (MIT)\n *\n * Copyright (c) 2015 Salakar\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in all\n * copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n * SOFTWARE.\n *\n */\n\nimport cuid from 'cuid';\nimport Promise from 'bluebird';\nimport { noop, sha1sum, tryJSONStringify, tryJSONParse } from 'redibox';\n\n/**\n * @class Job\n */\nclass Job {\n\n  /**\n   *\n   * @param core\n   * @param id\n   * @param data\n   * @param options\n   * @param queueName\n   * @param isNew\n   * @returns {*}\n   */\n  constructor(core, id, data = {}, options = {\n    unique: false,\n    timeout: 60000, // 1 minute default timeout\n  }, queueName, isNew) {\n    this.id = id;\n    this.core = core;\n    this.data = data;\n    this.status = 'created';\n    this.options = options;\n    this.queueName = queueName;\n    this.subscriptions = [];\n    if (isNew) return this.save();\n    return this;\n  }\n\n  /**\n   * Query redis for the specified job id and converts it to a new instance of Job.\n   * @static\n   * @param queue\n   * @param id\n   */\n  static fromId(queue, id) {\n    return queue.client.hget(queue.toKey('jobs'), id).then((data) =>\n      Job.fromData(queue, id, data)\n    );\n  }\n\n  /**\n   * Converts a JSON string of a job's data to a new instance of Job\n   * @static\n   * @param queue\n   * @param id\n   * @param data\n   * @returns {Job | null}\n   */\n  static fromData(queue, id, data) {\n    const obj = tryJSONParse(data);\n    if (!obj) return null;\n    const job = new Job(queue.core, id, obj.data, obj.options, queue.name);\n    job.status = obj.data.status;\n    return job;\n  }\n\n  /**\n   * Convert this Job instance to a json string.\n   */\n  toData() {\n    return tryJSONStringify({\n      id: this.id,\n      data: this.data,\n      status: this.status,\n      options: this.options,\n    });\n  }\n\n  /**\n   * Internal save that pushes to redis.\n   * @private\n   */\n  _save() {\n    this.core.log.verbose(`Saving new job ${this.id} for ${this.queueName}`);\n    return this.core.client.addjob(\n      this._toQueueKey('jobs'),\n      this._toQueueKey('waiting'),\n      this._toQueueKey('id'),\n      this.toData(),\n      !!this.options.unique,\n      this.id).then((id) => {\n        if (this.options.unique && id === 0) {\n          this.status = 'duplicate';\n          return Promise.reject(new Error(`ERR_DUPLICATE: Job ${this.id} already exists, save has been aborted.`));\n        }\n        this.core.log.verbose(`Saved job for ${this.queueName}`);\n        this.id = id;\n        this.status = 'saved';\n        // this.queue.jobs[id] = this;\n        return Promise.resolve(this);\n      }\n    );\n  }\n\n  /**\n   * Save this instance of Job to redis. Any active queues will pick it up\n   * immediately for processing.\n   * @returns {*}\n   */\n  save() {\n    this.id = `${this.queueName}-${(this.options.unique ? sha1sum(this.data) : cuid())}`;\n\n    if (this.options.notifySuccess) {\n      this.options.notifySuccess = `job:${this.id}:success`;\n      this.subscriptions.push(`job:${this.id}:success`);\n    }\n\n    if (this.options.notifyFailure) {\n      this.options.notifyFailure = `job:${this.id}:failure`;\n      this.subscriptions.push(`job:${this.id}:failure`);\n    }\n\n    if (this.options.notifySuccess || this.options.notifyFailure) {\n      return this.core.pubsub.subscribeOnceOf(\n        this.subscriptions,\n        (message) => { // on message received\n          const channel = message.channel;\n\n          // remove the pubsub data\n          if (message.data) {\n            message = message.data;\n          }\n\n          // if there's an error the assume failed.\n          if (message.error) {\n            return this.onFailureCallback(message);\n          }\n\n          // is it from the success channel.\n          if (this.subscriptions[0] === channel) {\n            return this.onSuccessCallback(message);\n          }\n\n          return this.onFailureCallback(message);\n        },\n        this.options.timeout + 2000\n      ).then(() =>  // subscribed callback\n        this._save()\n      ).catch(error =>\n        this.onFailureCallback({\n          type: 'job',\n          error: new Error('Error while subscribing to job events, however this job will still be queued - ' +\n            'you may be unable to receive onComplete / onFailure events for this job.'),\n          error_actual: error,\n        })\n      );\n    }\n\n    return this._save();\n  }\n\n  /**\n   * Set the number of times this job will retry on failure\n   * @param n\n   * @returns {Job}\n   */\n  retries(n) {\n    if (n < 0) {\n      throw Error('Retries cannot be negative');\n    }\n    this.options.retries = n - 1;\n    return this;\n  }\n\n  /**\n   * Set the onSuccess callback and notify option\n   * @param notify\n   * @returns {Job}\n   */\n  onSuccess(notify) {\n    this.options.notifySuccess = true;\n    this.onSuccessCallback = notify;\n    if (!this.onFailureCallback) this.onFailureCallback = noop;\n    return this;\n  }\n\n  /**\n   * Set the onFailure callback and notify option\n   * @param notify\n   * @returns {Job}\n   */\n  onFailure(notify) {\n    this.options.notifyFailure = true;\n    this.onFailureCallback = notify;\n    if (!this.onSuccessCallback) this.onSuccessCallback = noop;\n    return this;\n  }\n\n  unique(bool) {\n    this.options.unique = bool;\n    return this;\n  }\n\n  /**\n   * Set how long this job can run before it times out.\n   * @param ms\n   * @returns {Job}\n   */\n  timeout(ms) {\n    this.options.timeout = ms;\n    return this;\n  }\n\n  /**\n   *\n   * @returns {Job.initialJob|*}\n   */\n  initialJob() {\n    return this._internalData.initialJob;\n  }\n\n  /**\n   *\n   * @returns {Job.initialQueue|*}\n   */\n  initialQueue() {\n    return this._internalData.initialQueue;\n  }\n\n  /**\n   * Remove this job from all sets.\n   * @param cb\n   */\n  remove(cb = noop) {\n    this.core.client.removejob(\n      this._toQueueKey('succeeded'), this._toQueueKey('failed'), this._toQueueKey('waiting'),\n      this._toQueueKey('active'), this._toQueueKey('stalling'), this._toQueueKey('jobs'),\n      this.id, cb);\n  }\n\n  /**\n   * Re-save this job for the purpose of retrying it.\n   * @param cb\n   */\n  retry(cb = noop) {\n    this.core.client.multi()\n        .srem(this._toQueueKey('failed'), this.id)\n        .lpush(this._toQueueKey('waiting'), this.id)\n        .exec(cb);\n  }\n\n  /**\n   * Callbacks true of false if this job exists in the specified set.\n   * @param set\n   * @param cb\n   */\n  isInSet(set, cb = noop) {\n    this.core.client.sismember(this._toQueueKey(set), this.id, (err, result) => {\n      if (err) return cb(err);\n      return cb(null, result === 1);\n    });\n  }\n\n  /**\n   * Generates a queue prefixed key based on the provided string.\n   * @param str\n   * @returns {string}\n   * @private\n   */\n  _toQueueKey(str) {\n    if (this.core.cluster.isCluster()) {\n      return `${this.core.hooks.job.options.keyPrefix}:{${this.queueName}}:${str}`;\n    }\n    return `${this.core.hooks.job.options.keyPrefix}:${this.queueName}:${str}`;\n  }\n\n}\n\nexport default Job;\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/job.js"],"names":[],"mappings":"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","file":"job.js","sourcesContent":["/**\n *\n * The MIT License (MIT)\n *\n * Copyright (c) 2015 Salakar\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in all\n * copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n * SOFTWARE.\n *\n */\n\nimport cuid from 'cuid';\nimport Promise from 'bluebird';\nimport { noop, sha1sum, tryJSONStringify, tryJSONParse } from 'redibox';\n\n/**\n * @class Job\n */\nclass Job {\n\n  /**\n   *\n   * @param core\n   * @param id\n   * @param data\n   * @param options\n   * @param queueName\n   * @param isNew\n   * @returns {*}\n   */\n  constructor(core, id, data = {}, options = {\n    unique: false,\n    timeout: 60000, // 1 minute default timeout\n  }, queueName, isNew) {\n    this.id = id;\n    this.core = core;\n    this.data = data;\n    this.status = 'created';\n    this.options = options;\n    this.queueName = queueName;\n    this.subscriptions = [];\n    if (isNew) {\n      // this Proxy allows chaining methods while still keeping the\n      // save() promise valid\n      this.proxy = new Proxy(this, {\n        get(target, name) {\n          if (name in target) {\n            return target[name];\n          }\n\n          // haxxors\n          if (name === 'then') {\n            target.promise = target.save();\n            return target.promise.then.bind(target.promise);\n          }\n\n          return undefined;\n        },\n      });\n      return this.proxy;\n    }\n    return this;\n  }\n\n  /**\n   * Query redis for the specified job id and converts it to a new instance of Job.\n   * @static\n   * @param queue\n   * @param id\n   */\n  static fromId(queue, id) {\n    return queue.client.hget(queue.toKey('jobs'), id).then((data) =>\n      Job.fromData(queue, id, data)\n    );\n  }\n\n  /**\n   * Converts a JSON string of a job's data to a new instance of Job\n   * @static\n   * @param queue\n   * @param id\n   * @param data\n   * @returns {Job | null}\n   */\n  static fromData(queue, id, data) {\n    const obj = tryJSONParse(data);\n    if (!obj) return null;\n    const job = new Job(queue.core, id, obj.data, obj.options, queue.name);\n    job.status = obj.data.status;\n    return job;\n  }\n\n  /**\n   * Convert this Job instance to a json string.\n   */\n  toData() {\n    return tryJSONStringify({\n      id: this.id,\n      data: this.data,\n      status: this.status,\n      options: this.options,\n    });\n  }\n\n  /**\n   * Internal save that pushes to redis.\n   * @private\n   */\n  _save() {\n    this.core.log.verbose(`Saving new job ${this.id} for ${this.queueName}`);\n    return this.core.client.addjob(\n      this._toQueueKey('jobs'),\n      this._toQueueKey('waiting'),\n      this._toQueueKey('id'),\n      this.toData(),\n      !!this.options.unique,\n      this.id).then((id) => {\n        if (this.options.unique && id === 0) {\n          this.status = 'duplicate';\n          return Promise.reject(new Error(`ERR_DUPLICATE: Job ${this.id} already exists, save has been aborted.`));\n        }\n        this.core.log.verbose(`Saved job for ${this.queueName}`);\n        this.id = id;\n        this.status = 'saved';\n        // this.queue.jobs[id] = this;\n        return Promise.resolve(this);\n      }\n    );\n  }\n\n  /**\n   * Save this instance of Job to redis. Any active queues will pick it up\n   * immediately for processing.\n   * @returns {*}\n   */\n  save() {\n    this.id = `${this.queueName}-${(this.options.unique ? sha1sum(this.data) : cuid())}`;\n\n    if (this.options.notifySuccess) {\n      this.options.notifySuccess = `job:${this.id}:success`;\n      this.subscriptions.push(`job:${this.id}:success`);\n    }\n\n    if (this.options.notifyFailure) {\n      this.options.notifyFailure = `job:${this.id}:failure`;\n      this.subscriptions.push(`job:${this.id}:failure`);\n    }\n\n    if (this.options.notifySuccess || this.options.notifyFailure) {\n      if (!this.core.pubsub.options.subscriber) {\n        return Promise.reject(\n          new Error('Cannot subscribe to job events when RediBox.pubsub \\'subscriber\\' config is set to disabled.')\n        );\n      }\n\n      return this.core.pubsub.subscribeOnceOf(this.subscriptions, (message) => { // on message received\n        const channel = message.channel;\n\n        // remove the pubsub data\n        if (message.data) {\n          message = message.data;\n        }\n\n        // if there's an error the assume failed.\n        if (message.error) {\n          return this.onFailureCallback(message);\n        }\n\n        // is it from the success channel.\n        if (this.subscriptions[0] === channel) {\n          return this.onSuccessCallback(message);\n        }\n\n        return this.onFailureCallback(message);\n      }, this.options.timeout + 2000).then(() =>  // subscribed callback\n        this._save()\n      ).catch(error =>\n        this.onFailureCallback({\n          type: 'job',\n          error: new Error('Error while subscribing to job events, however this job will still be queued - ' +\n            'you may be unable to receive onComplete / onFailure events for this job.'),\n          error_actual: error,\n        })\n      );\n    }\n\n    return this._save();\n  }\n\n  /**\n   * Set the number of times this job will retry on failure\n   * @param n\n   * @returns {Job}\n   */\n  retries(n) {\n    if (n < 0) {\n      throw Error('Retries cannot be negative');\n    }\n    this.options.retries = n - 1;\n    return this.proxy;\n  }\n\n  /**\n   * Set the onSuccess callback and notify option\n   * @param notify\n   * @returns {Job}\n   */\n  onSuccess(notify) {\n    this.options.notifySuccess = true;\n    this.onSuccessCallback = notify;\n    if (!this.onFailureCallback) this.onFailureCallback = noop;\n    return this.proxy;\n  }\n\n  /**\n   * Set the onFailure callback and notify option\n   * @param notify\n   * @returns {Job}\n   */\n  onFailure(notify) {\n    this.options.notifyFailure = true;\n    this.onFailureCallback = notify;\n    if (!this.onSuccessCallback) this.onSuccessCallback = noop;\n    return this.proxy;\n  }\n\n  /**\n   *\n   * @param bool\n   * @returns {Job}\n   */\n  unique(bool) {\n    this.options.unique = bool;\n    return this.proxy;\n  }\n\n  /**\n   * Set how long this job can run before it times out.\n   * @param ms\n   * @returns {Job}\n   */\n  timeout(ms) {\n    this.options.timeout = ms;\n    return this.proxy;\n  }\n\n  /**\n   *\n   * @returns {Job.initialJob|*}\n   */\n  initialJob() {\n    return this._internalData.initialJob;\n  }\n\n  /**\n   *\n   * @returns {Job.initialQueue|*}\n   */\n  initialQueue() {\n    return this._internalData.initialQueue;\n  }\n\n  /**\n   * Remove this job from all sets.\n   * @param cb\n   */\n  remove(cb = noop) {\n    this.core.client.removejob(\n      this._toQueueKey('succeeded'), this._toQueueKey('failed'), this._toQueueKey('waiting'),\n      this._toQueueKey('active'), this._toQueueKey('stalling'), this._toQueueKey('jobs'),\n      this.id, cb);\n  }\n\n  /**\n   * Re-save this job for the purpose of retrying it.\n   * @param cb\n   */\n  retry(cb = noop) {\n    this.core.client.multi()\n        .srem(this._toQueueKey('failed'), this.id)\n        .lpush(this._toQueueKey('waiting'), this.id)\n        .exec(cb);\n  }\n\n  /**\n   * Callbacks true of false if this job exists in the specified set.\n   * @param set\n   * @param cb\n   */\n  isInSet(set, cb = noop) {\n    this.core.client.sismember(this._toQueueKey(set), this.id, (err, result) => {\n      if (err) return cb(err);\n      return cb(null, result === 1);\n    });\n  }\n\n  /**\n   * Generates a queue prefixed key based on the provided string.\n   * @param str\n   * @returns {string}\n   * @private\n   */\n  _toQueueKey(str) {\n    if (this.core.cluster.isCluster()) {\n      return `${this.core.hooks.job.options.keyPrefix}:{${this.queueName}}:${str}`;\n    }\n    return `${this.core.hooks.job.options.keyPrefix}:${this.queueName}:${str}`;\n  }\n\n}\n\nexport default Job;\n"]} |
{ | ||
"name": "redibox-hook-job", | ||
"description": "Advanced redibox powered jobs and queues", | ||
"version": "1.0.1", | ||
"version": "1.0.2", | ||
"main": "lib/index.js", | ||
@@ -10,8 +10,4 @@ "author": "Mike Diarmid", | ||
"engines": { | ||
"node": ">=4.3" | ||
"node": ">=6.0" | ||
}, | ||
"redibox": { | ||
"hook": true, | ||
"name": "scheduler" | ||
}, | ||
"keywords": [ | ||
@@ -70,2 +66,3 @@ "redis", | ||
"mocha": "^2.4.5", | ||
"redibox": "^2.0.1", | ||
"sinon": "^1.17.4" | ||
@@ -72,0 +69,0 @@ }, |
125
tests.js
@@ -12,2 +12,7 @@ global.HOOK_NAME = 'job'; | ||
}, | ||
pubsub: { | ||
eventPrefix: 'myEvents', | ||
subscriber: true, | ||
publisher: true, | ||
}, | ||
job: { | ||
@@ -24,2 +29,7 @@ queues: [ | ||
log: { level: 'error' }, | ||
pubsub: { | ||
eventPrefix: 'myEvents', | ||
subscriber: true, | ||
publisher: true, | ||
}, | ||
redis: { | ||
@@ -69,2 +79,6 @@ connectionTimeout: 2000, | ||
const tester = new Promise((resolve) => { | ||
return resolve(); | ||
}); | ||
global.RediBox = new Redibox(config, () => { | ||
@@ -74,105 +88,10 @@ global.Hook = RediBox.hooks[global.HOOK_NAME]; | ||
global.HookCluster = global.RediBoxCluster.hooks[global.HOOK_NAME]; | ||
Hook.create('test2', { | ||
runs: ['fooBar', 'fooBar', 'fooBar', 'fooBar', 'fooBar', 'fooBarEnd'], | ||
data: { | ||
foo: 'bar', | ||
}, | ||
}).then(() => { | ||
}).catch(console.error); | ||
Hook.create('test2', { | ||
runs: ['fooBar', 'fooBar', 'fooBar', 'fooBar', 'fooBar', 'fooBarEnd'], | ||
data: { | ||
foo: 'bar', | ||
}, | ||
}).then(() => { | ||
}).catch(console.error); | ||
Hook.create('test2', { | ||
runs: ['fooBar', 'fooBar', 'fooBar', 'fooBar', 'fooBar', 'fooBarEnd'], | ||
data: { | ||
foo: 'bar', | ||
}, | ||
}).then(() => { | ||
}).catch(console.error); | ||
Hook.create('test2', { | ||
runs: ['fooBar', 'fooBar', 'fooBar', 'fooBar', 'fooBar', 'fooBarEnd'], | ||
data: { | ||
foo: 'bar', | ||
}, | ||
}).then(() => { | ||
}).catch(console.error); | ||
Hook.create('test2', { | ||
runs: ['fooBar', 'fooBar', 'fooBar', 'fooBar', 'fooBar', 'fooBarEnd'], | ||
data: { | ||
foo: 'bar', | ||
}, | ||
}).then(() => { | ||
}).catch(console.error); | ||
Hook.create('test2', { | ||
runs: ['fooBar', 'fooBar', 'fooBar', 'fooBar', 'fooBar', 'fooBarEnd'], | ||
data: { | ||
foo: 'bar', | ||
}, | ||
}).then(() => { | ||
}).catch(console.error); | ||
Hook.create('test2', { | ||
runs: ['fooBar', 'fooBar', 'fooBar', 'fooBar', 'fooBar', 'fooBarEnd'], | ||
data: { | ||
foo: 'bar', | ||
}, | ||
}).then(() => { | ||
}).catch(console.error); | ||
Hook.create('test2', { | ||
runs: ['fooBar', 'fooBar', 'fooBar', 'fooBar', 'fooBar', 'fooBarEnd'], | ||
data: { | ||
foo: 'bar', | ||
}, | ||
}).then(() => { | ||
}).catch(console.error); | ||
Hook.create('test2', { | ||
runs: ['fooBar', 'fooBar', 'fooBar', 'fooBar', 'fooBar', 'fooBarEnd'], | ||
data: { | ||
foo: 'bar', | ||
}, | ||
}).then(() => { | ||
}).catch(console.error); | ||
Hook.create('test2', { | ||
runs: ['fooBar', 'fooBar', 'fooBar', 'fooBar', 'fooBar', 'fooBarEnd'], | ||
data: { | ||
foo: 'bar', | ||
}, | ||
}).then(() => { | ||
}).catch(console.error); | ||
Hook.create('test2', { | ||
runs: ['fooBar', 'fooBar', 'fooBar', 'fooBar', 'fooBar', 'fooBarEnd'], | ||
data: { | ||
foo: 'bar', | ||
}, | ||
}).then(() => { | ||
}).catch(console.error); | ||
Hook.create('test2', { | ||
runs: ['fooBar', 'fooBar', 'fooBar', 'fooBar', 'fooBar', 'fooBarEnd'], | ||
data: { | ||
foo: 'bar', | ||
}, | ||
}).then(() => { | ||
}).catch(console.error); | ||
Hook.create('test2', { | ||
runs: ['fooBar', 'fooBar', 'fooBar', 'fooBar', 'fooBar', 'fooBarEnd'], | ||
data: { | ||
foo: 'bar', | ||
}, | ||
}).then(() => { | ||
}).catch(console.error); | ||
tester.then(() => { | ||
return Hook.create('test2', { | ||
runs: ['fooBar', 'fooBar', 'fooBar', 'fooBar', 'fooBar', 'fooBarEnd'], | ||
data: { | ||
foo: 'bar', | ||
}, | ||
}).timeout(2000).unique(true).onSuccess((result) => { console.dir(result)}); | ||
}); | ||
}); | ||
@@ -179,0 +98,0 @@ }); |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
111657
13
24
1224