UNPKG

@theia/core

Version:

Theia is a cloud & desktop IDE framework implemented in TypeScript.

81 lines 3.98 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); // ***************************************************************************** // Copyright (C) 2021 Red Hat and others. // // This program and the accompanying materials are made available under the // terms of the Eclipse Public License v. 2.0 which is available at // http://www.eclipse.org/legal/epl-2.0. // // This Source Code may also be made available under the following Secondary // Licenses when the conditions for such availability set forth in the Eclipse // Public License v. 2.0 are satisfied: GNU General Public License, version 2 // with the GNU Classpath Exception which is available at // https://www.gnu.org/software/classpath/license.html. // // SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0 // ***************************************************************************** const assert = require("assert/strict"); const promise_util_1 = require("./promise-util"); const event_1 = require("./event"); const cancellation_1 = require("./cancellation"); describe('promise-util', () => { describe('waitForEvent', () => { it('should time out', async () => { const emitter = new event_1.Emitter(); await assert.rejects((0, promise_util_1.waitForEvent)(emitter.event, 1000), reason => reason instanceof cancellation_1.CancellationError); }); it('should get event', async () => { const emitter = new event_1.Emitter(); setTimeout(() => { emitter.fire('abcd'); }, 500); assert.strictEqual(await (0, promise_util_1.waitForEvent)(emitter.event, 1000), 'abcd'); }); }); describe('firstTrue', () => { function createSequentialPromises(...executionHandlers) { const deferreds = []; let i = 0; for (let k = 0; k < executionHandlers.length; k++) { deferreds.push(new promise_util_1.Deferred()); } const resolveNext = () => { if (i < executionHandlers.length) { executionHandlers[i](value => deferreds[i].resolve(value), error => deferreds[i].reject(error)); i++; } if (i < executionHandlers.length) { setTimeout(resolveNext, 1); } }; setTimeout(resolveNext, 1); return deferreds.map(deferred => deferred.promise); } it('should resolve to false when the promises arg is empty', async () => { const actual = await (0, promise_util_1.firstTrue)(); assert.strictEqual(actual, false); }); it('should resolve to true when the first promise resolves to true', async () => { const signals = []; function createHandler(signal, result) { return (resolve, reject) => { signals.push(signal); if (typeof result !== 'undefined') { resolve(result); } else { reject(undefined); } }; } const actual = await (0, promise_util_1.firstTrue)(...createSequentialPromises(createHandler('a', false), createHandler('b', false), createHandler('c', true), createHandler('d', false), createHandler('e', true))); assert.strictEqual(actual, true); assert.deepStrictEqual(signals, ['a', 'b', 'c']); }); it('should reject when one of the promises rejects', async () => { await assert.rejects((0, promise_util_1.firstTrue)(...createSequentialPromises((resolve, _) => resolve(false), resolve => resolve(false), (_, reject) => reject(new Error('my test error')), resolve => resolve(true))), /Error: my test error/); }); }); }); //# sourceMappingURL=promise-util.spec.js.map