From a0ed18b6ff8b07395681bd05ec4dca11a41875bd Mon Sep 17 00:00:00 2001 From: xinhyao Date: Tue, 10 Dec 2024 21:25:47 +0800 Subject: [PATCH] fix: set supertoken after authorization success --- .../src/authorization.js | 1 + .../test/unit/spec/authorization.js | 6 +++++- 2 files changed, 6 insertions(+), 1 deletion(-) diff --git a/packages/@webex/plugin-authorization-browser-first-party/src/authorization.js b/packages/@webex/plugin-authorization-browser-first-party/src/authorization.js index 91be8a7ce34..4c79d317fb8 100644 --- a/packages/@webex/plugin-authorization-browser-first-party/src/authorization.js +++ b/packages/@webex/plugin-authorization-browser-first-party/src/authorization.js @@ -434,6 +434,7 @@ const Authorization = WebexPlugin.extend({ eventType: 'authorizationSuccess', data: res.body, }); + this.webex.credentials.set({supertoken: res.body}); this.cancelQRCodePolling(); }) .catch((res) => { diff --git a/packages/@webex/plugin-authorization-browser-first-party/test/unit/spec/authorization.js b/packages/@webex/plugin-authorization-browser-first-party/test/unit/spec/authorization.js index b08af627998..a5a95285de2 100644 --- a/packages/@webex/plugin-authorization-browser-first-party/test/unit/spec/authorization.js +++ b/packages/@webex/plugin-authorization-browser-first-party/test/unit/spec/authorization.js @@ -599,6 +599,7 @@ describe('plugin-authorization-browser-first-party', () => { webex.request.onFirstCall().resolves({statusCode: 200, body: {access_token: 'token'}}); const emitSpy = sinon.spy(webex.authorization.eventEmitter, 'emit'); + const credentialsSetSpy = sinon.spy(webex.credentials, 'set'); sinon.spy(webex.authorization, 'cancelQRCodePolling'); webex.authorization._startQRCodePolling(options); @@ -617,6 +618,7 @@ describe('plugin-authorization-browser-first-party', () => { ); assert.calledOnce(webex.authorization.cancelQRCodePolling); + assert.calledOnce(credentialsSetSpy); assert.calledTwice(emitSpy); assert.equal(emitSpy.getCall(0).args[1].eventType, 'authorizationSuccess'); assert.equal(emitSpy.getCall(1).args[1].eventType, 'pollingCanceled'); @@ -708,7 +710,8 @@ describe('plugin-authorization-browser-first-party', () => { webex.request.onSecondCall().resolves({statusCode: 200, body: {access_token: 'token'}}); sinon.spy(webex.authorization, 'cancelQRCodePolling'); const emitSpy = sinon.spy(webex.authorization.eventEmitter, 'emit'); - + const credentialsSetSpy = sinon.spy(webex.credentials, 'set'); + webex.authorization._startQRCodePolling(options); await clock.tickAsync(4000); @@ -720,6 +723,7 @@ describe('plugin-authorization-browser-first-party', () => { assert.calledTwice(webex.request); assert.calledOnce(webex.authorization.cancelQRCodePolling); + assert.calledOnce(credentialsSetSpy); assert.calledTwice(emitSpy); assert.equal(emitSpy.getCall(0).args[1].eventType, 'authorizationSuccess'); assert.equal(emitSpy.getCall(1).args[1].eventType, 'pollingCanceled');