Fix joining deleted call links leaving call active
Co-authored-by: ayumi-signal <143036029+ayumi-signal@users.noreply.github.com>
This commit is contained in:
parent
b86663b1b7
commit
a099c402ff
2 changed files with 68 additions and 24 deletions
|
@ -2252,6 +2252,7 @@ const _startCallLinkLobby = async ({
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
let success = false;
|
||||||
try {
|
try {
|
||||||
dispatch({
|
dispatch({
|
||||||
type: WAITING_FOR_CALL_LINK_LOBBY,
|
type: WAITING_FOR_CALL_LINK_LOBBY,
|
||||||
|
@ -2342,9 +2343,11 @@ const _startCallLinkLobby = async ({
|
||||||
isConversationTooBigToRing: false,
|
isConversationTooBigToRing: false,
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
success = true;
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
log.error(`${logId}: Failed to start lobby`, Errors.toLogFormat(error));
|
log.error(`${logId}: Failed to start lobby`, Errors.toLogFormat(error));
|
||||||
|
} finally {
|
||||||
|
if (!success) {
|
||||||
try {
|
try {
|
||||||
calling.stopCallingLobby(roomId);
|
calling.stopCallingLobby(roomId);
|
||||||
} catch (innerError) {
|
} catch (innerError) {
|
||||||
|
@ -2359,6 +2362,7 @@ const _startCallLinkLobby = async ({
|
||||||
payload: { conversationId: roomId },
|
payload: { conversationId: roomId },
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
function leaveCurrentCallAndStartCallingLobby(
|
function leaveCurrentCallAndStartCallingLobby(
|
||||||
|
@ -2437,6 +2441,7 @@ function startCallingLobby({
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
let success = false;
|
||||||
try {
|
try {
|
||||||
dispatch({
|
dispatch({
|
||||||
type: WAITING_FOR_CALLING_LOBBY,
|
type: WAITING_FOR_CALLING_LOBBY,
|
||||||
|
@ -2473,9 +2478,11 @@ function startCallingLobby({
|
||||||
isConversationTooBigToRing: isConversationTooBigToRing(conversation),
|
isConversationTooBigToRing: isConversationTooBigToRing(conversation),
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
success = true;
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
log.error(`${logId}: Failed to start lobby`, Errors.toLogFormat(error));
|
log.error(`${logId}: Failed to start lobby`, Errors.toLogFormat(error));
|
||||||
|
} finally {
|
||||||
|
if (!success) {
|
||||||
try {
|
try {
|
||||||
calling.stopCallingLobby(conversationId);
|
calling.stopCallingLobby(conversationId);
|
||||||
} catch (innerError) {
|
} catch (innerError) {
|
||||||
|
@ -2490,6 +2497,7 @@ function startCallingLobby({
|
||||||
payload: { conversationId },
|
payload: { conversationId },
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
}
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1579,6 +1579,42 @@ describe('calling duck', () => {
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
describe('startCallLinkLobby for deleted links', () => {
|
||||||
|
beforeEach(function (this: Mocha.Context) {
|
||||||
|
this.callingServiceReadCallLink = this.sandbox
|
||||||
|
.stub(callingService, 'readCallLink')
|
||||||
|
.resolves(null);
|
||||||
|
});
|
||||||
|
|
||||||
|
const doAction = async (
|
||||||
|
payload: StartCallLinkLobbyType
|
||||||
|
): Promise<{ dispatch: sinon.SinonSpy }> => {
|
||||||
|
const { startCallLinkLobby } = actions;
|
||||||
|
const dispatch = sinon.spy();
|
||||||
|
await startCallLinkLobby(payload)(dispatch, getEmptyRootState, null);
|
||||||
|
return { dispatch };
|
||||||
|
};
|
||||||
|
|
||||||
|
it('fails', async function (this: Mocha.Context) {
|
||||||
|
const { roomId, rootKey } = FAKE_CALL_LINK;
|
||||||
|
const { dispatch } = await doAction({ rootKey });
|
||||||
|
|
||||||
|
sinon.assert.calledTwice(dispatch);
|
||||||
|
sinon.assert.calledWith(dispatch, {
|
||||||
|
type: 'calling/WAITING_FOR_CALL_LINK_LOBBY',
|
||||||
|
payload: {
|
||||||
|
roomId,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
sinon.assert.calledWith(dispatch, {
|
||||||
|
type: 'calling/CALL_LOBBY_FAILED',
|
||||||
|
payload: {
|
||||||
|
conversationId: roomId,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
describe('peekNotConnectedGroupCall', () => {
|
describe('peekNotConnectedGroupCall', () => {
|
||||||
const { peekNotConnectedGroupCall } = actions;
|
const { peekNotConnectedGroupCall } = actions;
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue