You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
111 lines
14 KiB
JavaScript
111 lines
14 KiB
JavaScript
var __create = Object.create;
|
|
var __defProp = Object.defineProperty;
|
|
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
var __getProtoOf = Object.getPrototypeOf;
|
|
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
var __copyProps = (to, from, except, desc) => {
|
|
if (from && typeof from === "object" || typeof from === "function") {
|
|
for (let key of __getOwnPropNames(from))
|
|
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
}
|
|
return to;
|
|
};
|
|
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target, mod));
|
|
var import_chai = __toESM(require("chai"));
|
|
var sinon = __toESM(require("sinon"));
|
|
var import_utils = require("../../../../session/utils");
|
|
var import_chai_as_promised = __toESM(require("chai-as-promised"));
|
|
import_chai.default.use(import_chai_as_promised.default);
|
|
import_chai.default.should();
|
|
const { expect } = import_chai.default;
|
|
describe("Promise Utils", () => {
|
|
const sandbox = sinon.createSandbox();
|
|
let pollSpy;
|
|
let waitForTaskSpy;
|
|
let waitUntilSpy;
|
|
beforeEach(() => {
|
|
pollSpy = sandbox.spy(import_utils.PromiseUtils, "poll");
|
|
waitForTaskSpy = sandbox.spy(import_utils.PromiseUtils, "waitForTask");
|
|
waitUntilSpy = sandbox.spy(import_utils.PromiseUtils, "waitUntil");
|
|
});
|
|
afterEach(() => {
|
|
sandbox.restore();
|
|
});
|
|
describe("poll", () => {
|
|
it("will call done on finished", async () => {
|
|
const completionSpy = sandbox.spy();
|
|
const task = /* @__PURE__ */ __name((done) => {
|
|
completionSpy();
|
|
done();
|
|
}, "task");
|
|
const promise = import_utils.PromiseUtils.poll(task, { interval: 10 });
|
|
expect(pollSpy.callCount).to.equal(1);
|
|
expect(completionSpy.callCount).to.equal(1);
|
|
return promise;
|
|
});
|
|
it("can timeout a task", () => {
|
|
const completionSpy = sandbox.spy();
|
|
const task = /* @__PURE__ */ __name((_done) => void 0, "task");
|
|
const promise = import_utils.PromiseUtils.poll(task, { timeoutMs: 1, interval: 10 });
|
|
expect(pollSpy.callCount).to.equal(1);
|
|
expect(completionSpy.callCount).to.equal(0);
|
|
return promise.should.eventually.be.rejectedWith("Periodic check timeout");
|
|
});
|
|
it("will recur according to interval option", async () => {
|
|
const expectedRecurrences = 4;
|
|
const timeout = 3e3;
|
|
const interval = 3;
|
|
const recurrenceSpy = sandbox.spy();
|
|
const task = /* @__PURE__ */ __name((done) => {
|
|
recurrenceSpy();
|
|
if (recurrenceSpy.callCount === expectedRecurrences) {
|
|
done();
|
|
}
|
|
}, "task");
|
|
const promise = import_utils.PromiseUtils.poll(task, { timeoutMs: timeout, interval });
|
|
await promise;
|
|
expect(pollSpy.callCount).to.equal(1);
|
|
expect(recurrenceSpy.callCount).to.equal(expectedRecurrences);
|
|
});
|
|
});
|
|
describe("waitForTask", () => {
|
|
it("can wait for a task", async () => {
|
|
const completionSpy = sandbox.spy();
|
|
const task = /* @__PURE__ */ __name((done) => {
|
|
completionSpy();
|
|
done();
|
|
}, "task");
|
|
const promise = import_utils.PromiseUtils.waitForTask(task);
|
|
expect(waitForTaskSpy.callCount).to.equal(1);
|
|
expect(completionSpy.callCount).to.equal(1);
|
|
return promise;
|
|
});
|
|
it("can timeout a task", () => {
|
|
const completionSpy = sandbox.spy();
|
|
const task = /* @__PURE__ */ __name(async (_done) => void 0, "task");
|
|
const promise = import_utils.PromiseUtils.waitForTask(task, 1);
|
|
expect(waitForTaskSpy.callCount).to.equal(1);
|
|
expect(completionSpy.callCount).to.equal(0);
|
|
return promise.should.eventually.be.rejectedWith("Task timed out");
|
|
});
|
|
});
|
|
describe("waitUntil", () => {
|
|
it("can wait for check", async () => {
|
|
const check = /* @__PURE__ */ __name(() => true, "check");
|
|
const promise = import_utils.PromiseUtils.waitUntil(check, 5);
|
|
expect(waitUntilSpy.callCount).to.equal(1);
|
|
return promise;
|
|
});
|
|
it("can timeout a check", () => {
|
|
const check = /* @__PURE__ */ __name(() => false, "check");
|
|
const promise = import_utils.PromiseUtils.waitUntil(check, 1);
|
|
expect(waitUntilSpy.callCount).to.equal(1);
|
|
return promise.should.eventually.be.rejectedWith("Periodic check timeout");
|
|
});
|
|
});
|
|
});
|
|
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../ts/test/session/unit/utils/Promise_test.ts"],
  "sourcesContent": ["// tslint:disable: no-implicit-dependencies max-func-body-length no-unused-expression\n\nimport chai from 'chai';\nimport * as sinon from 'sinon';\n\nimport { PromiseUtils } from '../../../../session/utils';\n\n// tslint:disable-next-line: no-require-imports no-var-requires\nimport chaiAsPromised from 'chai-as-promised';\nchai.use(chaiAsPromised as any);\nchai.should();\n\nconst { expect } = chai;\n\ndescribe('Promise Utils', () => {\n  const sandbox = sinon.createSandbox();\n  let pollSpy: sinon.SinonSpy<\n    [\n      (done: (arg: any) => void) => Promise<void> | void,\n      (Partial<PromiseUtils.PollOptions> | undefined)?\n    ],\n    Promise<void>\n  >;\n  let waitForTaskSpy: sinon.SinonSpy<\n    [(done: (arg: any) => void) => Promise<void> | void, (number | undefined)?],\n    Promise<unknown>\n  >;\n  let waitUntilSpy: sinon.SinonSpy<\n    [() => Promise<boolean> | boolean, (number | undefined)?],\n    Promise<void>\n  >;\n\n  beforeEach(() => {\n    pollSpy = sandbox.spy(PromiseUtils, 'poll');\n    waitForTaskSpy = sandbox.spy(PromiseUtils, 'waitForTask');\n    waitUntilSpy = sandbox.spy(PromiseUtils, 'waitUntil');\n  });\n\n  afterEach(() => {\n    sandbox.restore();\n  });\n\n  describe('poll', () => {\n    it('will call done on finished', async () => {\n      // completionSpy will be called on done\n      const completionSpy = sandbox.spy();\n\n      // tslint:disable-next-line: mocha-unneeded-done\n      const task = (done: any) => {\n        completionSpy();\n        done();\n      };\n\n      const promise = PromiseUtils.poll(task, { interval: 10 });\n\n      expect(pollSpy.callCount).to.equal(1);\n      expect(completionSpy.callCount).to.equal(1);\n      return promise;\n    });\n\n    it('can timeout a task', () => {\n      // completionSpy will be called on done\n      const completionSpy = sandbox.spy();\n      const task = (_done: any) => undefined;\n\n      const promise = PromiseUtils.poll(task, { timeoutMs: 1, interval: 10 });\n\n      expect(pollSpy.callCount).to.equal(1);\n      expect(completionSpy.callCount).to.equal(0);\n      return promise.should.eventually.be.rejectedWith('Periodic check timeout');\n    });\n\n    it('will recur according to interval option', async () => {\n      const expectedRecurrences = 4;\n      const timeout = 3000;\n      const interval = 3;\n\n      const recurrenceSpy = sandbox.spy();\n      const task = (done: any) => {\n        recurrenceSpy();\n\n        // Done after we've been called `expectedRecurrences` times\n        if (recurrenceSpy.callCount === expectedRecurrences) {\n          done();\n        }\n      };\n\n      const promise = PromiseUtils.poll(task, { timeoutMs: timeout, interval });\n      await promise;\n\n      expect(pollSpy.callCount).to.equal(1);\n      expect(recurrenceSpy.callCount).to.equal(expectedRecurrences);\n    });\n  });\n\n  describe('waitForTask', () => {\n    it('can wait for a task', async () => {\n      // completionSpy will be called on done\n      const completionSpy = sandbox.spy();\n\n      // tslint:disable-next-line: mocha-unneeded-done\n      const task = (done: any) => {\n        completionSpy();\n        done();\n      };\n\n      const promise = PromiseUtils.waitForTask(task);\n\n      expect(waitForTaskSpy.callCount).to.equal(1);\n      expect(completionSpy.callCount).to.equal(1);\n      return promise;\n    });\n\n    it('can timeout a task', () => {\n      // completionSpy will be called on done\n      const completionSpy = sandbox.spy();\n      const task = async (_done: any) => undefined;\n\n      const promise = PromiseUtils.waitForTask(task, 1);\n\n      expect(waitForTaskSpy.callCount).to.equal(1);\n      expect(completionSpy.callCount).to.equal(0);\n      return promise.should.eventually.be.rejectedWith('Task timed out');\n    });\n  });\n\n  describe('waitUntil', () => {\n    it('can wait for check', async () => {\n      const check = () => true;\n      const promise = PromiseUtils.waitUntil(check, 5);\n\n      expect(waitUntilSpy.callCount).to.equal(1);\n      return promise;\n    });\n\n    it('can timeout a check', () => {\n      const check = () => false;\n      const promise = PromiseUtils.waitUntil(check, 1);\n\n      expect(waitUntilSpy.callCount).to.equal(1);\n      return promise.should.eventually.be.rejectedWith('Periodic check timeout');\n    });\n  });\n});\n"],
  "mappings": "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",
  "names": []
}

|