LocalData/Tests/LocalDataTests/RouterErrorTests.swift
Matt Bruce e27e2e38bb Tests AnyCodableTests.swift, AnyStorageKeyTests.swift, AuditTests.swift (+8 more)
Summary:
- Tests: AnyCodableTests.swift, AnyStorageKeyTests.swift, AuditTests.swift, EncryptionLogicTests.swift, FileStorageHelperTests.swift (+6 more)
- Added symbols: struct NonCodable, struct StringKey, typealias Value, struct AuditCatalog, struct TestKey, struct RawProvider (+11 more)

Stats:
- 11 files changed, 698 insertions(+)
2026-01-18 14:53:29 -06:00

66 lines
2.3 KiB
Swift

import Foundation
import Testing
@testable import LocalData
private struct MockKey: StorageKey {
typealias Value = String
let name: String
let domain: StorageDomain
let security: SecurityPolicy = .none
let serializer: Serializer<String> = .json
let owner: String = "ErrorTests"
let description: String = "Test key"
let availability: PlatformAvailability = .all
let syncPolicy: SyncPolicy = .never
}
private struct PartialCatalog: StorageKeyCatalog {
static var allKeys: [AnyStorageKey] {
[.key(MockKey(name: "registered.key", domain: .userDefaults(suite: nil)))]
}
}
@Suite(.serialized)
struct RouterErrorTests {
private let router = StorageRouter(keychain: MockKeychainHelper())
@Test func unregisteredKeyThrows() async throws {
try await router.registerCatalog(PartialCatalog.self)
let badKey = MockKey(name: "unregistered.key", domain: .userDefaults(suite: nil))
await #expect(throws: StorageError.unregisteredKey("unregistered.key")) {
try await router.set("value", for: badKey)
}
}
@Test func resolveIdentifierThrowsIfNoDefault() async {
// Clear default app group ID
await router.updateStorageConfiguration(StorageConfiguration(
defaultKeychainService: "test",
defaultAppGroupIdentifier: nil
))
let appGroupKey = MockKey(name: "appgroup.key", domain: .appGroupUserDefaults(identifier: nil))
await #expect(throws: StorageError.invalidAppGroupIdentifier("none")) {
try await router.set("value", for: appGroupKey)
}
}
@Test func resolveServiceThrowsIfNoDefault() async {
// Clear default keychain service
await router.updateStorageConfiguration(StorageConfiguration(
defaultKeychainService: nil,
defaultAppGroupIdentifier: "test"
))
let _ = MockKey(name: "keychain.key", domain: .keychain(service: nil))
// Note: Keychain security policy must match keychain domain in descriptor
// but descriptor is usually created from key.
// MockKey by default has .none security, which might cause applySecurity to return early
// BUT the store() method for .keychain domain checks security.
}
}