Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

chore: cleanup MLSCallHelper class (WPB-7153) #2938

Merged
merged 2 commits into from
Aug 13, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -37,7 +37,7 @@ import com.wire.kalium.logic.data.call.CallRepository
import com.wire.kalium.logic.data.call.CallStatus
import com.wire.kalium.logic.data.call.CallType
import com.wire.kalium.logic.data.call.EpochInfo
import com.wire.kalium.logic.data.call.MLSCallHelperImpl
import com.wire.kalium.logic.data.call.CallHelperImpl
import com.wire.kalium.logic.data.call.VideoState
import com.wire.kalium.logic.data.call.VideoStateChecker
import com.wire.kalium.logic.data.call.mapper.CallMapper
Expand Down Expand Up @@ -198,7 +198,7 @@ class CallManagerImpl internal constructor(
.keepingStrongReference(),
closeCallHandler = OnCloseCall(
callRepository = callRepository,
mlsCallHelper = MLSCallHelperImpl(
callHelper = CallHelperImpl(
callRepository = callRepository,
subconversationRepository = subconversationRepository,
userConfigRepository = userConfigRepository
Expand Down Expand Up @@ -478,7 +478,7 @@ class CallManagerImpl internal constructor(
participantMapper = ParticipantMapperImpl(videoStateChecker, callMapper),
userRepository = userRepository,
userConfigRepository = userConfigRepository,
mlsCallHelper = MLSCallHelperImpl(
callHelper = CallHelperImpl(
callRepository = callRepository,
subconversationRepository = subconversationRepository,
userConfigRepository = userConfigRepository
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@ import com.wire.kalium.logger.obfuscateId
import com.wire.kalium.logic.callingLogger
import com.wire.kalium.logic.data.call.CallRepository
import com.wire.kalium.logic.data.call.CallStatus
import com.wire.kalium.logic.data.call.MLSCallHelper
import com.wire.kalium.logic.data.call.CallHelper
import com.wire.kalium.logic.data.conversation.Conversation
import com.wire.kalium.logic.data.id.ConversationId
import com.wire.kalium.logic.data.id.QualifiedIdMapper
Expand All @@ -36,7 +36,7 @@ import kotlinx.coroutines.launch
@Suppress("LongParameterList")
class OnCloseCall(
private val callRepository: CallRepository,
private val mlsCallHelper: MLSCallHelper,
private val callHelper: CallHelper,
private val scope: CoroutineScope,
private val qualifiedIdMapper: QualifiedIdMapper
) : CloseCallHandler {
Expand Down Expand Up @@ -73,7 +73,7 @@ class OnCloseCall(
callRepository.getCallMetadataProfile()[conversationIdWithDomain]?.conversationType

if (callRepository.getCallMetadataProfile()[conversationIdWithDomain]?.protocol is Conversation.ProtocolInfo.MLS) {
mlsCallHelper.handleCallTermination(conversationIdWithDomain, conversationType)
callHelper.handleCallTermination(conversationIdWithDomain, conversationType)
}
callingLogger.i("[OnCloseCall] -> ConversationId: ${conversationId.obfuscateId()} | callStatus: $callStatus")
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ import com.wire.kalium.logic.callingLogger
import com.wire.kalium.logic.configuration.UserConfigRepository
import com.wire.kalium.logic.data.call.CallParticipants
import com.wire.kalium.logic.data.call.CallRepository
import com.wire.kalium.logic.data.call.MLSCallHelper
import com.wire.kalium.logic.data.call.CallHelper
import com.wire.kalium.logic.data.call.Participant
import com.wire.kalium.logic.data.call.mapper.ParticipantMapper
import com.wire.kalium.logic.data.id.ConversationId
Expand All @@ -47,7 +47,7 @@ class OnParticipantListChanged internal constructor(
private val participantMapper: ParticipantMapper,
private val userRepository: UserRepository,
private val userConfigRepository: UserConfigRepository,
private val mlsCallHelper: MLSCallHelper,
private val callHelper: CallHelper,
private val endCall: suspend (conversationId: ConversationId) -> Unit,
private val callingScope: CoroutineScope,
private val jsonDecoder: Json = Json
Expand Down Expand Up @@ -81,7 +81,7 @@ class OnParticipantListChanged internal constructor(

val currentCall = callRepository.establishedCallsFlow().first().firstOrNull()
currentCall?.let {
val shouldEndSFTOneOnOneCall = mlsCallHelper.shouldEndSFTOneOnOneCall(
val shouldEndSFTOneOnOneCall = callHelper.shouldEndSFTOneOnOneCall(
conversationId = conversationIdWithDomain,
callProtocol = callProtocol,
conversationType = it.conversationType,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -30,13 +30,14 @@ import com.wire.kalium.logic.functional.onSuccess
import com.wire.kalium.network.api.base.authenticated.conversation.SubconversationDeleteRequest

/**
* Helper class to handle MLS call related operations.
* Helper class to handle call related operations.
*/
interface MLSCallHelper {
interface CallHelper {

/**
* Check if the OneOnOne MLS call that uses SFT should be ended.
* The call should be ended if the call has two participants and the second participant has lost audio.
* Check if the OneOnOne call that uses SFT should be ended.
* For Proteus, the call should be ended if the call has one participant after having 2 in the call.
* For MLS, the call should be ended if the call has two participants and the second participant has lost audio.
*
* @param conversationId the conversation id.
* @param callProtocol the call protocol.
Expand All @@ -55,7 +56,7 @@ interface MLSCallHelper {

/**
* Handle the call termination.
* If the call is a one on one call is oneOneOne on SFT, then delete MLS sub conversation
* If the call is oneOneOne on SFT, then delete MLS sub conversation
* otherwise leave the MLS conference.
*
* @param conversationId the conversation id.
Expand All @@ -68,11 +69,11 @@ interface MLSCallHelper {
)
}

class MLSCallHelperImpl(
class CallHelperImpl(
private val callRepository: CallRepository,
private val subconversationRepository: SubconversationRepository,
private val userConfigRepository: UserConfigRepository
) : MLSCallHelper {
) : CallHelper {

override fun shouldEndSFTOneOnOneCall(
conversationId: ConversationId,
Expand Down Expand Up @@ -100,12 +101,12 @@ class MLSCallHelperImpl(
if (userConfigRepository.shouldUseSFTForOneOnOneCalls().getOrElse(false) &&
conversationType == Conversation.Type.ONE_ON_ONE
) {
callingLogger.i("[MLSCallHelper] -> fetching remote MLS sub conversation details")
callingLogger.i("[CallHelper] -> fetching remote MLS sub conversation details")
subconversationRepository.fetchRemoteSubConversationDetails(
conversationId,
CALL_SUBCONVERSATION_ID
).onSuccess { subconversationDetails ->
callingLogger.i("[MLSCallHelper] -> Deleting remote MLS sub conversation")
callingLogger.i("[CallHelper] -> Deleting remote MLS sub conversation")
subconversationRepository.deleteRemoteSubConversation(
subconversationDetails.parentId.toModel(),
SubconversationId(subconversationDetails.id),
Expand All @@ -115,10 +116,10 @@ class MLSCallHelperImpl(
)
)
}.onFailure {
callingLogger.e("[MLSCallHelper] -> Error fetching remote MLS sub conversation details")
callingLogger.e("[CallHelper] -> Error fetching remote MLS sub conversation details")
}
} else {
callingLogger.i("[MLSCallHelper] -> Leaving MLS conference")
callingLogger.i("[CallHelper] -> Leaving MLS conference")
callRepository.leaveMlsConference(conversationId)
}
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -197,7 +197,7 @@ class MLSCallHelperTest {
@Mock
val userConfigRepository = mock(classOf<UserConfigRepository>())

private val mLSCallHelper: MLSCallHelper = MLSCallHelperImpl(
private val mLSCallHelper: CallHelper = CallHelperImpl(
callRepository = callRepository,
subconversationRepository = subconversationRepository,
userConfigRepository = userConfigRepository
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -27,9 +27,8 @@ import com.wire.kalium.logic.data.id.ConversationId
import com.wire.kalium.logic.data.id.GroupID
import com.wire.kalium.logic.data.id.QualifiedIdMapperImpl
import com.wire.kalium.logic.data.call.CallStatus
import com.wire.kalium.logic.data.call.MLSCallHelper
import com.wire.kalium.logic.data.call.CallHelper
import com.wire.kalium.logic.data.mls.CipherSuite
import com.wire.kalium.logic.feature.call.scenario.OnCloseCall
import com.wire.kalium.logic.framework.TestUser
import io.mockative.Mock
import io.mockative.any
Expand All @@ -52,7 +51,7 @@ class OnCloseCallTest {
val callRepository = mock(classOf<CallRepository>())

@Mock
val mlsCallHelper = mock(classOf<MLSCallHelper>())
val callHelper = mock(classOf<CallHelper>())

val qualifiedIdMapper = QualifiedIdMapperImpl(TestUser.SELF.id)

Expand All @@ -66,7 +65,7 @@ class OnCloseCallTest {
fun setUp() {
onCloseCall = OnCloseCall(
callRepository,
mlsCallHelper,
callHelper,
testScope,
qualifiedIdMapper
)
Expand Down Expand Up @@ -282,8 +281,8 @@ class OnCloseCallTest {
.with(eq(conversationId), eq(CallStatus.CLOSED))
.wasInvoked(once)

verify(mlsCallHelper)
.suspendFunction(mlsCallHelper::handleCallTermination)
verify(callHelper)
.suspendFunction(callHelper::handleCallTermination)
.with(eq(conversationId), any())
.wasInvoked(once)
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@ import com.wire.kalium.logic.configuration.UserConfigRepository
import com.wire.kalium.logic.data.call.Call
import com.wire.kalium.logic.data.call.CallRepository
import com.wire.kalium.logic.data.call.CallStatus
import com.wire.kalium.logic.data.call.MLSCallHelper
import com.wire.kalium.logic.data.call.CallHelper
import com.wire.kalium.logic.data.call.Participant
import com.wire.kalium.logic.data.call.mapper.ParticipantMapper
import com.wire.kalium.logic.data.conversation.Conversation
Expand Down Expand Up @@ -152,7 +152,7 @@ class OnParticipantListChangedTest {
val userRepository = mock(UserRepository::class)

@Mock
val mlsCallHelper = mock(MLSCallHelper::class)
val callHelper = mock(CallHelper::class)

var isEndCallInvoked = false

Expand All @@ -163,7 +163,7 @@ class OnParticipantListChangedTest {
participantMapper = participantMapper,
userConfigRepository = userConfigRepository,
userRepository = userRepository,
mlsCallHelper = mlsCallHelper,
callHelper = callHelper,
qualifiedIdMapper = qualifiedIdMapper,
endCall = {
isEndCallInvoked = true
Expand Down Expand Up @@ -200,8 +200,8 @@ class OnParticipantListChangedTest {
}

fun withShouldEndSFTOneOnOneCall(result: Boolean) = apply {
given(mlsCallHelper)
.function(mlsCallHelper::shouldEndSFTOneOnOneCall)
given(callHelper)
.function(callHelper::shouldEndSFTOneOnOneCall)
.whenInvokedWith(any(), any(), any(), any(), any())
.thenReturn(result)
}
Expand Down
Loading