Как протестировать Future Publisher с помощью модульных тестов?IOS

Программируем под IOS
Ответить
Anonymous
 Как протестировать Future Publisher с помощью модульных тестов?

Сообщение Anonymous »

Это мой простой класс, который мне нужно протестировать:

Код: Выделить всё

class Example: ObservableObject {
@Published var isError = false
var cancellable: AnyCancellable?
private let failure: Bool
// MARK: - Initialization

init(failure: Bool) {
self.failure = failure
}

// MARK: - Internal

func fetch() {
isError = false
cancellable = fetch(type: "abc")
.receive(on: DispatchQueue.main)
.sink(receiveCompletion: { [weak self, type] result in
if case .failure = result {
self?.isError = true
}
}, receiveValue: { [weak self] value in
print(value)
})
.eraseToAnyPublisher()
}

// MARK: - Private

private func fetch(type: String) -> Future {
Future { [weak self] promise in
Task {
do {
let value = try await self?.check(type: type)
promise(.success(value))
} catch {
promise(.failure(error))
}
}
}
}

private func check(type: String) async throws -> String {
// do some acync fetch
if failure {
throw MyError.example
} else {
return "result: \(type)"
}
}
}

enum MyError: Error {
case example
}
а вот модульный тест:

Код: Выделить всё

func testWithSuccess() {
let sut = Example(failure: false)
XCTAssertFalse(sut.isError)
sut.fetch()
XCTAssertTrue(sut.isError)
}
Но, прежде всего, тип выражения неоднозначен без аннотации типа рядом с отменяемой строкой. и почему раковина(...) вообще не вызывается?
Это упрощенный пример, указывающий на проблему.

Подробнее здесь: https://stackoverflow.com/questions/798 ... unit-tests
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «IOS»