Skip to content
Snippets Groups Projects
Select Git revision
  • 668751d8da11eddc9b161041316b9bc85cd74a54
  • release default protected
  • 11-22-implement-kv-interface-defined-in-collectiveversionedkvgo
  • hotfix/TestHostPool_UpdateNdf_AddFilter
  • XX-4719/announcementChannels
  • xx-4717/logLevel
  • jonah/noob-channel
  • master protected
  • XX-4707/tagDiskJson
  • xx-4698/notification-retry
  • hotfix/notifylockup
  • syncNodes
  • hotfix/localCB
  • XX-4677/NewChanManagerMobile
  • XX-4689/DmSync
  • duplicatePrefix
  • XX-4601/HavenInvites
  • finalizedUICallbacks
  • XX-4673/AdminKeySync
  • debugNotifID
  • anne/test
  • v4.7.5
  • v4.7.4
  • v4.7.3
  • v4.7.2
  • v4.7.1
  • v4.6.3
  • v4.6.1
  • v4.5.0
  • v4.4.4
  • v4.3.11
  • v4.3.8
  • v4.3.7
  • v4.3.6
  • v4.3.5
  • v4.2.0
  • v4.3.0
  • v4.3.4
  • v4.3.3
  • v4.3.2
  • v4.3.1
41 results

jsonStorage.go

Blame
  • MessengerStop.swift 1.39 KiB
    import Foundation
    import XCTestDynamicOverlay
    import XXClient
    
    public struct MessengerStop {
      public struct Wait: Equatable {
        public init(
          sleepInterval: TimeInterval = 1,
          retries: Int = 10
        ) {
          self.sleepInterval = sleepInterval
          self.retries = retries
        }
    
        public var sleepInterval: TimeInterval
        public var retries: Int
      }
    
      public enum Error: Swift.Error, Equatable {
        case notLoaded
        case timedOut
      }
    
      public var run: (Wait?) throws -> Void
    
      public func callAsFunction(wait: Wait? = nil) throws -> Void {
        try run(wait)
      }
    }
    
    extension MessengerStop {
      public static func live(_ env: MessengerEnvironment) -> MessengerStop {
        MessengerStop { wait in
          guard let cMix = env.cMix() else {
            throw Error.notLoaded
          }
          guard cMix.networkFollowerStatus() == .running else {
            return
          }
          try cMix.stopNetworkFollower()
          guard let wait else { return }
          var retries = wait.retries
          var hasRunningProcesses = cMix.hasRunningProcesses()
          while retries > 0 && hasRunningProcesses {
            env.sleep(wait.sleepInterval)
            hasRunningProcesses = cMix.hasRunningProcesses()
            retries -= 1
          }
          if hasRunningProcesses {
            throw Error.timedOut
          }
        }
      }
    }
    
    extension MessengerStop {
      public static let unimplemented = MessengerStop(
        run: XCTUnimplemented("\(Self.self)")
      )
    }