2017-07-19 19:05:24 +00:00
|
|
|
'use strict';
|
|
|
|
|
|
|
|
describe('createTaskWithTimeout', function() {
|
2018-05-02 16:51:22 +00:00
|
|
|
it('resolves when promise resolves', function() {
|
|
|
|
var task = function() {
|
|
|
|
return Promise.resolve('hi!');
|
|
|
|
};
|
|
|
|
var taskWithTimeout = textsecure.createTaskWithTimeout(task);
|
2017-07-19 19:05:24 +00:00
|
|
|
|
2018-05-02 16:51:22 +00:00
|
|
|
return taskWithTimeout().then(function(result) {
|
|
|
|
assert.strictEqual(result, 'hi!');
|
2017-07-19 19:05:24 +00:00
|
|
|
});
|
2018-05-02 16:51:22 +00:00
|
|
|
});
|
|
|
|
it('flows error from promise back', function() {
|
|
|
|
var error = new Error('original');
|
|
|
|
var task = function() {
|
|
|
|
return Promise.reject(error);
|
|
|
|
};
|
|
|
|
var taskWithTimeout = textsecure.createTaskWithTimeout(task);
|
2017-07-19 19:05:24 +00:00
|
|
|
|
2018-05-02 16:51:22 +00:00
|
|
|
return taskWithTimeout().catch(function(flowedError) {
|
|
|
|
assert.strictEqual(error, flowedError);
|
2017-07-19 19:05:24 +00:00
|
|
|
});
|
2018-05-02 16:51:22 +00:00
|
|
|
});
|
|
|
|
it('rejects if promise takes too long (this one logs error to console)', function() {
|
|
|
|
var error = new Error('original');
|
|
|
|
var complete = false;
|
|
|
|
var task = function() {
|
|
|
|
return new Promise(function(resolve) {
|
|
|
|
setTimeout(function() {
|
|
|
|
complete = true;
|
|
|
|
resolve();
|
|
|
|
}, 3000);
|
|
|
|
});
|
|
|
|
};
|
|
|
|
var taskWithTimeout = textsecure.createTaskWithTimeout(task, this.name, {
|
|
|
|
timeout: 10,
|
2017-07-19 19:05:24 +00:00
|
|
|
});
|
2018-05-02 16:51:22 +00:00
|
|
|
|
|
|
|
return taskWithTimeout().then(
|
|
|
|
function() {
|
|
|
|
throw new Error('it was not supposed to resolve!');
|
|
|
|
},
|
|
|
|
function() {
|
|
|
|
assert.strictEqual(complete, false);
|
|
|
|
}
|
|
|
|
);
|
|
|
|
});
|
|
|
|
it('resolves if task returns something falsey', function() {
|
|
|
|
var task = function() {};
|
|
|
|
var taskWithTimeout = textsecure.createTaskWithTimeout(task);
|
|
|
|
return taskWithTimeout();
|
|
|
|
});
|
|
|
|
it('resolves if task returns a non-promise', function() {
|
|
|
|
var task = function() {
|
|
|
|
return 'hi!';
|
|
|
|
};
|
|
|
|
var taskWithTimeout = textsecure.createTaskWithTimeout(task);
|
|
|
|
return taskWithTimeout().then(function(result) {
|
|
|
|
assert.strictEqual(result, 'hi!');
|
2017-07-19 19:05:24 +00:00
|
|
|
});
|
2018-05-02 16:51:22 +00:00
|
|
|
});
|
|
|
|
it('rejects if task throws (and does not log about taking too long)', function() {
|
|
|
|
var error = new Error('Task is throwing!');
|
|
|
|
var task = function() {
|
|
|
|
throw error;
|
|
|
|
};
|
|
|
|
var taskWithTimeout = textsecure.createTaskWithTimeout(task, this.name, {
|
|
|
|
timeout: 10,
|
2017-08-30 20:33:55 +00:00
|
|
|
});
|
2018-05-02 16:51:22 +00:00
|
|
|
return taskWithTimeout().then(
|
|
|
|
function(result) {
|
|
|
|
throw new Error('Overall task should reject!');
|
|
|
|
},
|
|
|
|
function(flowedError) {
|
|
|
|
assert.strictEqual(flowedError, error);
|
|
|
|
}
|
|
|
|
);
|
|
|
|
});
|
2017-07-19 19:05:24 +00:00
|
|
|
});
|