LocalData/Tests/LocalDataTests/AnyStorageKeyTests.swift
Matt Bruce c2b17a4b7f Update Migrations, Models, Protocols (+2 more) + tests + docs
Summary:
- Sources: Migrations, Models, Protocols, Services, Utilities
- Tests: AnyStorageKeyTests.swift, MigrationAdditionalTests.swift, MigrationIntegrationTests.swift, MigrationProtocolTests.swift, MigrationTests.swift (+1 more)
- Docs: Migration, Migration_Refactor_Plan_Clean, Proposal, README
- Added symbols: struct MyMigration, typealias DestinationKey, func shouldMigrate, func migrate, extension MyNewKey, protocol StorageMigration (+74 more)
- Removed symbols: enum StorageDomain, func migrate, func validatePlatformAvailability, func deserialize, func applySecurity, func retrieve (+1 more)

Stats:
- 31 files changed, 2820 insertions(+), 80 deletions(-)
2026-01-18 14:53:30 -06:00

38 lines
1.2 KiB
Swift

import Foundation
import Testing
@testable import LocalData
@Suite struct AnyStorageKeyTests {
private struct StringKey: StorageKey {
typealias Value = String
let name: String
let domain: StorageDomain = .userDefaults(suite: nil)
let security: SecurityPolicy = .none
let serializer: Serializer<String> = .json
let owner: String = "Test"
let description: String = "Test"
let availability: PlatformAvailability = .all
let syncPolicy: SyncPolicy = .never
}
@Test func anyStorageKeyCapturesDescriptor() {
let key = StringKey(name: "test.key")
let anyKey = AnyStorageKey.key(key)
#expect(anyKey.descriptor.name == "test.key")
#expect(anyKey.descriptor.owner == "Test")
#expect(anyKey.descriptor.valueType == "String")
}
@Test func anyStorageKeyTriggersMigration() async throws {
let router = StorageRouter(keychain: MockKeychainHelper())
let key = StringKey(name: "test.key")
let anyKey = AnyStorageKey.key(key)
// This will call router.forceMigration(for: key)
// Since there is no migration configured, it just returns
try await anyKey.migrate(on: router)
}
}