2016-08-03 15:27:03 -04:00
|
|
|
/* eslint-env qunit */
|
2016-12-05 16:14:03 -05:00
|
|
|
import sinon from 'sinon';
|
2022-05-23 16:23:13 -04:00
|
|
|
import * as Fn from '../../../src/js/utils/fn';
|
2015-05-03 16:12:38 -07:00
|
|
|
|
2022-05-23 16:23:13 -04:00
|
|
|
QUnit.module('utils/fn', {
|
2016-12-05 16:14:03 -05:00
|
|
|
beforeEach() {
|
|
|
|
this.clock = sinon.useFakeTimers();
|
|
|
|
},
|
|
|
|
afterEach() {
|
|
|
|
this.clock.restore();
|
|
|
|
}
|
|
|
|
});
|
2015-08-03 15:19:36 -04:00
|
|
|
|
2016-08-12 13:51:31 -04:00
|
|
|
QUnit.test('should add context to a function', function(assert) {
|
2022-05-23 16:23:13 -04:00
|
|
|
assert.expect(1);
|
|
|
|
|
2016-08-03 15:27:03 -04:00
|
|
|
const newContext = { test: 'obj'};
|
|
|
|
const asdf = function() {
|
2016-08-12 13:51:31 -04:00
|
|
|
assert.ok(this === newContext);
|
2015-05-03 16:12:38 -07:00
|
|
|
};
|
2016-08-03 15:27:03 -04:00
|
|
|
const fdsa = Fn.bind(newContext, asdf);
|
2015-05-03 16:12:38 -07:00
|
|
|
|
|
|
|
fdsa();
|
|
|
|
});
|
2016-12-05 16:14:03 -05:00
|
|
|
|
|
|
|
QUnit.test('should throttle functions properly', function(assert) {
|
2022-05-23 16:23:13 -04:00
|
|
|
assert.expect(3);
|
|
|
|
|
2016-12-05 16:14:03 -05:00
|
|
|
const tester = sinon.spy();
|
|
|
|
const throttled = Fn.throttle(tester, 100);
|
|
|
|
|
|
|
|
// We must wait a full wait period before the function can be called.
|
|
|
|
this.clock.tick(100);
|
|
|
|
throttled();
|
|
|
|
throttled();
|
|
|
|
this.clock.tick(50);
|
|
|
|
throttled();
|
|
|
|
|
|
|
|
assert.strictEqual(tester.callCount, 1, 'the throttled function has been called the correct number of times');
|
|
|
|
|
|
|
|
this.clock.tick(50);
|
|
|
|
throttled();
|
|
|
|
|
|
|
|
assert.strictEqual(tester.callCount, 2, 'the throttled function has been called the correct number of times');
|
|
|
|
|
|
|
|
throttled();
|
|
|
|
this.clock.tick(100);
|
|
|
|
throttled();
|
|
|
|
|
|
|
|
assert.strictEqual(tester.callCount, 3, 'the throttled function has been called the correct number of times');
|
|
|
|
});
|
2022-05-23 16:23:13 -04:00
|
|
|
|
|
|
|
QUnit.test('should debounce functions properly', function(assert) {
|
|
|
|
assert.expect(6);
|
|
|
|
|
|
|
|
const tester = sinon.spy();
|
|
|
|
const debounced = Fn.debounce(tester, 100);
|
|
|
|
|
|
|
|
// Called twice on each assertion to ensure that multiple calls only result
|
|
|
|
// in a call to the inner function.
|
|
|
|
debounced();
|
|
|
|
debounced();
|
|
|
|
assert.strictEqual(tester.callCount, 0, 'the debounced function was NOT called because no time has elapsed');
|
|
|
|
|
|
|
|
this.clock.tick(100);
|
|
|
|
assert.strictEqual(tester.callCount, 1, 'the debounced function was called because enough time elapsed');
|
|
|
|
|
|
|
|
this.clock.tick(100);
|
|
|
|
assert.strictEqual(tester.callCount, 1, 'the debounced function was NOT called again even though time elapsed');
|
|
|
|
|
|
|
|
debounced();
|
|
|
|
debounced();
|
|
|
|
assert.strictEqual(tester.callCount, 1, 'the debounced function was NOT called because no time has elapsed since invocation');
|
|
|
|
|
|
|
|
this.clock.tick(50);
|
|
|
|
assert.strictEqual(tester.callCount, 1, 'the debounced function was NOT called because the clock has NOT ticket forward enough');
|
|
|
|
|
|
|
|
this.clock.tick(50);
|
|
|
|
assert.strictEqual(tester.callCount, 2, 'the debounced function was called because the clock ticked forward enough');
|
|
|
|
});
|
|
|
|
|
|
|
|
QUnit.test('may immediately invoke debounced functions', function(assert) {
|
|
|
|
assert.expect(2);
|
|
|
|
|
|
|
|
const tester = sinon.spy();
|
|
|
|
const debounced = Fn.debounce(tester, 100, true);
|
|
|
|
|
|
|
|
// Called twice on each assertion to ensure that multiple calls only result
|
|
|
|
// in a call to the inner function.
|
|
|
|
debounced();
|
|
|
|
debounced();
|
|
|
|
assert.strictEqual(tester.callCount, 1, 'the debounced function was called because true was passed');
|
|
|
|
|
|
|
|
this.clock.tick(100);
|
|
|
|
assert.strictEqual(tester.callCount, 1, 'the debounced function was NOT called because it has only been invoked once');
|
|
|
|
});
|
|
|
|
|
|
|
|
QUnit.test('may cancel debounced functions', function(assert) {
|
|
|
|
assert.expect(2);
|
|
|
|
|
|
|
|
const tester = sinon.spy();
|
|
|
|
const debounced = Fn.debounce(tester, 100);
|
|
|
|
|
|
|
|
debounced();
|
|
|
|
this.clock.tick(50);
|
|
|
|
debounced.cancel();
|
|
|
|
this.clock.tick(50);
|
|
|
|
assert.strictEqual(tester.callCount, 0, 'the debounced function was NOT called because it was cancelled');
|
|
|
|
|
|
|
|
debounced();
|
|
|
|
this.clock.tick(100);
|
|
|
|
assert.strictEqual(tester.callCount, 1, 'the debounced function was called because it was NOT cancelled');
|
|
|
|
});
|