Skip to content

Commit

Permalink
refactor: Clearer code paths
Browse files Browse the repository at this point in the history
  • Loading branch information
fabriziodemaria committed Nov 7, 2024
1 parent 1cd12a7 commit 632c3bf
Showing 1 changed file with 27 additions and 8 deletions.
35 changes: 27 additions & 8 deletions Sources/Confidence/FlagEvaluation.swift
Original file line number Diff line number Diff line change
Expand Up @@ -44,17 +44,12 @@ extension FlagResolution {
)
}

if resolvedFlag.resolveReason == .targetingKeyError {
return Evaluation(
value: defaultValue,
variant: nil,
reason: .targetingKeyError,
errorCode: .invalidContext,
errorMessage: "Invalid targeting key"
)
if let evaluation = checkBackendErrrs(resolvedFlag: resolvedFlag, defaultValue: defaultValue) {
return evaluation
}

guard let value = resolvedFlag.value else {
// No backend error, but nil value returned. This can happend with "noSegmentMatch" or "archived", for example
Task {
await flagApplier?.apply(flagName: parsedKey.flag, resolveToken: self.resolveToken)
}
Expand Down Expand Up @@ -133,6 +128,30 @@ extension FlagResolution {
}
// swiftlint:enable function_body_length

private func checkBackendErrrs<T>(resolvedFlag: ResolvedValue, defaultValue: T) -> Evaluation<T>? {
if resolvedFlag.resolveReason == .targetingKeyError {
return Evaluation(
value: defaultValue,
variant: nil,
reason: .targetingKeyError,
errorCode: .invalidContext,
errorMessage: "Invalid targeting key"
)
} else if resolvedFlag.resolveReason == .error ||
resolvedFlag.resolveReason == .unknown ||
resolvedFlag.resolveReason == .unspecified {
return Evaluation(
value: defaultValue,
variant: nil,
reason: .error,
errorCode: .evaluationError,
errorMessage: "Unknown error from backend"
)
} else {
return nil
}
}

// swiftlint:disable:next cyclomatic_complexity
private func getTyped<T>(value: ConfidenceValue) -> T? {
if let value = self as? T {
Expand Down

0 comments on commit 632c3bf

Please sign in to comment.