本文整理汇总了TypeScript中lib/utils/js-utils.defer函数的典型用法代码示例。如果您正苦于以下问题:TypeScript defer函数的具体用法?TypeScript defer怎么用?TypeScript defer使用的例子?那么恭喜您, 这里精选的函数代码示例或许可以为您提供帮助。
在下文中一共展示了defer函数的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的TypeScript代码示例。
示例1: it
it("allows multiple promises", async function() {
// setup
stubConsoleFn(fnName);
const spiedFn = console[fnName] as Sinon.SinonSpy;
const dEnabled1 = defer<boolean>();
const dEnabled2 = defer<boolean>();
const dEnabled3 = defer<boolean>();
const log = new Log({enabled: false, level: "all"});
// exercise (1)
log.setEnabled(dEnabled1.promise)
log[fnName]("1");
log.setEnabled(dEnabled2.promise)
log[fnName]("2");
log.setEnabled(dEnabled3.promise)
log[fnName]("3");
// verify (1)
sinon.assert.notCalled(spiedFn);
// exercise (2)
dEnabled1.resolve(true);
dEnabled2.resolve(false);
dEnabled3.resolve(true);
await Promise.resolve();
// verify (2)
sinon.assert.calledTwice(spiedFn);
sinon.assert.calledWithExactly(spiedFn, `${C.LOG_PREFIX}[DELAYED] 1`);
sinon.assert.calledWithExactly(spiedFn, `${C.LOG_PREFIX}[DELAYED] 3`);
});
示例2: it
it("should work with multiple concurrent changes", async function() {
// setup
asyncSettings = createAsyncSettings({
applyDefault: "DEFAULT:applyDefault",
applyUserValue: "DEFAULT:applyUserValue",
effectivelyUnchanged: "oldValueAndDefault",
});
const dChanges = defer<IStorageChanges>();
const changeListener = sinon.spy((changes) => {
dChanges.resolve(changes);
});
asyncSettings.onChanged.addListener(changeListener);
asyncSettings.startup();
await asyncSettings.whenReady;
stubbedStorage.local.set.resolves();
// exercise
stubbedStorage.onChanged.trigger({
applyDefault: {},
applyUserValue: {newValue: "myNewUserValue"},
effectivelyUnchanged: {oldValue: "oldValueAndDefault"},
settingWithoutDefaultValue: {newValue: "something"},
});
const changes = await dChanges.promise;
// verify
assert.deepEqual(changes, {
applyDefault: {newValue: "DEFAULT:applyDefault"},
applyUserValue: {newValue: "myNewUserValue"},
});
});
示例3: promiseObserverTopic
export function promiseObserverTopic(aTopic: XPCOMObserverTopic) {
const deferred = defer<[any, string, any]>();
function callback(subject: any, topic: string, data: any) {
observer.unregister();
deferred.resolve([subject, topic, data]);
}
const observer = new XPCOMObserver(aTopic, callback);
return deferred.promise;
}