2023-06-28 11:39:38 +02:00
|
|
|
//
|
2024-09-06 16:34:30 +03:00
|
|
|
// Copyright 2023, 2024 New Vector Ltd.
|
2023-06-28 11:39:38 +02:00
|
|
|
//
|
2025-01-06 11:27:37 +01:00
|
|
|
// SPDX-License-Identifier: AGPL-3.0-only OR LicenseRef-Element-Commercial
|
|
|
|
// Please see LICENSE files in the repository root for full details.
|
2023-06-28 11:39:38 +02:00
|
|
|
//
|
|
|
|
|
|
|
|
import Combine
|
|
|
|
import XCTest
|
|
|
|
|
|
|
|
@testable import ElementX
|
|
|
|
|
|
|
|
@MainActor
|
|
|
|
class StaticLocationScreenViewModelTests: XCTestCase {
|
|
|
|
var viewModel: StaticLocationScreenViewModelProtocol!
|
|
|
|
|
2023-09-14 12:53:33 +03:00
|
|
|
private var cancellables = Set<AnyCancellable>()
|
2023-06-28 11:39:38 +02:00
|
|
|
|
|
|
|
var context: StaticLocationScreenViewModel.Context {
|
|
|
|
viewModel.context
|
|
|
|
}
|
|
|
|
|
|
|
|
override func setUpWithError() throws {
|
2023-09-14 12:53:33 +03:00
|
|
|
cancellables.removeAll()
|
2023-06-29 11:12:42 +02:00
|
|
|
let viewModel = StaticLocationScreenViewModel(interactionMode: .picker)
|
2023-07-11 12:42:59 +02:00
|
|
|
viewModel.state.bindings.isLocationAuthorized = true
|
2023-06-28 11:39:38 +02:00
|
|
|
self.viewModel = viewModel
|
|
|
|
}
|
|
|
|
|
|
|
|
func testUserDidPan() async throws {
|
2023-07-05 12:54:03 +02:00
|
|
|
XCTAssertTrue(context.viewState.isSharingUserLocation)
|
2023-07-11 12:42:59 +02:00
|
|
|
XCTAssertEqual(context.showsUserLocationMode, .showAndFollow)
|
2023-06-28 11:39:38 +02:00
|
|
|
context.send(viewAction: .userDidPan)
|
2023-07-05 12:54:03 +02:00
|
|
|
XCTAssertFalse(context.viewState.isSharingUserLocation)
|
2023-07-11 12:42:59 +02:00
|
|
|
XCTAssertEqual(context.showsUserLocationMode, .show)
|
|
|
|
}
|
|
|
|
|
|
|
|
func testCenterOnUser() async throws {
|
|
|
|
XCTAssertTrue(context.viewState.isSharingUserLocation)
|
|
|
|
context.showsUserLocationMode = .show
|
|
|
|
XCTAssertFalse(context.viewState.isSharingUserLocation)
|
|
|
|
context.send(viewAction: .centerToUser)
|
|
|
|
XCTAssertTrue(context.viewState.isSharingUserLocation)
|
|
|
|
XCTAssertEqual(context.showsUserLocationMode, .showAndFollow)
|
|
|
|
}
|
|
|
|
|
|
|
|
func testCenterOnUserWithoutAuth() async throws {
|
|
|
|
context.showsUserLocationMode = .hide
|
|
|
|
context.isLocationAuthorized = nil
|
|
|
|
context.send(viewAction: .centerToUser)
|
|
|
|
XCTAssertEqual(context.showsUserLocationMode, .showAndFollow)
|
|
|
|
}
|
|
|
|
|
|
|
|
func testCenterOnUserWithDeniedAuth() async throws {
|
|
|
|
context.isLocationAuthorized = false
|
|
|
|
context.showsUserLocationMode = .hide
|
|
|
|
context.send(viewAction: .centerToUser)
|
|
|
|
XCTAssertNotEqual(context.showsUserLocationMode, .showAndFollow)
|
|
|
|
XCTAssertNotNil(context.alertInfo)
|
|
|
|
}
|
|
|
|
|
|
|
|
func testErrorMapping() async throws {
|
|
|
|
let mapError = AlertInfo(locationSharingViewError: .mapError(.failedLoadingMap))
|
|
|
|
XCTAssertEqual(mapError.message, L10n.errorFailedLoadingMap(InfoPlistReader.main.bundleDisplayName))
|
|
|
|
let locationError = AlertInfo(locationSharingViewError: .mapError(.failedLocatingUser))
|
|
|
|
XCTAssertEqual(locationError.message, L10n.errorFailedLocatingUser(InfoPlistReader.main.bundleDisplayName))
|
|
|
|
let authorizationError = AlertInfo(locationSharingViewError: .missingAuthorization)
|
2023-10-24 16:57:27 +02:00
|
|
|
XCTAssertEqual(authorizationError.message, L10n.dialogPermissionLocationDescriptionIos)
|
2023-06-28 11:39:38 +02:00
|
|
|
}
|
2023-07-12 11:02:05 +02:00
|
|
|
|
|
|
|
func testSendUserLocation() async throws {
|
|
|
|
context.mapCenterLocation = .init(latitude: 0, longitude: 0)
|
|
|
|
context.geolocationUncertainty = 10
|
2023-09-26 13:28:29 +03:00
|
|
|
|
|
|
|
let deferred = deferFulfillment(viewModel.actions) { action in
|
|
|
|
switch action {
|
|
|
|
case .sendLocation:
|
|
|
|
return true
|
|
|
|
default:
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-07-12 11:02:05 +02:00
|
|
|
context.send(viewAction: .selectLocation)
|
|
|
|
guard case .sendLocation(let geoUri, let isUserLocation) = try await deferred.fulfill() else {
|
|
|
|
XCTFail("Sent action should be 'sendLocation'")
|
|
|
|
return
|
|
|
|
}
|
|
|
|
XCTAssertEqual(geoUri.uncertainty, 10)
|
|
|
|
XCTAssertTrue(isUserLocation)
|
|
|
|
}
|
|
|
|
|
|
|
|
func testSendPickedLocation() async throws {
|
|
|
|
context.mapCenterLocation = .init(latitude: 0, longitude: 0)
|
|
|
|
context.isLocationAuthorized = nil
|
|
|
|
context.geolocationUncertainty = 10
|
2023-09-26 13:28:29 +03:00
|
|
|
|
|
|
|
let deferred = deferFulfillment(viewModel.actions) { action in
|
|
|
|
switch action {
|
|
|
|
case .sendLocation:
|
|
|
|
return true
|
|
|
|
default:
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-07-12 11:02:05 +02:00
|
|
|
context.send(viewAction: .selectLocation)
|
|
|
|
guard case .sendLocation(let geoUri, let isUserLocation) = try await deferred.fulfill() else {
|
|
|
|
XCTFail("Sent action should be 'sendLocation'")
|
|
|
|
return
|
|
|
|
}
|
|
|
|
XCTAssertEqual(geoUri.uncertainty, nil)
|
|
|
|
XCTAssertFalse(isUserLocation)
|
|
|
|
}
|
2023-06-28 11:39:38 +02:00
|
|
|
}
|