| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241 |
- // Copyright 2023 Google LLC
- //
- // Licensed under the Apache License, Version 2.0 (the "License");
- // you may not use this file except in compliance with the License.
- // You may obtain a copy of the License at
- //
- // http://www.apache.org/licenses/LICENSE-2.0
- //
- // Unless required by applicable law or agreed to in writing, software
- // distributed under the License is distributed on an "AS IS" BASIS,
- // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- // See the License for the specific language governing permissions and
- // limitations under the License.
- import XCTest
- import FirebaseCore
- import FirebaseRemoteConfig
- import FirebaseRemoteConfigInterop
- final class FirebaseRemoteConfig_APIBuildTests: XCTestCase {
- func usage() throws {
- // MARK: - FirebaseRemoteConfig
- // TODO(ncooke3): These global constants should be lowercase.
- let _: String = FirebaseRemoteConfig.NamespaceGoogleMobilePlatform
- let _: String = FirebaseRemoteConfig.RemoteConfigThrottledEndTimeInSecondsKey
- // TODO(ncooke3): This should probably not be initializable.
- FirebaseRemoteConfig.ConfigUpdateListenerRegistration().remove()
- let fetchStatus: FirebaseRemoteConfig.RemoteConfigFetchStatus? = nil
- switch fetchStatus! {
- case .noFetchYet: break
- case .success: break
- case .failure: break
- case .throttled: break
- @unknown default: break
- }
- let fetchAndActivateStatus: FirebaseRemoteConfig.RemoteConfigFetchAndActivateStatus? = nil
- switch fetchAndActivateStatus! {
- case .successFetchedFromRemote: break
- case .successUsingPreFetchedData: break
- case .error: break
- @unknown default: break
- }
- // Used to pass into the initializers for the custom errors below.
- let nsError = NSError(domain: "", code: 0, userInfo: nil)
- // TODO(ncooke3): Global constants should be lowercase.
- let _: String = FirebaseRemoteConfig.RemoteConfigErrorDomain
- let _ = FirebaseRemoteConfig.RemoteConfigError(_nsError: nsError)
- let _: FirebaseRemoteConfig.RemoteConfigError.Code._ErrorType = FirebaseRemoteConfig
- .RemoteConfigError(_nsError: nsError)
- let _: String = FirebaseRemoteConfig.RemoteConfigError.errorDomain
- let code: FirebaseRemoteConfig.RemoteConfigError.Code? = nil
- switch code! {
- case .unknown: break
- case .throttled: break
- case .internalError: break
- @unknown default: break
- }
- _ = FirebaseRemoteConfig.RemoteConfigError.unknown
- _ = FirebaseRemoteConfig.RemoteConfigError.throttled
- _ = FirebaseRemoteConfig.RemoteConfigError.internalError
- // TODO(ncooke3): Global constants should be lowercase.
- let _: String = FirebaseRemoteConfig.RemoteConfigUpdateErrorDomain
- let _ = FirebaseRemoteConfig.RemoteConfigUpdateError(_nsError: nsError)
- let _: FirebaseRemoteConfig.RemoteConfigUpdateError.Code._ErrorType = FirebaseRemoteConfig
- .RemoteConfigUpdateError(_nsError: nsError)
- let _: String = FirebaseRemoteConfig.RemoteConfigUpdateError.errorDomain
- let updateErrorCode: FirebaseRemoteConfig.RemoteConfigUpdateError.Code? = nil
- switch updateErrorCode! {
- case .streamError: break
- case .notFetched: break
- case .messageInvalid: break
- case .unavailable: break
- @unknown default: break
- }
- _ = FirebaseRemoteConfig.RemoteConfigUpdateError.streamError
- _ = FirebaseRemoteConfig.RemoteConfigUpdateError.notFetched
- _ = FirebaseRemoteConfig.RemoteConfigUpdateError.messageInvalid
- _ = FirebaseRemoteConfig.RemoteConfigUpdateError.unavailable
- // TODO(ncooke3): This should probably not be initializable.
- let value = FirebaseRemoteConfig.RemoteConfigValue()
- let _: String? = value.stringValue
- // TODO(ncooke3): Returns an Objective-C reference type.
- let _: NSNumber = value.numberValue
- let _: Data = value.dataValue
- let _: Bool = value.boolValue
- let _: Any? = value.jsonValue
- let source: FirebaseRemoteConfig.RemoteConfigSource = value.source
- switch source {
- case .remote: break
- case .default: break
- case .static: break
- @unknown default: break
- }
- let settings = FirebaseRemoteConfig.RemoteConfigSettings()
- settings.minimumFetchInterval = TimeInterval(100)
- settings.fetchTimeout = TimeInterval(100)
- // TODO(ncooke3): This should probably not be initializable.
- let update = FirebaseRemoteConfig.RemoteConfigUpdate()
- let _: Set<String> = update.updatedKeys
- let _ = FirebaseRemoteConfig.RemoteConfig.remoteConfig()
- let config = FirebaseRemoteConfig.RemoteConfig
- .remoteConfig(app: FirebaseCore.FirebaseApp.app()!)
- let _: Date? = config.lastFetchTime
- let _: FirebaseRemoteConfig.RemoteConfigFetchStatus = config.lastFetchStatus
- let _: FirebaseRemoteConfig.RemoteConfigSettings = config.configSettings
- config.ensureInitialized(completionHandler: { (error: Error?) in })
- config.fetch(completionHandler: { (status: FirebaseRemoteConfig.RemoteConfigFetchStatus,
- error: Error?) in })
- config.fetch()
- config.fetch(
- withExpirationDuration: TimeInterval(100),
- completionHandler: { (status: FirebaseRemoteConfig.RemoteConfigFetchStatus, error: Error?) in
- }
- )
- config.fetch(withExpirationDuration: TimeInterval(100))
- config
- .fetchAndActivate(
- completionHandler: { (status: FirebaseRemoteConfig.RemoteConfigFetchAndActivateStatus,
- error: Error?) in }
- )
- config.fetchAndActivate()
- config.activate(completion: { (success: Bool, error: Error?) in })
- config.activate()
- if #available(iOS 13.0, *) {
- Task {
- let _: Void = try await config.ensureInitialized()
- let _: FirebaseRemoteConfig.RemoteConfigFetchStatus = try await config.fetch()
- let _: FirebaseRemoteConfig.RemoteConfigFetchStatus = try await config
- .fetch(withExpirationDuration: TimeInterval(100))
- let _: FirebaseRemoteConfig.RemoteConfigFetchAndActivateStatus = try await config
- .fetchAndActivate()
- let _: Bool = try await config.activate()
- }
- }
- let _: FirebaseRemoteConfig.RemoteConfigValue = config["key"]
- let _: FirebaseRemoteConfig.RemoteConfigValue = config.configValue(forKey: "key")
- // TODO(ncooke3): Should `nil` be acceptable here in a Swift context?
- let _: FirebaseRemoteConfig.RemoteConfigValue = config.configValue(forKey: nil)
- let _: FirebaseRemoteConfig.RemoteConfigValue = config.configValue(
- forKey: "key",
- source: source
- )
- // TODO(ncooke3): Should `nil` be acceptable here in a Swift context?
- let _: FirebaseRemoteConfig.RemoteConfigValue = config.configValue(forKey: nil, source: source)
- let _: [String] = config.allKeys(from: source)
- let _: Set<String> = config.keys(withPrefix: "")
- // TODO(ncooke3): Should `nil` be acceptable here in a Swift context?
- let _: Set<String> = config.keys(withPrefix: nil)
- let defaults: [String: NSObject]? = [:]
- config.setDefaults(defaults)
- // TODO(ncooke3): Should `nil` be acceptable here in a Swift context?
- config.setDefaults(nil)
- config.setDefaults(fromPlist: "")
- // TODO(ncooke3): Should `nil` be acceptable here in a Swift context?
- config.setDefaults(fromPlist: nil)
- let _: FirebaseRemoteConfig.RemoteConfigValue? = config.defaultValue(forKey: "")
- // TODO(ncooke3): Should `nil` be acceptable here in a Swift context?
- let _: FirebaseRemoteConfig.RemoteConfigValue? = config.defaultValue(forKey: nil)
- let _: FirebaseRemoteConfig.ConfigUpdateListenerRegistration = config
- .addOnConfigUpdateListener(
- remoteConfigUpdateCompletion: { (update: FirebaseRemoteConfig.RemoteConfigUpdate?,
- error: Error?) in
- }
- )
- let valueError: FirebaseRemoteConfig
- .RemoteConfigValueCodableError = .unsupportedType("foo")
- switch valueError {
- case .unsupportedType: break
- }
- let error: FirebaseRemoteConfig.RemoteConfigCodableError = .invalidSetDefaultsInput("foo")
- switch error {
- case .invalidSetDefaultsInput: break
- }
- @available(iOS 14.0, macOS 11.0, macCatalyst 14.0, tvOS 14.0, watchOS 7.0, *)
- struct PropertyWrapperTester {
- @FirebaseRemoteConfig.RemoteConfigProperty(key: "", fallback: "")
- var stringValue: String!
- }
- struct MyDecodableValue: Decodable {}
- let _: MyDecodableValue? = config[decodedValue: ""]
- let _: [String: AnyHashable]? = config[jsonValue: ""]
- let _: MyDecodableValue = try value.decoded()
- let _: MyDecodableValue = try value.decoded(asType: MyDecodableValue.self)
- let _: MyDecodableValue? = try config.decoded()
- let _: MyDecodableValue? = try config.decoded(asType: MyDecodableValue.self)
- struct MyEncodableValue: Encodable {}
- let _: Void = try config.setDefaults(from: MyEncodableValue())
- Task {
- let signals: [String: CustomSignalValue?] = [
- "signal_1": .integer(5),
- "signal_2": .string("enable_feature"),
- "signal_3": 5,
- "signal_4": "enable_feature",
- "signal_5": "enable_feature_\("secret")",
- "signal_6": .double(3.14),
- "signal_7": 3.14159,
- "signal_8": nil, // Used to delete the custom signal for a given key.
- ]
- try await config.setCustomSignals(signals)
- }
- }
- }
|