mirror of
https://github.com/tenrok/axios.git
synced 2026-06-11 18:02:32 +03:00
Adding Cancel and CancelToken classes
This commit is contained in:
@@ -0,0 +1,17 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A `Cancel` is an object that is thrown when an operation is canceled.
|
||||||
|
*
|
||||||
|
* @class
|
||||||
|
* @param {string=} message The message.
|
||||||
|
*/
|
||||||
|
function Cancel(message) {
|
||||||
|
this.message = message;
|
||||||
|
}
|
||||||
|
|
||||||
|
Cancel.prototype.toString = function toString() {
|
||||||
|
return 'Cancel' + (this.message ? ': ' + this.message : '');
|
||||||
|
};
|
||||||
|
|
||||||
|
module.exports = Cancel;
|
||||||
@@ -0,0 +1,57 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
var Cancel = require('./Cancel');
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A `CancelToken` is an object that can be used to request cancellation of an operation.
|
||||||
|
*
|
||||||
|
* @class
|
||||||
|
* @param {Function} executor The executor function.
|
||||||
|
*/
|
||||||
|
function CancelToken(executor) {
|
||||||
|
if (typeof executor !== 'function') {
|
||||||
|
throw new TypeError('executor must be a function.');
|
||||||
|
}
|
||||||
|
|
||||||
|
var resolvePromise;
|
||||||
|
this.promise = new Promise(function promiseExecutor(resolve) {
|
||||||
|
resolvePromise = resolve;
|
||||||
|
});
|
||||||
|
|
||||||
|
var token = this;
|
||||||
|
executor(function cancel(message) {
|
||||||
|
if (token.reason) {
|
||||||
|
// Cancellation has already been requested
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
token.reason = new Cancel(message);
|
||||||
|
resolvePromise(token.reason);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Throws a `Cancel` if cancellation has been requested.
|
||||||
|
*/
|
||||||
|
CancelToken.prototype.throwIfRequested = function throwIfRequested() {
|
||||||
|
if (this.reason) {
|
||||||
|
throw this.reason;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns an object that contains a new `CancelToken` and a function that, when called,
|
||||||
|
* cancels the `CancelToken`.
|
||||||
|
*/
|
||||||
|
CancelToken.source = function source() {
|
||||||
|
var cancel;
|
||||||
|
var token = new CancelToken(function executor(c) {
|
||||||
|
cancel = c;
|
||||||
|
});
|
||||||
|
return {
|
||||||
|
token: token,
|
||||||
|
cancel: cancel
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
module.exports = CancelToken;
|
||||||
@@ -0,0 +1,15 @@
|
|||||||
|
var Cancel = require('../../../lib/cancel/Cancel');
|
||||||
|
|
||||||
|
describe('Cancel', function() {
|
||||||
|
describe('toString', function() {
|
||||||
|
it('returns correct result when message is not specified', function() {
|
||||||
|
var cancel = new Cancel();
|
||||||
|
expect(cancel.toString()).toBe('Cancel');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('returns correct result when message is specified', function() {
|
||||||
|
var cancel = new Cancel('Operation has been canceled.');
|
||||||
|
expect(cancel.toString()).toBe('Cancel: Operation has been canceled.');
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
@@ -0,0 +1,87 @@
|
|||||||
|
var CancelToken = require('../../../lib/cancel/CancelToken');
|
||||||
|
var Cancel = require('../../../lib/cancel/Cancel');
|
||||||
|
|
||||||
|
describe('CancelToken', function() {
|
||||||
|
describe('constructor', function() {
|
||||||
|
it('throws when executor is not specified', function() {
|
||||||
|
expect(function() {
|
||||||
|
new CancelToken();
|
||||||
|
}).toThrowError(TypeError, 'executor must be a function.');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('throws when executor is not a function', function() {
|
||||||
|
expect(function() {
|
||||||
|
new CancelToken(123);
|
||||||
|
}).toThrowError(TypeError, 'executor must be a function.');
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
describe('reason', function() {
|
||||||
|
it('returns a Cancel if cancellation has been requested', function() {
|
||||||
|
var cancel;
|
||||||
|
var token = new CancelToken(function(c) {
|
||||||
|
cancel = c;
|
||||||
|
});
|
||||||
|
cancel('Operation has been canceled.');
|
||||||
|
expect(token.reason).toEqual(jasmine.any(Cancel));
|
||||||
|
expect(token.reason.message).toBe('Operation has been canceled.');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('returns undefined if cancellation has not been requested', function() {
|
||||||
|
var token = new CancelToken(function() {});
|
||||||
|
expect(token.reason).toBeUndefined();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
describe('promise', function() {
|
||||||
|
it('returns a Promise that resolves when cancellation is requested', function(done) {
|
||||||
|
var cancel;
|
||||||
|
var token = new CancelToken(function(c) {
|
||||||
|
cancel = c;
|
||||||
|
});
|
||||||
|
token.promise.then(function onFulfilled(value) {
|
||||||
|
expect(value).toEqual(jasmine.any(Cancel));
|
||||||
|
expect(value.message).toBe('Operation has been canceled.');
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
cancel('Operation has been canceled.');
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
describe('throwIfRequested', function() {
|
||||||
|
it('throws if cancellation has been requested', function() {
|
||||||
|
// Note: we cannot use expect.toThrowError here as Cancel does not inherit from Error
|
||||||
|
var cancel;
|
||||||
|
var token = new CancelToken(function(c) {
|
||||||
|
cancel = c;
|
||||||
|
});
|
||||||
|
cancel('Operation has been canceled.');
|
||||||
|
try {
|
||||||
|
token.throwIfRequested();
|
||||||
|
fail('Expected throwIfRequested to throw.');
|
||||||
|
} catch (thrown) {
|
||||||
|
if (!(thrown instanceof Cancel)) {
|
||||||
|
fail('Expected throwIfRequested to throw a Cancel, but it threw ' + thrown + '.');
|
||||||
|
}
|
||||||
|
expect(thrown.message).toBe('Operation has been canceled.');
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
it('does not throw if cancellation has not been requested', function() {
|
||||||
|
var token = new CancelToken(function() {});
|
||||||
|
token.throwIfRequested();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
describe('source', function() {
|
||||||
|
it('returns an object containing token and cancel function', function() {
|
||||||
|
var source = CancelToken.source();
|
||||||
|
expect(source.token).toEqual(jasmine.any(CancelToken));
|
||||||
|
expect(source.cancel).toEqual(jasmine.any(Function));
|
||||||
|
expect(source.token.reason).toBeUndefined();
|
||||||
|
source.cancel('Operation has been canceled.');
|
||||||
|
expect(source.token.reason).toEqual(jasmine.any(Cancel));
|
||||||
|
expect(source.token.reason.message).toBe('Operation has been canceled.');
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
Reference in New Issue
Block a user