From 1d53aa46fa37dcd0de79f3948f6f79aa363d67a6 Mon Sep 17 00:00:00 2001 From: Michael Peters Date: Thu, 13 Oct 2022 22:02:48 -0700 Subject: [PATCH] trusted resolve and unverify, second try resolve --- src/client/tests/webapp/auto-verifier.test.ts | 102 +++++++++--------- src/client/webapp/auto-verifier.ts | 4 +- 2 files changed, 53 insertions(+), 53 deletions(-) diff --git a/src/client/tests/webapp/auto-verifier.test.ts b/src/client/tests/webapp/auto-verifier.test.ts index b77a1cd..46ff1ee 100644 --- a/src/client/tests/webapp/auto-verifier.test.ts +++ b/src/client/tests/webapp/auto-verifier.test.ts @@ -1024,69 +1024,69 @@ describe('fetchAndVerifyIfNeeded tests', () => { }); - /* test('ab: a: primary with null, b: primary dedup, ab: resolve trusted fetch and unverify, second trusted with value', async () => { */ - /* const { */ - /* nextPrimary, nextTrusted, nextVerify, */ - /* primaryFunc, trustedFunc, verifyFunc */ - /* } = getManualsAndMocks(); */ + test('ab: a: primary with null, b: primary dedup, ab: resolve trusted fetch and unverify, second trusted with value', async () => { + const { + nextPrimary, nextTrusted, nextVerify, + primaryFunc, trustedFunc, verifyFunc + } = getManualsAndMocks(); - /* const av = new AutoVerifier(primaryFunc, trustedFunc, verifyFunc); */ + const av = new AutoVerifier(primaryFunc, trustedFunc, verifyFunc); - /* const a = fetchAndVerifyIfNeededManually(av, nextPrimary, nextTrusted, nextVerify); */ - /* const b = fetchAndVerifyIfNeededManually(av, nextPrimary, nextTrusted, nextVerify); */ - /* */ - /* expect(av.primaryPromise).toBe(a.primary.promise); */ - /* expect(av.trustedPromise).toBe(a.trusted.promise); */ - /* expect(av.trustedStatus).toBe('fetching'); */ - /* expect(primaryFunc).toHaveBeenCalled(); */ - /* expect(trustedFunc).toHaveBeenCalled(); */ + const a = fetchAndVerifyIfNeededManually(av, nextPrimary, nextTrusted, nextVerify); + const b = fetchAndVerifyIfNeededManually(av, nextPrimary, nextTrusted, nextVerify); + + expect(av.primaryPromise).toBe(a.primary.promise); + expect(av.trustedPromise).toBe(a.trusted.promise); + expect(av.trustedStatus).toBe('fetching'); + expect(primaryFunc).toHaveBeenCalled(); + expect(trustedFunc).toHaveBeenCalled(); - /* a.primary.resolve(null); */ - /* await disjoint(); */ + a.primary.resolve(null); + await disjoint(); - /* expect(av.primaryPromise).toBe(null); */ - /* expect(av.trustedPromise).toBe(a.trusted.promise); */ - /* expect(av.trustedStatus).toBe('verifying'); */ - /* */ - /* a.trusted.reject(new Error('rejected')); */ - /* av.unverify() */ - /* */ - /* expect(av.primaryPromise).toBe(null); */ - /* expect(av.trustedPromise).toBe(null); */ - /* expect(av.trustedStatus).toBe('none'); */ + expect(av.primaryPromise).toBe(null); + expect(av.trustedPromise).toBe(a.trusted.promise); + expect(av.trustedStatus).toBe('verifying'); + + a.trusted.resolve(new BasicWE(2)); + av.unverify() + + expect(av.primaryPromise).toBe(null); + expect(av.trustedPromise).toBe(null); + expect(av.trustedStatus).toBe('none'); - /* await disjoint(); */ + await disjoint(); - /* expect(av.primaryPromise).toBe(null); */ - /* expect(av.trustedPromise).toBe(b.trusted.promise); */ - /* expect(av.trustedStatus).toBe('verifying'); */ + expect(av.primaryPromise).toBe(null); + expect(av.trustedPromise).toBe(b.trusted.promise); + expect(av.trustedStatus).toBe('verifying'); - /* expect(verifyFunc).toHaveBeenCalledTimes(0); */ - /* b.trusted.resolve(new BasicWE(2)); */ - /* await disjoint(); */ + expect(verifyFunc).toHaveBeenCalledTimes(0); + b.trusted.resolve(new BasicWE(3)); + await disjoint(); - /* expect(verifyFunc).toHaveBeenCalledWith(null, new BasicWE(2)); */ - /* expect(av.primaryPromise).toBe(null); */ - /* expect(av.trustedPromise).toBe(b.trusted.promise); */ - /* expect(av.trustedStatus).toBe('verifying'); */ + expect(verifyFunc).toHaveBeenCalledWith(null, new BasicWE(3)); + expect(av.primaryPromise).toBe(null); + expect(av.trustedPromise).toBe(b.trusted.promise); + expect(av.trustedStatus).toBe('verifying'); - /* expect(a.result).toBeUndefined(); */ - /* expect(b.result).toBeUndefined(); */ - /* a.verify.resolve(true); */ - /* await disjoint() */ + expect(a.result).toBeUndefined(); + expect(b.result).toBeUndefined(); + a.verify.resolve(true); + await disjoint() - /* expect(a.result).toEqual(new BasicWE(2)); */ - /* expect(b.result).toEqual(new BasicWE(2)); */ - /* expect(av.primaryPromise).toBe(null); */ - /* expect(av.trustedPromise).toBe(b.trusted.promise); */ - /* expect(av.trustedStatus).toBe('verified'); */ + expect(a.result).toEqual(new BasicWE(3)); + expect(b.result).toEqual(new BasicWE(3)); + expect(av.primaryPromise).toBe(null); + expect(av.trustedPromise).toBe(b.trusted.promise); + expect(av.trustedStatus).toBe('verified'); - /* await disjoint(); */ + await disjoint(); - /* expect(primaryFunc).toHaveBeenCalledTimes(1); */ - /* expect(trustedFunc).toHaveBeenCalledTimes(2); */ - /* expect(verifyFunc).toHaveBeenCalledTimes(1); */ - /* }); */ + expect(primaryFunc).toHaveBeenCalledTimes(1); + expect(trustedFunc).toHaveBeenCalledTimes(2); + expect(verifyFunc).toHaveBeenCalledTimes(1); + }); // TODO: Why not have fetcher and a simple dedup wrapper to remove some complexity from this function? // This would likely make it possible to get rid of the "else" block in tryResolveTrustedPromise diff --git a/src/client/webapp/auto-verifier.ts b/src/client/webapp/auto-verifier.ts index cc116e2..d18c834 100644 --- a/src/client/webapp/auto-verifier.ts +++ b/src/client/webapp/auto-verifier.ts @@ -296,7 +296,7 @@ export class AutoVerifier { try { trustedResult = await origTrustedPromise; } catch (e: unknown) { - if (this.trustedPromise == origTrustedPromise) { + if (this.trustedPromise === origTrustedPromise) { throw e; } else { console.warn('trusted promise from another path rejected after unverify', e); @@ -343,8 +343,8 @@ export class AutoVerifier { await tryResolveTrustedPromise(); } catch (e: unknown) { if (!resolved) { - this.trustedPromise = null; // suppress warnings about uncaught rejections this.primaryPromise = null; // suppress warnings about uncaught rejections + //this.trustedPromise = null; // suppress warnings about uncaught rejections this.verifyPromise = null; // suppress warnings about uncaught rejections this.unverify(); // eslint-disable-next-line prefer-promise-reject-errors