mirror of
https://github.com/metabolist/metatext.git
synced 2024-11-18 14:21:04 +00:00
61 lines
2 KiB
Swift
61 lines
2 KiB
Swift
// Copyright © 2020 Metabolist. All rights reserved.
|
|
|
|
import Combine
|
|
import CombineExpectations
|
|
import HTTP
|
|
import Mastodon
|
|
import MockKeychain
|
|
import ServiceLayer
|
|
import ServiceLayerMocks
|
|
@testable import ViewModels
|
|
import XCTest
|
|
|
|
class AddIdentityViewModelTests: XCTestCase {
|
|
func testAddIdentity() throws {
|
|
let sut = AddIdentityViewModel(allIdentitiesService: try AllIdentitiesService(environment: .mock()))
|
|
let addedIDRecorder = sut.addedIdentityID.record()
|
|
|
|
sut.urlFieldText = "https://mastodon.social"
|
|
sut.logInTapped()
|
|
|
|
_ = try wait(for: addedIDRecorder.next(), timeout: 1)
|
|
}
|
|
|
|
func testAddIdentityWithoutScheme() throws {
|
|
let sut = AddIdentityViewModel(allIdentitiesService: try AllIdentitiesService(environment: .mock()))
|
|
let addedIDRecorder = sut.addedIdentityID.record()
|
|
|
|
sut.urlFieldText = "mastodon.social"
|
|
sut.logInTapped()
|
|
|
|
_ = try wait(for: addedIDRecorder.next(), timeout: 1)
|
|
}
|
|
|
|
func testInvalidURL() throws {
|
|
let sut = AddIdentityViewModel(allIdentitiesService: try AllIdentitiesService(environment: .mock()))
|
|
let recorder = sut.$alertItem.record()
|
|
|
|
XCTAssertNil(try wait(for: recorder.next(), timeout: 1))
|
|
|
|
sut.urlFieldText = "🐘.social"
|
|
sut.logInTapped()
|
|
|
|
let alertItem = try wait(for: recorder.next(), timeout: 1)
|
|
|
|
XCTAssertEqual((alertItem?.error as? URLError)?.code, URLError.badURL)
|
|
}
|
|
|
|
func testDoesNotAlertCanceledLogin() throws {
|
|
let allIdentitiesService = try AllIdentitiesService(
|
|
environment: .mock(webAuthSessionType: CanceledLoginMockWebAuthSession.self))
|
|
let sut = AddIdentityViewModel(allIdentitiesService: allIdentitiesService)
|
|
let recorder = sut.$alertItem.record()
|
|
|
|
XCTAssertNil(try wait(for: recorder.next(), timeout: 1))
|
|
|
|
sut.urlFieldText = "https://mastodon.social"
|
|
sut.logInTapped()
|
|
|
|
try wait(for: recorder.next().inverted, timeout: 1)
|
|
}
|
|
}
|