* Use the SDK's offline state to drive the offline indicator. * Only use network reachability for restarting the sync loop, use the homeserver reachability for requests. * Add a separate indicator to distinguish when the server is unreachable but the device is online.
114 lines
5.4 KiB
Swift
114 lines
5.4 KiB
Swift
//
|
|
// Copyright 2024 New Vector Ltd.
|
|
//
|
|
// SPDX-License-Identifier: AGPL-3.0-only OR LicenseRef-Element-Commercial
|
|
// Please see LICENSE files in the repository root for full details.
|
|
//
|
|
|
|
import Combine
|
|
import Foundation
|
|
|
|
struct ClientProxyMockConfiguration {
|
|
var homeserver = ""
|
|
var userIDServerName: String?
|
|
var userID: String = RoomMemberProxyMock.mockMe.userID
|
|
var deviceID: String?
|
|
var roomSummaryProvider: RoomSummaryProviderProtocol = RoomSummaryProviderMock(.init())
|
|
var joinedSpaceRooms: [SpaceRoomProxyProtocol] = []
|
|
var roomDirectorySearchProxy: RoomDirectorySearchProxyProtocol?
|
|
|
|
var recoveryState: SecureBackupRecoveryState = .enabled
|
|
|
|
var notificationSettings = NotificationSettingsProxyMock(with: .init())
|
|
|
|
var timelineMediaVisibility = TimelineMediaVisibility.always
|
|
var hideInviteAvatars = false
|
|
|
|
var maxMediaUploadSize: UInt = 100 * 1024 * 1024
|
|
}
|
|
|
|
enum ClientProxyMockError: Error {
|
|
case generic
|
|
}
|
|
|
|
extension ClientProxyMock {
|
|
convenience init(_ configuration: ClientProxyMockConfiguration) {
|
|
self.init()
|
|
|
|
userID = configuration.userID
|
|
deviceID = configuration.deviceID
|
|
|
|
homeserver = configuration.homeserver
|
|
userIDServerName = configuration.userIDServerName
|
|
|
|
roomSummaryProvider = configuration.roomSummaryProvider
|
|
alternateRoomSummaryProvider = RoomSummaryProviderMock(.init())
|
|
staticRoomSummaryProvider = RoomSummaryProviderMock(.init())
|
|
|
|
roomDirectorySearchProxyReturnValue = configuration.roomDirectorySearchProxy
|
|
|
|
actionsPublisher = PassthroughSubject<ClientProxyAction, Never>().eraseToAnyPublisher()
|
|
loadingStatePublisher = .init(.notLoading)
|
|
verificationStatePublisher = .init(.unknown)
|
|
homeserverReachabilityPublisher = .init(.reachable)
|
|
|
|
userAvatarURLPublisher = .init(nil)
|
|
userDisplayNamePublisher = .init("User display name")
|
|
|
|
ignoredUsersPublisher = .init([RoomMemberProxyMock].allMembers.map(\.userID))
|
|
|
|
notificationSettings = configuration.notificationSettings
|
|
|
|
isOnlyDeviceLeftReturnValue = .success(false)
|
|
accountURLActionReturnValue = "https://matrix.org/account"
|
|
canDeactivateAccount = false
|
|
directRoomForUserIDReturnValue = .failure(.sdkError(ClientProxyMockError.generic))
|
|
createDirectRoomWithExpectedRoomNameReturnValue = .failure(.sdkError(ClientProxyMockError.generic))
|
|
createRoomNameTopicIsRoomPrivateIsKnockingOnlyUserIDsAvatarURLAliasLocalPartReturnValue = .failure(.sdkError(ClientProxyMockError.generic))
|
|
uploadMediaReturnValue = .failure(.sdkError(ClientProxyMockError.generic))
|
|
loadUserDisplayNameReturnValue = .failure(.sdkError(ClientProxyMockError.generic))
|
|
setUserDisplayNameReturnValue = .failure(.sdkError(ClientProxyMockError.generic))
|
|
loadUserAvatarURLReturnValue = .failure(.sdkError(ClientProxyMockError.generic))
|
|
setUserAvatarMediaReturnValue = .failure(.sdkError(ClientProxyMockError.generic))
|
|
removeUserAvatarReturnValue = .failure(.sdkError(ClientProxyMockError.generic))
|
|
isAliasAvailableReturnValue = .success(true)
|
|
searchUsersSearchTermLimitReturnValue = .success(.init(results: [], limited: false))
|
|
profileForReturnValue = .success(.init(userID: "@a:b.com", displayName: "Some user"))
|
|
ignoreUserReturnValue = .success(())
|
|
unignoreUserReturnValue = .success(())
|
|
|
|
trackRecentlyVisitedRoomReturnValue = .success(())
|
|
recentlyVisitedRoomsReturnValue = .success([])
|
|
recentConversationCounterpartsReturnValue = []
|
|
|
|
loadMediaContentForSourceThrowableError = ClientProxyError.sdkError(ClientProxyMockError.generic)
|
|
loadMediaThumbnailForSourceWidthHeightThrowableError = ClientProxyError.sdkError(ClientProxyMockError.generic)
|
|
loadMediaFileForSourceFilenameThrowableError = ClientProxyError.sdkError(ClientProxyMockError.generic)
|
|
|
|
secureBackupController = SecureBackupControllerMock(.init(recoveryState: configuration.recoveryState))
|
|
resetIdentityReturnValue = .success(IdentityResetHandleSDKMock(.init()))
|
|
|
|
spaceService = SpaceServiceProxyMock(.init())
|
|
|
|
roomForIdentifierClosure = { [weak self] identifier in
|
|
if let room = self?.roomSummaryProvider.roomListPublisher.value.first(where: { $0.id == identifier }) {
|
|
await .joined(JoinedRoomProxyMock(.init(id: room.id, name: room.name)))
|
|
} else if let spaceRoom = configuration.joinedSpaceRooms.first(where: { $0.id == identifier }) {
|
|
await .joined(JoinedRoomProxyMock(.init(id: spaceRoom.id, name: spaceRoom.name)))
|
|
} else {
|
|
nil
|
|
}
|
|
}
|
|
|
|
userIdentityForReturnValue = .success(UserIdentityProxyMock(configuration: .init()))
|
|
|
|
underlyingIsReportRoomSupported = true
|
|
underlyingIsLiveKitRTCSupported = true
|
|
|
|
underlyingTimelineMediaVisibilityPublisher = CurrentValueSubject<TimelineMediaVisibility, Never>(configuration.timelineMediaVisibility).asCurrentValuePublisher()
|
|
underlyingHideInviteAvatarsPublisher = CurrentValueSubject<Bool, Never>(configuration.hideInviteAvatars).asCurrentValuePublisher()
|
|
|
|
underlyingMaxMediaUploadSize = .success(configuration.maxMediaUploadSize)
|
|
}
|
|
}
|