From cf7b4dc9409a42829cf81b48c484a77d146c0d6d Mon Sep 17 00:00:00 2001 From: Liran Cohen Date: Wed, 17 Jul 2024 19:36:31 -0400 Subject: [PATCH] call onsuccess as long as failures dont occur --- packages/api/src/web5.ts | 12 ++---------- packages/api/tests/web5.spec.ts | 4 ++-- 2 files changed, 4 insertions(+), 12 deletions(-) diff --git a/packages/api/src/web5.ts b/packages/api/src/web5.ts index fd63ce294..243f250aa 100644 --- a/packages/api/src/web5.ts +++ b/packages/api/src/web5.ts @@ -330,9 +330,6 @@ export class Web5 { // If a registration object is passed, we attempt to register the AgentDID and the ConnectedDID with the DWN endpoints provided const serviceEndpointNodes = techPreview?.dwnEndpoints ?? didCreateOptions?.dwnEndpoints; - // We only want to return the success callback if we successfully register with all DWN endpoints - // So we keep track of whether we attempted registration at all - let registrationAttempt = false; try { for (const dwnEndpoint of serviceEndpointNodes) { // check if endpoint needs registration @@ -342,8 +339,6 @@ export class Web5 { continue; } - registrationAttempt = true; - // register the agent DID await DwnRegistrar.registerTenant(dwnEndpoint, agent.agentDid.uri); @@ -351,11 +346,8 @@ export class Web5 { await DwnRegistrar.registerTenant(dwnEndpoint, connectedDid); } - if (registrationAttempt) { - // If there was a registration attempt and no errors were thrown, call the onSuccess callback - registration.onSuccess(); - } - + // If no failures occurred, call the onSuccess callback + registration.onSuccess(); } catch(error) { // for any failure, call the onFailure callback with the error registration.onFailure(error); diff --git a/packages/api/tests/web5.spec.ts b/packages/api/tests/web5.spec.ts index 5e818e1b5..c5afee939 100644 --- a/packages/api/tests/web5.spec.ts +++ b/packages/api/tests/web5.spec.ts @@ -302,9 +302,9 @@ describe('Web5', () => { expect(web5).to.exist; expect(did).to.exist; - // should ot call either success or failure + // should call onSuccess and not onFailure + expect(registerSuccessSpy.calledOnce, 'onSuccess called').to.be.true; expect(registerFailureSpy.notCalled, 'onFailure not called').to.be.true; - expect(registerSuccessSpy.notCalled, 'onSuccess called').to.be.true; // Expect getServerInfo to be called but not registerTenant expect(serverInfoStub.calledTwice, 'getServerInfo called').to.be.true; // once per dwnEndpoint