From 973cd52fafacb22854a96ed72b6ce340902f45b0 Mon Sep 17 00:00:00 2001 From: Dariusz Rybicki <dariusz@elixxir.io> Date: Fri, 14 Oct 2022 12:40:07 +0200 Subject: [PATCH] Add MessengerReceiveFile function --- .../Functions/MessengerReceiveFile.swift | 32 +++++++++++++++++++ .../Messenger/Messenger.swift | 7 ++-- .../Functions/MessengerReceiveFileTests.swift | 27 ++++++++++++++++ 3 files changed, 64 insertions(+), 2 deletions(-) create mode 100644 Sources/XXMessengerClient/Messenger/Functions/MessengerReceiveFile.swift create mode 100644 Tests/XXMessengerClientTests/Messenger/Functions/MessengerReceiveFileTests.swift diff --git a/Sources/XXMessengerClient/Messenger/Functions/MessengerReceiveFile.swift b/Sources/XXMessengerClient/Messenger/Functions/MessengerReceiveFile.swift new file mode 100644 index 00000000..91230c63 --- /dev/null +++ b/Sources/XXMessengerClient/Messenger/Functions/MessengerReceiveFile.swift @@ -0,0 +1,32 @@ +import Foundation +import XCTestDynamicOverlay +import XXClient + +public struct MessengerReceiveFile { + public enum Error: Swift.Error, Equatable { + case notConnected + } + + public var run: () throws -> Void + + public func callAsFunction() throws -> Void { + try run() + } +} + +extension MessengerReceiveFile { + public static func live(_ env: MessengerEnvironment) -> MessengerReceiveFile { + MessengerReceiveFile { + guard let e2e = env.e2e() else { + throw Error.notConnected + } + // TODO: implement receiving file + } + } +} + +extension MessengerReceiveFile { + public static let unimplemented = MessengerReceiveFile( + run: XCTUnimplemented("\(Self.self)") + ) +} diff --git a/Sources/XXMessengerClient/Messenger/Messenger.swift b/Sources/XXMessengerClient/Messenger/Messenger.swift index 22f11030..b2cc82fb 100644 --- a/Sources/XXMessengerClient/Messenger/Messenger.swift +++ b/Sources/XXMessengerClient/Messenger/Messenger.swift @@ -40,6 +40,7 @@ public struct Messenger { public var stopBackup: MessengerStopBackup public var setLogLevel: MessengerSetLogLevel public var startLogging: MessengerStartLogging + public var receiveFile: MessengerReceiveFile } extension Messenger { @@ -83,7 +84,8 @@ extension Messenger { backupParams: .live(env), stopBackup: .live(env), setLogLevel: .live(env), - startLogging: .live(env) + startLogging: .live(env), + receiveFile: .live(env) ) } } @@ -128,6 +130,7 @@ extension Messenger { backupParams: .unimplemented, stopBackup: .unimplemented, setLogLevel: .unimplemented, - startLogging: .unimplemented + startLogging: .unimplemented, + receiveFile: .unimplemented ) } diff --git a/Tests/XXMessengerClientTests/Messenger/Functions/MessengerReceiveFileTests.swift b/Tests/XXMessengerClientTests/Messenger/Functions/MessengerReceiveFileTests.swift new file mode 100644 index 00000000..ef9b5864 --- /dev/null +++ b/Tests/XXMessengerClientTests/Messenger/Functions/MessengerReceiveFileTests.swift @@ -0,0 +1,27 @@ +import CustomDump +import XCTest +import XXClient +@testable import XXMessengerClient + +final class MessengerReceiveFileTests: XCTestCase { + func testReceiveFile() throws { + var env: MessengerEnvironment = .unimplemented + env.e2e.get = { .unimplemented } + let receiveFile: MessengerReceiveFile = .live(env) + + try receiveFile() + } + + func testReceiveFileWhenNotConnected() { + var env: MessengerEnvironment = .unimplemented + env.e2e.get = { nil } + let receiveFile: MessengerReceiveFile = .live(env) + + XCTAssertThrowsError(try receiveFile()) { error in + XCTAssertNoDifference( + error as? MessengerReceiveFile.Error, + MessengerReceiveFile.Error.notConnected + ) + } + } +} -- GitLab